分层命名空间 HNS(Hierarchical NameSpace,简称分层桶)是对象存储 TOS 推出的一个全新的基于分层元数据管理的桶类型。在提供分层命名空间能力的同时兼顾了对象扁平化扩展性,提供对象语义与文件语义透明互通的能力,实现真正的一份数据多种访问协议,提升数据使用效率。
相比原来扁平命名空间 FNS(Flat NameSpace,简称扁平桶)可以很好的支持目录级别的 mv 与 rename 操作,同时优化常见读操作 List 与目录 Head,提升数据处理效率与性能,能很好的满足大数据、数据湖和 AI 领域的使用场景。
本文介绍如何通过 TOS Java SDK 的 createBucket
接口创建分层命名空间。
tos:CreateBucket
权限。您可以通过 IAM 策略授予相应权限,具体步骤,请参见 IAM 策略。示例代码
import com.volcengine.tos.TOSV2; import com.volcengine.tos.TOSV2ClientBuilder; import com.volcengine.tos.TosClientException; import com.volcengine.tos.TosServerException; import com.volcengine.tos.comm.common.ACLType; import com.volcengine.tos.comm.common.StorageClassType; import com.volcengine.tos.model.bucket.CreateBucketV2Input; import com.volcengine.tos.model.bucket.CreateBucketV2Output; public class CreateDirectoryBucketExample { public static void main(String[] args) { String endpoint = "your endpoint"; String region = "your region"; String accessKey = System.getenv("TOS_ACCESS_KEY"); String secretKey = System.getenv("TOS_SECRET_KEY"); // 设置桶名,请保证桶名的唯一性 String bucketName = "your bucket name"; // 创建桶是可以设置桶的访问权限和存储类型等 // 注意以下代码仅为示例,不是必选参数 // 设置桶的访问权限 ACLType aclType = ACLType.ACL_PRIVATE; // 设置桶的存储类型 StorageClassType storageClassType = StorageClassType.STORAGE_CLASS_STANDARD; TOSV2 tos = new TOSV2ClientBuilder().build(region, endpoint, accessKey, secretKey); try{ CreateBucketV2Input input = new CreateBucketV2Input().setBucket(bucketName) .setAcl(aclType).setStorageClass(storageClassType); CreateBucketV2Output output = tos.createBucket(input); System.out.println("bucket created: " + output.getLocation()); } catch (TosClientException e) { // 操作失败,捕获客户端异常,一般情况是请求参数错误,此时请求并未发送 System.out.println("createBucket failed"); System.out.println("Message: " + e.getMessage()); if (e.getCause() != null) { e.getCause().printStackTrace(); } } catch (TosServerException e) { // 操作失败,捕获服务端异常,可以获取到从服务端返回的详细错误信息 System.out.println("createBucket failed"); System.out.println("StatusCode: " + e.getStatusCode()); System.out.println("Code: " + e.getCode()); System.out.println("Message: " + e.getMessage()); System.out.println("RequestID: " + e.getRequestID()); } catch (Throwable t) { // 作为兜底捕获其他异常,一般不会执行到这里 System.out.println("createBucket failed"); System.out.println("unexpected exception, message: " + t.getMessage()); } } }
关于创建桶的 API 文档,请参见 CreateBucket。