华为OBS云储存

产品架构
1.OBS的基本组成是桶和对象。
2.桶是OBS中存储对象的容器,每个桶都有自己的存储类别、访问权限、所属区域等属性,用户在互联网上通过桶的访问域名来定位桶。
3.对象是OBS中数据存储的基本单位,一个对象实际是一个文件的数据与其相关属性信息的集合体
4.OBS通过AK/SK对请求进行签名,在向OBS发送请求时,客户端发送的每个消息头需要包含由SK、请求时间、请求类型等信息生成的签名信息。
AK(Access Key ID):访问密钥ID。与私有访问密钥关联的唯一标识符;访问密钥ID和私有访问密钥一起使用,对请求进行加密签名。格式例如:HCY8BGCN1YM5ZWYOK1MH
SK(Secret Access Key):与访问密钥ID结合使用的密钥,对请求进行加密签名,可标识发送方,并防止请求被修改。格式例如:9zYwf1uabSQY0JTnFqbUqG7vcfqYBaTdXde2GUcq
初始化obs客户端
String endPoint = “https://your-endpoint”;
String ak = “*** Provide your Access Key ";
String sk = "
Provide your Secret Key ***”;
// 创建ObsClient实例
ObsClient obsClient = new ObsClient(ak, sk, endPoint);

// 使用访问OBS
    
// 关闭obsClient,全局使用一个ObsClient客户端的情况下,不建议主动关闭ObsClient客户端
obsClient.close();

桶管理
1.创建桶
CreateBucketRequest request = new CreateBucketRequest();
request.setBucketName(“bucketname”);
// 设置桶访问权限为公共读,默认是私有读写
request.setAcl(AccessControlList.REST_CANNED_PUBLIC_READ);
// 设置桶的存储类型为归档存储
request.setBucketStorageClass(StorageClassEnum.COLD);
// 设置桶区域位置(以区域为华北-北京四为例)
request.setLocation(“cn-north-4”);
// 指定创建多AZ桶,如果不设置,默认创建单AZ桶
request.setAvailableZone(AvailableZoneEnum.MULTI_AZ);
try{
// 创建桶成功
ObsBucket bucket = obsClient.createBucket(request);
System.out.println(bucket.getRequestId());
}
2.列举桶
ListBucketsRequest request = new ListBucketsRequest();
request.setQueryLocation(true);
List buckets = obsClient.listBuckets(request);
3.删除桶
obsClient.deleteBucket(“bucketname”);
4.判断桶是否存在
boolean exists = obsClient.headBucket(“bucketname”);
对象管理
1.上传对象
流式上传 对象已存在再次上传会更新对象
String content = “Hello OBS”;
obsClient.putObject(“bucketname”, “objectname”, new ByteArrayInputStream(content.getBytes()));
文件上传
// localfile为待上传的本地文件路径,需要指定到具体的文件名
obsClient.putObject(“bucketname”, “objectkey”, new File(“localfile”));
分段上传
InitiateMultipartUploadRequest request = new InitiateMultipartUploadRequest(“bucketname”, “objectname”);
ObjectMetadata metadata = new ObjectMetadata();
metadata.addUserMetadata(“property”, “property-value”);
metadata.setContentType(“text/plain”);
request.setMetadata(metadata);
InitiateMultipartUploadResult result = obsClient.initiateMultipartUpload(request);
追加上传 ObsClient.putObject上传的对象可覆盖ObsClient.appendObject上传的对象,覆盖后对象变为普通对象,不可再进行追加上传。
AppendObjectRequest request = new AppendObjectRequest();
request.setBucketName(“bucketname”);
request.setObjectKey(“objectname”);
request.setPosition(0);
request.setInput(new ByteArrayInputStream(“Hello OBS”.getBytes()));
AppendObjectResult result = obsClient.appendObject(request);
2.对象下载 公共桶的对象信息可以根据 域名/objectkey直接访问
流式下载
ObsObject obsObject = obsClient.getObject(“bucketname”, “objectname”);
// 读取对象内容
System.out.println(“Object content:”);
InputStream input = obsObject.getObjectContent();
byte[] b = new byte[1024];
ByteArrayOutputStream bos = new ByteArrayOutputStream();
int len;
while ((len=input.read(b)) != -1){
bos.write(b, 0, len);
}

	System.out.println(new String(bos.toByteArray()));
	bos.close();
	input.close();
3.列举对象 可以根据前缀,指定范围等参数过滤获取
	ObjectListing result = obsClient.listObjects("bucketname");
	如指定前缀获取
	ListObjectsRequest request = new ListObjectsRequest("bucketname");
	// 设置列举带有prefix前缀的100个对象
	request.setMaxKeys(100);
	request.setPrefix("prefix");
	ObjectListing result = obsClient.listObjects(request);
	for(ObsObject obsObject : result.getObjects()){
		System.out.println("\t" + obsObject.getObjectKey());
		System.out.println("\t" + obsObject.getOwner());
	}
4.删除对象
	单个删除
	obsClient.deleteObject("bucketname", "objectname");
	批量删除
	通过ObsClient.deleteObjects批量删除对象。
5.判断对象是否存在
	obsClient.doesObjectExist("bucketname", "objectname")

你可能感兴趣的:(华为云)