【摘要】本文探讨了Ceph的架构原理、读写原理。本系列后续还将解读Swift、GFS等,欢迎关注。
首先,我们从 Ceph的官方网站上,可以看到:“Ceph is a unified, distributed storage system designed for excellent performance, reliability and scalability.” 从它的定义上我们可以明确它是一种存储系统,而且可以明确它所具备的两点特性:
(1)统一性( unified ):意味着可以同时提供对象存储、块存储和文件系统存储三种接口功能。
(2)分布式( distributed ):意味着其内部节点架构是以分布式集群算法为依托的。
接下来,我们从其架构原理以及读写原理上来分析其如何支撑定义当中所提到的各个特性。
从功能角度来讲,Ceph本身的架构比较清晰明了,主要分应用接口层、存储基础接口层以及存储对象层,接口层主要对客户端的访问负责,分为本地语言绑定接口(C/C++, Java, Python)、RESTful (S3/Swift)、块存储设备接口、文件系统接口。从这个点上,其完整诠释了“统一性( unified )”的特性。
具体如图2.1所示: