如何解决AWS S3 对象访问和编辑
假设我想将一个哈希集对象存储到 AWS S3 上的存储桶中。我可以轻松地频繁更新该对象(向哈希集添加新字符串),还是必须在更改之前将哈希集从存储桶中取出?
解决方法
S3 是一个键 ->(对象+元数据)存储。近期(2020 年 12 月),S3 在更新、删除、列表和获取方面获得了强一致性。只有桶有最终的一致性约束。这意味着您应该能够轻松地在 S3 上存储序列化对象,并使用基本的 CRUD 操作来读取、更新、删除和列出存储的对象。
所以,是的,理论上您将能够在 S3 上存储哈希集。您可以将集合的各个值散列映射到 s3 键后缀并直接将值存储在 S3 中。您不必将整个哈希集加载到内存中,因为您可以将大部分操作直接映射到 S3。
- HashSet::Put -> S3::PutObject。 O(1)
- HashSet::isPresent -> S3::GetObjectMetaData。 O(1)
- HashSet::Remove -> S3::DeleteObject。 O(1)
- HashSet::ListAllObjects -> S3::ListObjects。 O(n)
您也可以实现并集、交集操作。不过,我不确定与通常的实现相比它的效率有多高。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。