1. 块存储

典型设备: 磁盘阵列,硬盘

​ 块存储主要是将裸磁盘空间整个映射给主机使用的,就是说例如磁盘阵列里面有5块硬盘(为方便说明,假设每个硬盘1G),然后可以通过划逻辑盘、做Raid、或者LVM(逻辑卷)等种种方式逻辑划分出N个逻辑的硬盘。

​ 接着块存储会采用映射的方式将这几个逻辑盘映射给主机,主机上面的操作系统会识别到有5块硬盘,但是操作系统是区分不出到底是逻辑还是物理的,它一概就认为只是5块裸的物理硬盘而已,跟直接拿一块物理硬盘挂载到操作系统没有区别的,至少操作系统感知上没有区别。

​ 此种方式下,操作系统还需要对挂载的裸硬盘进行分区、格式化后,才能使用,与平常主机内置硬盘的方式完全无异。

1.1 优点

1、 这种方式的好处当然是因为通过了Raid与LVM等手段,对数据提供了保护。

2、 另外也可以将多块廉价的硬盘组合起来,成为一个大容量的逻辑盘对外提供服务,提高了容量。

3、 写入数据的时候,由于是多块磁盘组合出来的逻辑盘,所以几块磁盘可以并行写入的,提升了读写效率。

4、 很多时候块存储采用SAN架构组网,传输速率以及封装协议的原因,使得传输速度与读写速率得到提升。

1.2 缺点

1、采用SAN架构组网时,需要额外为主机购买光纤通道卡,还要买光纤交换机,造价成本高。

2、主机之间的数据无法共享,在服务器不做集群的情况下,块存储裸盘映射给主机,再格式化使用后,对于主机来说相当于本地盘,那么主机A的本地盘根本不能给主机B去使用,无法共享数据。

3、不利于不同操作系统主机间的数据共享:另外一个原因是因为操作系统使用不同的文件系统,格式化完之后,不同文件系统间的数据是共享不了的。例如一台装了WIN7/XP,文件系统是FAT32/NTFS,而Linux是EXT4,EXT4是无法识别NTFS的文件系统的。就像一只NTFS格式的U盘,插进Linux的笔记本,根本无法识别出来。所以不利于文件共享。

2. 文件存储

典型设备:FTP、NFS服务器

​ 为了克服块存储中文件服务共享的问题,所以有了文件存储。

​ 文件存储也有软硬一体化的设备,但是其实普通拿一台服务器/笔记本,只要装上合适的操作系统与软件,就可以架设FTP与NFS服务了,架上该类服务之后的服务器,就是文件存储的一种了。

​ 主机A可以直接对文件存储进行文件的上传下载,与块存储不同,主机A是不需要再对文件存储进行格式化的,因为文件管理功能已经由文件存储自己搞定了。

2.1 优点

1、造价交低:随便一台机器就可以了,另外普通以太网就可以,根本不需要专用的SAN网络,所以造价低。

2、 方便文件共享:针对块存储中文件无法共享问题,使用文件存储,第三方进行中转。

2.2 缺点

​ 读写速率低,传输速率慢:以太网,上传下载速度较慢,另外所有读写都要1台服务器里面的硬盘来承担,相比起磁盘阵列动不动就几十上百块硬盘同时读写,速率慢了许多。

3. 对象存储

典型设备:内置大容量硬盘的分布式服务器

​ 对象存储最常用的方案,就是多台服务器内置大容量硬盘,再装上对象存储软件,然后搞几台服务器作为管理节点,安装上对象存储管理软件。管理节点可以管理其他服务器对外提供读写访问功能。

​ 之所以出现对象存储,是为了克服块存储与文件存储各自的缺点。简单来说块存储读写快,不利于共享,文件存储读写慢,利于共享。能否搞一个读写快,利于共享的出来呢?于是有了对象存储。

对象存储的原理

​ 首先,一个文件包含了属性(术语叫metadata,元数据,例如该文件的大小、修改时间、存储路径等)以及内容(以下简称数据)

​ 以往像FAT32这种文件系统,是直接将一份文件的数据与metadata一起存储的,存储过程先将文件按照文件系统的最小块大小来打散(如4M的文件,假设文件系统要求一个块4K,那么就将文件打散成1000个小块),再写进硬盘里面,过程中没有区分数据/metadata的。而每个块最后会告知你下一个要读取的块的地址,然后一直这样顺序地按图索骥,最后完成整份文件的所有块的读取。

​ 这种情况下读写速度很慢,因为就算你呦100个机械手臂在读写,但是由于你只有读取到第一块,才能知道下一个在哪里,其实相当于只能有一个机械手臂在实际工作。

对象存储将元数据独立出来,控制节点叫元数据服务器(服务器+对象存储管理软件),里面主要负责存储对象的属性(主要是对象的数据被打散存放到了那几台分布式服务器中的信息),而其他负责存储数据的分布式服务器叫做OSD,主要负责存储文件的数据部分。当用户访问对象,会先访问元数据服务器,元数据服务器只负责反馈对象存储在那些OSD,假设反馈文件A存储在B、C、D三台OSD,那么用户就会再次直接访问3台OSD服务器去读取数据。

​ 这时候由于是3台OSD同时对外传输数据,所以传输的速度就加快了。当OSD服务器数量越多,这种读写速度的提升就越大,通过这种方式,实现了读写快的目的。

