对象储存服务obs优劣以及实践储服务

背景介绍:什么是obs呢?

现在越来越多的行业使用OBS存储图片、视频、软件包等静态资源文件,并将OBS作为网站、论坛、APP、游戏等业务的存储源。在需要获取这些静态资源时,用户通过URL直接从OBS请求数据,数据请求过程如[图1所示。OBS能够很好的解决本地存储不够用的难题,但一般情况下文件只存储在一个区域,不同区域的用户访问OBS的响应速度存在差异。在需要频繁访问的场景下,直接访问OBS来获取相应文件,还会消耗大量的流量费用。

图1 从OBS获取数据过程 file

知道了obs的作用,那么我们接下来看看华为云对象储存服务obs是怎么工作的。储服

方案说明

OBS提供低成本的存储,华为云CDN可以提供网站加速、文件下载加速和点播加速。将数据存放在OBS中然后通过配置CDN加速,这样构造的业务系统可以在降低成本的同时,提高终端用户使用感受。当终端用户发起访问请求时,会首先通过CDN查找对此域名响应速度最快的CDN节点,并查询此节点是否有缓存终端用户请求的内容。

在CDN节点没有缓存用户请求的数据或缓存到期的情况下,CDN加速访问OBS的示意图如下图所示。

CDN加速访问OBS示意图(CDN无缓存) file

当其他终端用户再次访问相同的数据时,CDN将直接返回缓存的数据给终端用户,而无需再向OBS发起访问请求。在CDN有缓存的情况下,CDN加速访问OBS的示意图如图所示

加速访问OBS示意图(CDN有缓存)

### 华为云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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值