## 0. 阅读完本文你将会学会- 写出更优雅高效的Java代码## 1. 前言周六逛B乎的时候正好刷到这样一个问题 **"Java开发手册(黄山版)怎么样?"**,我仔细一看这不是孤尽老师的著作吗?居然已经更新到了黄山版。上次... // 反例: 开发者 A 定义了缓存的 key。 String key = "Id#taobao_" + tradeId; cache.put(key, value); // 开发者 B 使用缓存时直接复制少了下划线,// 即 key 是"Id#taobao" + tradeId,导致出现故障。 String...
## 一、前言- 开发Java项目过程中,难免会碰到一些 性能 问题,这时候就需要一些工具,帮忙排查- 本文主要介绍 JDK自带的上古神器 jstat、jmap,用于分析内存问题,另简单介绍 MAT、gceasy、HeapDump 等- 以 openjdk... `-t` 表示每行开头输出 相对应用启动时间的Timestamp 时间戳### 2. jstat -gcutil- 常用命令格式:jstat -gcutil 进程号 持续输出间隔毫秒数,下图每隔 1000毫秒输出一次- 前6列 输出各个内存区域使用百分比 (没...
## 一、前言 - 还在为排查Java程序线上问题头痛吗,看我们用阿里开源的诊断神器 Arthas 来帮您- 本文开篇主要介绍 阿里开源的诊断神器Arthas 3.7.0版本,watch、jad、classloader 命令,以 Debian 11、openjdk 11 为例## 二、Arthas 简介和安装 ### 1. [简介](https://arthas.aliyun.com/doc/) - Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息- 并能在不修改应用代码的情况下,...
时间处理时的数据乱序和数据迟到的问题。- Window:提供了一套开箱即用的窗口操作,如滚动窗口、滑动窗口、会话窗口,支持非常灵活的自定义窗口满足特殊业务需求。- 带反压的流模型Flink是采用java开发的,flink计算集群运行在java虚拟机中,因为flink计算会面临大量数据处理、大量状态存储,完全基于jvm的堆内存管理存在较大的缺陷,flink基于jvm实现了独立的内存管理:可超出主内存的大小限制、承受更少的垃圾回收开销、对象序...
TOS Java SDK 支持设置下载对象的限定条件。您可以在下载对象时,设置下载对象的限制条件(如对象 ETag 或对象修改时间),当对象信息满足设置的限定条件时服务端才会返回对象数据,否则会返回相应错误。本文介绍如何通... 需保证不存在,否则会覆盖原有文件 String filePath = "example_dir/example_file.txt"; TOSV2 tos = new TOSV2ClientBuilder().build(region, endpoint, accessKey, secretKey); // 以下代码...
本文介绍如何快速使用 TOS Java SDK 完成常见操作,包括客户端通用示例、创建桶、上传对象、下载对象、列举对象和删除对象。 前提条件安装SDK 初始化客户端 客户端通用示例以下代码以上传对象为例,展示使用 TOS Ja... // 上传文件需要指定存储桶名称 String bucketName = "bucket-example"; // 上传文件需要指定唯一的对象名,TOS 以对象名作为唯一标识符, // 如果同个 objectKey 进行多次上传,则后面...
桶(Bucket)是 TOS 的全局唯一的命名空间,相当于数据的容器,用来储存对象(Object)数据。本文介绍如何通过 TOS Java SDK 的 headBucket 接口获取桶的元数据,包括桶所属地域(Region)和桶的存储类型(StorageClass),以及判断桶是否存在。 注意事项获取桶元数据之前,您必须具有 tos:HeadBucket 权限。具体操作,请参见权限配置概述。 若桶不存在则该接口会返回 404,也常用于判断桶是否存在。 示例代码以下代码展示如何获取桶元数据及判...
本文介绍火山引擎对象存储服务 TOS(Tinder Object Storage) Java SDK 在各种场景下的使用方法、接口定义和参数说明,以及针对桶、对象操作的示例代码,方便您参考使用。 SDK 概览项目 参考文档 使用准备 安装 SDK 初始化客户端 快速入门 存储桶接口 桶基础接口 创建桶 列举桶 获取桶元数据 删除桶 获取桶地域 管理桶配置 管理桶 ACL 管理桶策略 管理桶存储类型 管理桶生命周期 管理镜像回源 管理跨域资源共享...
桶(Bucket)是 TOS 的全局唯一的命名空间,相当于数据的容器,用来储存对象(Object)数据。本文介绍如何通过 TOS Java SDK 的 listBuckets 接口列举您账号下所有地域的桶(Bucket)列表。 注意事项列举桶之前,您必须具有 tos:ListBuckets 权限。具体操作,请参见 IAM 策略概述。 此接口会返回当前账号所有地域的桶。 示例代码以下代码展示如何列举当前账号所有地域的桶。 java import com.volcengine.tos.TOSV2;import com.volcengine....
桶(Bucket)是 TOS 的全局唯一的命名空间,相当于数据的容器,用来储存对象(Object)数据。当请求桶中的对象数据不存在时,TOS 默认返回 404 错误。但如果您设置了桶的回源规则,填写了对象数据的正确地址,TOS 将会通过回源规则从源站获取数据。TOS 支持镜像回源和重定向回源两种方式,可以满足您对于数据热迁移、特定请求的重定向等需求。本文介绍如何通过 TOS Java SDK 管理桶的回源规则。 设置镜像回源规则您可以通过 TOS Java SDK 的...
桶(Bucket)是 TOS 的全局唯一的命名空间,相当于数据的容器,用来储存对象(Object)数据。TOS 支持设置桶的跨域访问 CORS(Cross-Origin Resource Sharing)规则。当 TOS 收到跨域请求或 OPTIONS 请求时,会读取桶对应的 CORS 规则,进行相应的权限检查并返回相应的 Header,保证跨域传输数据的安全性。本文介绍如何通过 TOS Java SDK 管理桶的跨区域资源共享配置。 设置跨域资源共享规则您可以通过 TOS Java SDK 的 putBucketCORS 接口设...
如果桶中已经存在同名对象,则新对象会覆盖已有的对象。桶开启多版本的场景下,则会保留原有对象,生成一个新版本号用于标识新上传的对象。 TOS是面向海量存储设计的分布式对象存储产品,内部分区存储了对象索引数据,为横向扩展您上传对象和下载对象时的最大吞吐量,和减小热点分区的概率,请您避免使用字典序递增的对象命名方式,详细信息,请参见性能优化。 基本示例以下代码展示 uploadFile 接口的基本使用方式。 java import com.v...
桶(Bucket)是 TOS 的全局唯一的命名空间,相当于数据的容器,用来储存对象(Object)数据。TOS针对桶(Bucket)资源的权限控制包括桶授权策略(Bucket Policy)和桶访问控制(Bucket ACL)。本文介绍如何通过 TOS Java SDK 管理桶的授权策略(Policy)。有关桶的访问控制管理请参考读写权限配置。 设置桶策略您可以通过 TOS Java SDK 的 putBucketPolicy 接口设置指定桶的授权策略。 注意 设置桶策略,您的账号必须具备 tos:PutBucketPolicy 权...