基于文件语义实现S3接口语义的注意事项
本文标题中提到的文件语义,指的是POSIX规范。
S3指的是AWS提供的对象存储服务以及相关接口。为方便描述,下文中以对象语义替代S3接口语义。
文件语义和对象语义存在比较多的差异。
对象语义不支持文件语义的部分特性,比如:
- 目录的操作,创建、删除、修改名称。
- 文件的部分操作,追加写、随机写、修改名称等。
- 文件的元数据,比如:
- 时间字段,即crtime/ctime/mtime/atime。
- 用户和组,即uid/gid。
- 权限,即UGO和ACL。
- 文件的扩展属性。
- 硬链接。
- 软链接。
- 锁。
文件语义不支持对象语义的部分特性,比如:
- Etag,文件语义中没有定义相关信息。
- 生命周期管理。
- 桶策略。
- 多版本。
- 对象的元数据,即:
- 系统元数据,即标准HTTP头部。
- 用户自定义元数据,即命名为
x-amz-meta-*的HTTP头部。 - 对象tagging,即命名为
x-amz-tagging的HTTP头部。
部分存在差异的语义,比如:
- WORM,文件语义和对象语义的实现,由于前述差异,具体实现和保护范围可能存在一定的差异。
- 文件的创建。依据对象语义,保存对象的操作是一个原子行为,包含数据、元数据一并写入,要么成功、要么失败,只要上传对象的接口返回了成功,即表示对象创建成功。而依据文件语义,保存文件的操作,涉及打开、写入数据、写入元数据、关闭文件等操作,并不是原子行为,写入数据的过程中可能会被中断,但由于文件打开成功,因此会出现数据不一致的现象。
- 目录,对象语义对目录的支持非常有限,而文件语义则提供了丰富的API。
对象语义中,使用对象来表示客户的数据,在存储和管理对象时,放弃了目录的概念,所有的对象均以展平的形式存储,在使用文件语义实现对象语义时,需要对目录做特殊的处理。
在文件语义中,/有特殊含义,表示目录的分隔符,因此一般不允许在目录名或者文件名中使用。
而AWS S3定义的规范中,/是普通字符,允许在对象名中使用。
做个实验,登录Linux环境的控制台,执行如下命令,输出如下:
$ ll a.py
-rw-r--r-- 1 jackie docker 138 3月 29 21:47 a.py
$ mkdir a.py
mkdir: cannot create directory ‘a.py’: File exists
$ mkdir a.py/
mkdir: cannot create directory ‘a.py/’: File exists
依据对象语义,a.py和a.py/是不同的对象,但在文件语义下,a.py存在,则阻塞目录a.py的创建操作。
依据文件语义,删除目录即类似rm -rf /path/to/delete时,目录和目录下的所有的文件、目录均会被删除。
考虑到本操作并不是一个原子操作,因此使用文件语义实现对象语义的删除操作时,会有比较多的注意事项。
思考点
- 删除目录时,目录下的对象,需要一并删除。假如对象数量比较多时,则删除操作将比较耗时。
- 目录下假如存在未合并的多段对象,是否一并删除。
- 目录下假如仅有一个对象,使用对象语义的删除接口,将该对象删除时,目录是否需要被删除。
- 先上传目录,上传一个对象至该目录下,使用对象语义的删除接口,将该对象删除时,目录是否需要被删除。
- 手工上传的目录,在列举对象时,是否作为一个对象在列举结果中出现。
- 如前所述,文件主义并不支持对象主义的Etag,因此在实现上传对象的操作时,需要计算并保留Etag值。
- 保存对象的数据的操作,计算MD5值的操作,二者需要保持进度一致,避免MD5值计算结果不正确,或者耗时过久,影响上传操作的性能。
- Etag保存的位置。
- 对象元数据的保存位置,依据语义,需要和数据一起保存。
- 元数据保存的位置。
- 操作的原子性。
- 对象语义写入对象时,文件的元数据,应当如何填值。如前述,不支持的元数据,如下:
- 时间字段,即crtime/ctime/mtime/atime。
- 用户和组,即uid/gid。
- 权限,即UGO和ACL。
基于文件语义实现S3接口语义的注意事项的更多相关文章
- 基于MIndSpore框架的道路场景语义分割方法研究
基于MIndSpore框架的道路场景语义分割方法研究 概述 本文以华为最新国产深度学习框架Mindspore为基础,将城市道路下的实况图片解析作为任务背景,以复杂城市道路进行高精度的语义分割为任务目标 ...
- 使用COSBench工具对ceph s3接口进行压力测试
一.COSBench安装 COSBench是Intel团队基于java开发,对云存储的测试工具,全称是Cloud object Storage Bench 吐槽下,貌似这套工具是intel上海团队开发 ...
- JMeter基于http请求的web接口性能测试总结
[本文出自天外归云的博客园] 基于http请求的web接口性能测试总结 压测的目的:对于Web接口压测的目的最终是要在对数据库造成压力的情况下观察压测服务器的cpu是否达到预警值.memory是否发生 ...
- 实现基于文件存储的Session类
自主实现Session功能的类,基于文件方式存储Session数据,测试基本通过,还比较好玩,实际应用没有意义,只不过是学习Session是如何实现的. 一般基于文件存储Session数据效率不是很高 ...
- 【科研论文】基于文件解析的飞行器模拟系统软件设计(应用W5300)
摘要: 飞行器模拟系统是复杂飞行器研制和使用过程中的重要设备,它可以用来模拟真实飞行器的输入输出接口,产生与真实系统一致的模拟数据,从而有效避免因使用真实飞行器带来的高风险,极大提高地面测发控系统的研 ...
- Hadoop基于文件的数据结构及实例
基于文件的数据结构 两种文件格式: 1.SequenceFile 2.MapFile SequenceFile 1.SequenceFile文件是Hadoop用来存储二进制形式的<key,val ...
- 【ALB学习笔记】基于事件触发方式的串行通信接口数据接收案例
基于事件触发方式的串行通信接口数据接收案例 广东职业技术学院 欧浩源 一.案例背景 之前写过一篇<基于多线程方式的串行通信接口数据接收案例>的博文,讨论了采用轮询方式接收串口数据的情况. ...
- 【安富莱专题教程第1期】基于STM32的硬件RGB888接口实现emWin的快速刷新方案,32位色或24
说明:1. 首先感谢ST终于推出了ARGB格式的emWin库,可谓千呼万唤始出来,使用STM32的硬件RGB888接口刷新图片慢的问题终于得到解决.2. 这个问题由来已久,是之前为我们的STM32-V ...
- Asp.Net Core基于JWT认证的数据接口网关Demo
近日,应一位朋友的邀请写了个Asp.Net Core基于JWT认证的数据接口网关Demo.朋友自己开了个公司,接到的一个升级项目,客户要求用Aps.Net Core做数据网关服务且基于JWT认证实现对 ...
- ceph储存的S3接口实现(支持断点续传)
最近公司准备接ceph储存,研究了一番,准备用亚马逊的s3接口实现,实现类如下: /** * Title: S3Manager * Description: Ceph储存的s3接口实现,参考文档: * ...
随机推荐
- 问题:django中对datetime类型数据在pycharm中sqlite3进行修改时,修改后datetime日期数据变成了时间戳类型
这是正在修改的 提交完之后 问题原因 问题原因是sqlite数据库对日期类型不敏感,Pycharm直接插入会变成图中这样的时间戳,用POST请求添加数据或Django自带的后台管理插入不会有这样的问题 ...
- 【LeetCode链表#6】移除链表元素
移除链表元素 题目 力扣题目链接(opens new window) 题意:删除链表中等于给定值 val 的所有节点. 示例 1: 输入:head = [1,2,6,3,4,5,6], val = 6 ...
- 名校AI课推荐 | MIT6.S191《深度学习导论》
"连续开设5年,对新手友好.易于上手,参加课程的多数学生来自非计算机科学领域--" 推荐一门AI课程--MIT官方深度学习入门课程6.S191<深度学习导论(2022)> ...
- FROM_UNIXTIME函数格式化时间戳日期类型
select FROM_UNIXTIME(bce.daysec_time/1000,'%Y-%m-%d %h:%i:%s') ,bce.* from biz_cvent bce where bce.d ...
- 21 Educational Codeforces Round 136 (Rated for Div. 2)Knowledge Cards(树状数组、set、+思维、数字华容道)
最开始猜了个结论错了,猜的是必须要有\(m+n-1\)个方格空着,这样才能保证任意一张牌能从起点到终点. 其实并不是,参考数字华容道,实际上是只要除了终点和起点,以及自身这个方格.我们只需要留出一个空 ...
- 探究WPF中文字模糊的问题:TextOptions的用法
有网友问WPF中一些文字模糊是什么问题.之前我也没有认真思考过这个问题,只是大概知道和WPF的像素对齐(pixel snapping).抗锯齿(anti-aliasing)有关,通过设置附加属性Tex ...
- 使用 PMML 实现模型融合及优化技巧
在机器学习的生产环境中,我们经常需要将多个模型的预测结果进行融合,以便提高预测的准确性.这个过程通常涉及到多个模型子分的简单逻辑回归融合.虽然离线训练时我们可以直接使用sklearn的逻辑回归进行训练 ...
- git reset --soft HEAD^^ 项目提交代码冲突 提交当前merge后,别提交远程,用命令回滚2次,到未提交的版本,再拉取同事代码,冲突解决
git reset --soft HEAD^^ 项目提交代码冲突 提交当前merge后,别提交远程,用命令回滚2次,到未提交的版本,再拉取同事代码,冲突解决 当多人写一个项目,最好还是关掉vscode ...
- Codeforces Round 858:B. Mex Master
一.来源:Problem - B - Codeforces 二.题面 三.思路 题面:n个非负正数,随机排列并由相邻两个数相加构成n-1个数并进行升序排列,求从0开始的第一个MEX(Minimum E ...
- java生产者消费者模式代码示例
package test; import java.util.LinkedList; public class Test { public static void main(String[] args ...