阿里云oss 对象存储服务是什么?

2023-07-0212:01:46网站管理维护Comments1,917 views字数 2406阅读模式

oss 是什么?

OSS是阿里云对象存储服务(Object Storage Service)的一个简称,它是阿里云提供的海量、安全、低成本、高可靠的云存储服务。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

即开即用、无限大空间的存储集群。相较传统建服务器存储而言,OSS在可靠性、安全性、成本和数据处理能力方面都有着突出的优势。使用OSS,您可以通过网络随时存储和调用包括文本、图片和视频等在内的各种非结构化数据文件。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

阿里云oss 对象存储服务是什么?
OSS将数据文件以对象/文件(Object)的形式上传到存储空间(Bucket)中。OSS提供的是一个Key-Value键值对形式的对象存储服务。用户可以根据Object的名称(Key)唯一地址获取该Object的内容。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

OSS产品架构图

阿里云oss 对象存储服务是什么?
WS&PM(协议接入层):负责接收用户使用RESTful协议发来的请求,进行安全认证。如果认证通过,用户的请求将被转发到Key-Value引擎继续处理。如果认证失败,直接返回错误信息给用户。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

KV集群:负责数据结构化处理,即按照Key(对象名称)来查找或存储数据,并支持大规模并发的请求。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

当协调服务集群变更导致服务被迫改变运行物理位置时,可以快速协调找到接入点。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

存储集群:元数据存储在Master上,Master之间采用**分布式消息一致性协议(Paxos)**保证元数据的一致性,从而实现高效的文件分布式存储和访问。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

OSS基本概念

对象/文件(Object)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

对象是OSS存储数据的基本单元,也被称为OSS的文件。对象由元信息(Object Meta)、用户数据(Data)和文件名(Key)组成。对象由存储空间内部唯一的Key来标识。对象元信息是一个键值对,表示了对象的一些属性,比如最后修改时间、大小等信息,同时用户也可以在元信息中存储一些自定义的信息。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

对象的生命周期是从上传成功到被删除为止。在整个生命周期内,对象信息不可变更,重复上传同名的对象会覆盖之前的对象。因此,OSS不支持修改文件的部分内容等操作。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

存储空间(Bucket)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

存储空间是您用于存储对象(Object)的容器,所有的对象都必须隶属于某个存储空间。您可以设置和修改存储空间属性用来控制访问权限、生命周期等,这些属性设置直接作用于该存储空间内所有对象,因此您可以通过灵活创建不同的存储空间来完成不同的管理功能。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

同一个存储空间的内部是扁平的,没有文件系统的目录等概念,所有对象都直接隶属于其对应的存储空间。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

每个用户可以拥有多个存储空间。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

存储空间的名称在OSS范围内必须是全局唯一的,一旦创建之后无法修改名称。
存储空间内部的对象数目没有限制。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

强一致性
Object操作在OSS上具有原子性,操作要么成功要么失败,不会存在有中间状态的Object。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

OSS保证用户一旦上传完成之后读到的Object是完整的,OSS不会返回给用户一个部分上传成功的Object。Object操作在OSS上同样具有强一致性,用户一旦收到了一个上传(PUT)成功的响应,该上传的Object就已经立即可读,并且数据的三份副本已经写成功。不存在一种上传的中间状态,即read-after-write却无法读取到数据。对于删除操作也是一样的,用户删除指定的Object成功之后,该Object立即变为不存在。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

强一致性方便了用户架构设计,可以使用跟传统存储设备同样的逻辑来使用OSS,修改立即可见,无需考虑最终一致性带来的各种问题。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

OSS与文件系统的对比文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

OSS是一个分布式的对象存储服务,提供的是一个Key-Value对形式的对象存储服务。用户可以根据Object的名称(Key)唯一地获取该Object的内容。虽然用户可以使用类似test1/test.jpg的名字,但是这并不表示用户的Object是保存在test1目录下面的。对于OSS来说,test1/test.jpg仅仅只是一个字符串,和a.jpg这种并没有本质的区别。因此不同名称的Object之间的访问消耗的资源是类似的。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

文件系统是一种典型的树状索引结构,一个名为test1/test.jpg的文件,访问过程需要先访问到test1这个目录,然后再在该目录下查找名为test.jpg的文件。因此文件系统可以很轻易地支持文件夹的操作,比如重命名目录、删除目录、移动目录等,因为这些操作仅仅只是针对目录节点的操作。这种组织结构也决定了文件系统访问越深的目录消耗的资源也越大,操作拥有很多文件的目录也会非常慢。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

对于OSS来说,可以通过一些操作来模拟类似的功能,但是代价非常昂贵。比如重命名目录,希望将test1目录重命名成test2,那么OSS的实际操作是将所有以test1/开头的Object都重新复制成以test2/开头的Object,这是一个非常消耗资源的操作。因此在使用OSS的时候要尽量避免类似的操作。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

OSS保存的Object不支持修改(追加写Object需要调用特定的接口,生成的Object也和正常上传的Object类型上有差别)。用户哪怕是仅仅需要修改一个字节也需要重新上传整个Object。而文件系统的文件支持修改,比如修改指定偏移位置的内容、截断文件尾部等,这些特点也使得文件系统拥有广泛的适用性。但另外一方面,OSS能支持海量的用户并发访问,而文件系统会受限于单个设备的性能。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

因此,将OSS映射为文件系统是非常低效的,也是不建议的做法。如果一定要挂载成文件系统的话,建议尽量只做新建文件、删除文件、读取文件这几种操作。使用OSS应该充分发挥其优点,即海量数据处理能力,优先用来存储海量的非结构化数据,比如图片、视频、文档等。
————————————————
版权声明:本文为CSDN博主「Antoni_cy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Antoni_cy/article/details/117807845文章源自菜鸟学院-https://www.cainiaoxueyuan.com/wg/49237.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/wg/49237.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定