博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
对象存储、块存储、文件系统存储概念与区别
阅读量:6214 次
发布时间:2019-06-21

本文共 1230 字,大约阅读时间需要 4 分钟。

 

一、概念及区别

针对不同的应用场景,选择的分布式存储方案也会不同,因此有了对象存储、块存储、文件系统存储。这三者的主要区别在于它们的存储接口:

1.  对象存储:

  也就是通常意义的键值存储,其接口就是简单的GET,PUT,DEL和其他扩展,如七牛、又拍,Swift,S3

2. 块存储:

  这种接口通常以QEMU Driver或者Kernel Module的方式存在,这种接口需要实现Linux的Block Device的接口或者QEMU提供的Block Driver接口,如Sheepdog,AWS的EBS,青云的云硬盘和阿里云的盘古系统,还有Ceph的RBD(RBD是Ceph面向块存储的接口)

3. 文件存储:

  通常意义是支持POSIX接口,它跟传统的文件系统如Ext4是一个类型的,但区别在于分布式存储提供了并行化的能力,如Ceph的CephFS(CephFS是Ceph面向文件存储的接口),但是有时候又会把GFS,HDFS这种非POSIX接口的类文件存储接口归入此类。

 

二、IO特点

按照这三种接口和其应用场景,很容易了解这三种类型的IO特点,括号里代表了它在非分布式情况下的对应:

1. 对象存储(键值数据库):

  接口简单,一个对象我们可以看成一个文件,只能全写全读,通常以大文件为主,要求足够的IO带宽。

2. 块存储(硬盘):

  它的IO特点与传统的硬盘是一致的,一个硬盘应该是能面向通用需求的,即能应付大文件读写,也能处理好小文件读写。但是硬盘的特点是容量大,热点明显。因此块存储主要可以应付热点问题。另外,块存储要求的延迟是最低的。

3. 文件存储(文件系统):

  支持文件存储的接口的系统设计跟传统本地文件系统如Ext4这种的特点和难点是一致的,它比块存储具有更丰富的接口,需要考虑目录、文件属性等支持,实现一个支持并行化的文件存储应该是最困难的。但像HDFS、GFS这种自己定义标准的系统,可以通过根据实现来定义接口,会容易一点。

 

  因此,这三种接口分别以非分布式情况下的键值数据库、硬盘和文件系统的IO特点来对应即可。至于冷热、快慢、大小文件而言更接近于业务。但是因为存储系统是通用化实现,通常来说,需要尽量满足各种需求,而接口定义已经一定意义上就砍去了一些需求,如对象存储会以冷存储更多,大文件为主。

 

 三、Ceph的对象存储、块存储、文件系统存储

  Ceph同时支持这三种存储,方法就是通过支持不同的接口来支持不同的存储。下面是Ceph的基本架构图,可以看到通过兼容AWS的S3和OpenStack的Swift接口来支持对象存储,通过librbd库提供块存储的接口,通过libcephfs库的文件系统接口或标准posix接口来支持文件系统存储。

 

(全文完)

参考:

1. 王豪迈的回答:

2.《Ceph源码分析》

 

转载于:https://www.cnblogs.com/zxiner/p/7141861.html

你可能感兴趣的文章
正向代理与反向代理
查看>>
SSM框架——实现分页和搜索分页
查看>>
以太坊客户端Geth命令用法-参数详解
查看>>
BBSSDK插件技术方案
查看>>
威胁网络安全的因素有哪些
查看>>
智能合约游戏之殇——类 Fomo3D 攻击分析
查看>>
4_上拉加载下拉刷新
查看>>
六周第一次课(4月25日)正则介绍_grep上、grep中、grep下
查看>>
SQL数据库常见问题解答及万能密码注入原理讲解[图]
查看>>
Python爬虫初接触,学会爬虫不抓美女图片干啥!
查看>>
学习网站
查看>>
深度解析双十一背后的阿里云 Redis 服务
查看>>
PHP扩展模块安装
查看>>
Win下Jenkins-2.138源码编译及填坑笔记
查看>>
三千预算进卡吧的顺口溜是啥
查看>>
递归算法的时间复杂度
查看>>
BCGControlBar教程:将MFC控件的BCGControlBar / BCGSuite添加到对话框中
查看>>
PyCharm入门教程——在编辑器中打开和重新打开文件
查看>>
分布式系统理论概述
查看>>
传统IDC部署网站(六)
查看>>