当前位置:

分布式存储

块存储、文件存储、对象存储这三者的本质差别是什么?

1.块存储

块存储一般体现形式是卷或者硬盘(比如windows里面看到的c盘),数据是按字节来访问的,对于块存储而言,对里面存的数据内容和格式是完全一无所知的。

好比下图中,数据就像玉米粒一样堆放在块存储里,块存储只关心玉米粒进来和出去,不关心玉米粒之间的关系和用途。

e9caa2a166774e7fa8a3bb047d98b60e.png

块存储只负责数据读取和写入,因此性能很高,适用于对响应时间要求高的系统。比如数据库等。

2.文件存储

文件存储一般体现形式是目录和文件(比如C:UsersDownloads ext.doc),数据以文件的方式存储和访问,按照目录结构进行组织。

文件存储可以对数据进行一定的高级管理,比如在文件层面进行访问权限控制等。

54201c1295d84393bd602c7a080ecac3.png

数据像玉米粒一样组成玉米棒子,再对应到不同的玉米杆上,要找到某个玉米粒,先找到玉米杆,再找到玉米棒子,然后根据玉米粒在玉米棒子上的位置找到它。

文件存储可以很方便的共享,因此用途非常广泛。

比如常用的NFS、CIFS、ftp等都是基于文件存储的。

3.对象存储

对象存储一般体现形式是一个UUID(比如https://www.youtube.com/watch?v=nAKxJbcec8U),数据和元数据打包在一起作为一个整体对象存在一个超大池子里。

对于对象访问,只需要报出它的UUID,就能立即找到它,但访问的时候对象是作为一个整体访问的。

好比下图中,数据的玉米粒被做成了玉米罐头,每个玉米罐头都有一个唯一出厂号,但是买卖罐头,都一次是一盒为单位。

3c9424c21b0e4a309cf80f10c91589f8.png

从设计之初衷(一般的对象存储都是基于哈希环之类的技术来实现),对象存储就可以非常简单的扩展到超大规模,因此非常适合数据量大、增速又很快的视频、图像等。

参考:https://www.zhihu.com/question/21536660