分层命名空间 HNS(Hierarchical NameSpace,简称分层桶)是对象存储 TOS 推出的一个全新的基于分层元数据管理的桶类型。在提供分层命名空间能力的同时兼顾了对象扁平化扩展性,提供对象语义与文件语义透明互通的能力,实现真正的一份数据多种访问协议,提升数据使用效率。
相比原来扁平命名空间 FNS(Flat NameSpace,简称扁平桶)可以很好的支持目录级别的 mv 与 rename 操作,同时优化常见读操作 List 与目录 Head,提升数据处理效率与性能,能很好的满足大数据、数据湖和 AI 领域的使用场景。
本文介绍如何通过 TOS Java SDK 的 listBuckets
接口列举您账号下所有地域的分层命名空间列表。
tos:ListBuckets
权限。具体操作,请参见 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.model.bucket.ListBucketsV2Input; import com.volcengine.tos.model.bucket.ListBucketsV2Output; import com.volcengine.tos.model.bucket.ListedBucket; public class ListBucketExample { 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"); TOSV2 tos = new TOSV2ClientBuilder().build(region, endpoint, accessKey, secretKey); try{ ListBucketsV2Input input = new ListBucketsV2Input(); input.setBucketType(BucketType.BUCKET_TYPE_HNS); ListBucketsV2Output output = tos.listBuckets(input); System.out.println("bucket owner is " + output.getOwner()); if (output.getBuckets() != null) { System.out.println("you have listed " + output.getBuckets().size() + " buckets"); for (int i = 0; i < output.getBuckets().size(); i++){ ListedBucket bucket = output.getBuckets().get(i); System.out.printf("Listed bucket, name is %s, location is %s, extranetEndpoint is %s, " + "intranetEndpoint is %s, creationDate is %s.\n", bucket.getName(), bucket.getLocation(), bucket.getExtranetEndpoint(), bucket.getIntranetEndpoint(), bucket.getCreationDate()); } } else { System.out.println("there are no buckets in your account."); } } catch (TosClientException e) { // 操作失败,捕获客户端异常,一般情况是请求参数错误,此时请求并未发送 System.out.println("listBuckets failed"); System.out.println("Message: " + e.getMessage()); if (e.getCause() != null) { e.getCause().printStackTrace(); } } catch (TosServerException e) { // 操作失败,捕获服务端异常,可以获取到从服务端返回的详细错误信息 System.out.println("listBuckets 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("listBuckets failed"); System.out.println("unexpected exception, message: " + t.getMessage()); } } }
关于列举桶的 API 文档,请参见 ListBuckets。