​ 另一方面,对象存储软件是有专门的文件系统的,所以OSD对象又相当于文件服务器,那么就不存在文件共享方面的困难了,也就解决了文件共享方面的问题。

​ 所以对象存储的出现,很好地结合了块存储与文件存储的优点。

三种存储的对比

明辰智航云安网络与虚拟化性能管理系统

4 读写文件_块存储、文件存储、对象存储的区别相关推荐

  1. 阿里云文件存储NAS和对象存储OSS区别对比如何选择?

    阿里云对象存储OSS和文件存储NAS有什么区别?文件存储NAS和对象存储OSS如何选择?NAS是传统的NFS挂载共享文件夹,OSS可以使用RESTful API,阿里云百科从技术.使用方式.容量.存储 ...

  2. 分布式存储--理解分布式文件系统、分布式块存储、分布式对象存储、分布式数据库

    1. 单机文件系统 vs 分布式文件系统 传统单机文件系统是计算机中一个非常重要的组件,为存储设备提供一致的访问和管理方式.在不同的操作系统中,文件系统会有一些差别,但也有一些共性几十年都没怎么变化: ...

  3. 对象存储使用案例_连云数据都有“对象存储”了,你还是单身?

    没错,对象存储(OOS,Object-Oriented Storage)可不是一项"在你嫌男票/女票烦的时候暂时寄存的服务",而是中国电信为客户提供的一种海量.弹性.高可靠.高性价 ...

  4. linux中普通文件和块设备文件的区别

    1,概述 一直都搞不明白普通文件跟块文件的区别,总觉得一个普通的文件是存放在磁盘块上,那它既属于普通文件又属于块设备文件.刚好下午睡了一个大头觉,比较清醒,集中学习了下普通文件和块设备文件的区别和联系 ...

  5. 关于字符设备文件和块设备文件的区别

    本文转载自:http://www.cnblogs.com/qlee/archive/2011/07/27/2118406.html 近来想了解一下字符设备文件和块设备文件的区别,看到有篇文章写的很详细 ...

  6. 对象存储3:对象存储的原理、构造和详解

    前两篇介绍了对象存储的基础,包括存储类型,常用存储分类和分类方法. SCSI,TCP/IP,FC等存储介质以及DAS\NAS\SAN等存储网络,请参考:对象存储1:传统存储类型和分类. 文件存储,块存 ...

  7. java s3 与ceph的关系_Ceph存储与S3对象存储性能优化.pdf

    Ceph存储与S3对象存储性能优化.pdf Ceph on Storage appliance Case Study and Performance for AWS S3 based object s ...

  8. 文件上传到云服务器对象存储oos流程

    两种方式: 1.通过服务器直接上传云服务器 2.网页向服务器发送请求获取云服务器签名,后直接上传到云服务器(可以降低自身服务器访问压力) 流程: 1.注册云服务器对象存储.开启跨域访问和创建阿里云的子 ...

  9. 轻松实现微信小程序上传多文件/图片到腾讯云对象存储COS(免费额度)

    概述 对象存储(Cloud Object Storage,COS)是腾讯云提供的一种存储海量文件的分布式存储服务,用户可通过网络随时存储和查看数据. 个人账户首次开通COS可以免费领取50GB 标准存 ...

最新文章

  1. 伪元素first-letter
  2. 使用Gradle第一次构建Web应用
  3. 谁占用了我的Buffer Pool?
  4. Maven的单元测试没有执行的问题
  5. HDU 6113 度度熊的01世界【DFS/Flood Fill】
  6. [译]LightSwitch 如何实现:在查询中创建和使用全局值(Eric Erhardt)
  7. 设计素材画面太平淡?优秀案例网页教你如何用色彩丰富画
  8. 成功在家用ssh远程连上了学校电脑虚拟机当中的ubuntu(代价是虚拟机全部黑屏只能用SSH连接了!)
  9. jmeter学习指南之源码导入 IntelliJ IDEA
  10. Block和inline元素对比
  11. (源码)智能优化算法—藤壶交配优化算法(Barnacles Mating Optimizer,BMO)
  12. Confluence 6.15 附件(Attachments )宏
  13. 哪个软件测试交易系统好用,交易系统测试结果的可信度检验
  14. matlab 模的平方,RSA模重复平方算法小示例
  15. 计算机数据表示实验报告,过程通道和数据采集处理实验报告.docx
  16. 从单体应用到微服务开发旅程
  17. 贝叶斯网络(belief network)
  18. 阿刚编程遇到的小问题集合~ 以后回顾用
  19. 扩展easyUI样式,全新的easyUI体验样式
  20. robotframework基础入门:(3):找不到关键字的对应方法

热门文章

  1. java quot;1quot;==quot;1quot;_JAVA: 为什么要使用quot;抽象类quot;? 使用quot;抽象类quot;有什么好处?...
  2. bean找不到报空指针_为什么C指针可以实现函数间的通信呢?
  3. idea lombok插件安装_mac安装的软件和idea的插件推荐
  4. Android开发之SDK开发获取资源id报错的问题
  5. iphone-命令行编译之--xcodebuild
  6. CIKERS Shane 20190530
  7. iOS开发-开发总结(四)
  8. Paket:一个面向.NET的包管理器
  9. Lower Power with CPF(三)
  10. C#线程 在某一时间内,只有N个线程在并发执行,其余都在队列中的实现(转载)...