对象存储调研四华为云OBS

华为云OBS是一种基于对象的海量存储服务,提供标准、低频访问、归档和深度归档四种存储类别,适用于大数据分析、备份归档等场景。OBS与自建服务器相比具有数据稳定、安全、高并发和低成本优势,并能与Hadoop等大数据服务对接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

华为云对象存储OBS架构

华为云对象存储服务(Object Storage Service ,OBS)是一个基于对象的海量存储服务,为客户提供海量、安全、高可靠、低成本的数据存储能力。
OBS的基本组成是桶和对象,其中对象是OBS中数据存储的基本单位,一个对象实际是一个文件的数据与其相关属性信 息的集合体,包括Key 、 Metadata 、Data三部分。
华为云针对OBS提供的REST API进行了二次开发,为您提供了控制台、SDK和各类工 具,方便在不同的场景下轻松访问OBS桶以及桶中的对象。当然您也可以利用OBS 提供的SDK和OBS API,根据您业务的实际情况自行开发,以满足不同场景的海量数据存储诉求。
在这里插入图片描述
在这里插入图片描述
● Key:键值,即对象的名称,为经过UTF-8编码的长度大于0且不超过1024的字符 序列。一个桶里的每个对象必须拥有唯一的对象键值。
● Metadata:元数据,即对象的描述信息,包括系统元数据和用户元数据,这些元 数据以键值对(Key-Value)的形式被上传到OBS中。
– 系统元数据由OBS自动产生,在处理对象数据时使用,包括Date ,Content- length , Last-modify,Content-MD5等。

### 华为云OBS对象存储Java SDK使用指南 #### 依赖引入 为了能够在项目中集成并使用华为云OBS对象存储服务,需先在项目的`pom.xml`文件里加入如下Maven依赖: ```xml <dependency> <groupId>com.huaweicloud</groupId> <artifactId>esdk-obs-java</artifactId> <version>3.21.12</version> </dependency> ``` 此版本号可能随时间更新而变化,请查阅官方文档获取最新版次[^1]。 #### 初始化客户端 创建ObsClient实例用于后续操作前,应确保已设置好环境变量或配置文件中的认证信息(Access Key ID 和 Secret Access Key),以便成功连接至华为云账户下的资源。以下是初始化代码片段: ```java import com.obs.services.ObsClient; // ... String ak = "your-access-key-id"; String sk = "your-secret-access-key"; String endpoint = "https://your-endpoint"; ObsClient obsClient = new ObsClient(ak, sk, endpoint); ``` 此处endpoint参数取决于所选区域的服务地址,具体可参见官方文档说明。 #### 文件上传功能实现 利用上述构建好的ObsClient对象执行PUT请求完成文件上传动作,下面是一段简单的例子展示如何将本地路径指定的一个文件上传到特定桶内: ```java import java.io.File; public void uploadFile(String bucketName, String objectKey, File file){ try { PutObjectResult putObjectResult = obsClient.putObject(bucketName, objectKey, file); System.out.println("Etag:" + putObjectResult.getETag()); System.out.println("VersionId:" + putObjectResult.getVersionId()); } catch (Exception e) { e.printStackTrace(); } } ``` 这段程序会打印出返回的etag以及版本ID作为确认标志。 #### 文件下载逻辑编写 对于从OBS拉取数据而言,则可通过调用get方法来达成目的;这里提供了一个基础示例用来读取远端对象的内容流,并将其保存成新的本地文件形式: ```java import java.nio.file.Files; import java.nio.file.Paths; public void downloadFile(String bucketName, String objectKey, String localFilePath){ try{ ObjectMetadata metadata = obsClient.getObject(new GetObjectRequest(bucketName, objectKey), Paths.get(localFilePath)); System.out.println("Content-Type: " + metadata.getContentType()); }catch(Exception ex){ ex.printStackTrace(); } } ``` 该函数接收三个字符串类型的参数分别代表目标容器名称、待检索键名及期望存放位置,最终输出的是HTTP响应头里的content-type字段值。 #### 资源管理与清理工作 当不再需要某个已经存在的bucket或者想要移除其中部分object时,可以借助deleteBucket/deleteObjects API接口来进行相应处理。需要注意的是,在实际应用环境中应当谨慎对待这些命令以免误删重要资料。 ```java // 删除单个对象 DeleteObjectResult deleteObjectResult = obsClient.deleteObject(bucketName, objectKey); // 批量删除多个对象 List<String> keysToDelete = Arrays.asList("key1", "key2"); DeleteObjectsResponse response = obsClient.deleteObjects( DeleteObjectsRequest.builder() .withQuiet(false) .addKeys(keysToDelete.toArray(new String[0])) .build(), bucketName); ``` 以上即是对华为云OBS对象存储服务基本使用的介绍,涵盖了SDK接入准备阶段直至常见CRUD操作的具体实践过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangvalue

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值