本文将对Ceph的基本状况进行概要介绍,以期读者可以在不涉及技术细节的状况下对Ceph创建一个初步印象。服务器
Ceph的官方网站Ceph.com上用以下这句话简明扼要地定义了Ceph:运维
“Ceph is a unified, distributed storage system designed for excellent performance, reliability and scalability.”分布式
也即,Ceph是一种为优秀的性能、可靠性和可扩展性而设计的统一的、分布式的存储系统。应该说,这句话确实点出了Ceph的要义,能够做为理解 Ceph系统设计思想和实现机制的基本出发点。在这个定义中,应当特别注意“存储系统”这个概念的两个修饰词,即“统一的”和“分布式的”。性能
具体而言,“统一的”意味着Ceph能够一套存储系统同时提供对象存储、块存储和文件系统存储三种功能,以便在知足不一样应用需求的前提下简化部署和 运维。而“分布式的”在Ceph系统中则意味着真正的无中心结构和没有理论上限的系统规模可扩展性。在实践当中,Ceph能够被部署于上千台服务器上。截 至2013年3月初,Ceph在生产环境下部署的最大规模系统为Dreamhost公司的对象存储业务集群,其管理的物理存储容量为3PB。网站
事实上,Ceph并非一个刚刚出现的开源项目。与此相反,从最初发布到逐渐流行,Ceph走过了七年以上的漫长路程。笔者觉得,之因此应当对Ceph加以了解,其缘由大体有两个方面:云计算
首先,Ceph自己确实具备较为突出的优点。操作系统
Ceph值得一提的优点颇多,包括统一存储能力、可扩展性、可靠性、性能、自动化的维护等等。本质上,Ceph的这些优点均来源于其先进的核心设计 思想,笔者将其归纳为八个字——“无需查表,算算就好”。基于这种设计思想,Ceph充分发挥存储设备自身的计算能力,同时消除了对系统单一中心节点的依 赖,从而实现了真正的无中心结构。基于这一设计思想和结构,Ceph一方面实现了高度的可靠性和可扩展性,另外一方面保证了客户端访问的相对低延迟和高聚合 带宽。经过后续内容的介绍,读者能够看到,Ceph几乎全部优秀特性的实现,都与这个核心设计思想有关。scala
其次,Ceph目前在OpenStack社区中备受重视。设计
OpenStack是目前最为流行的开源云操做系统。而据笔者观察,Ceph之因此在近一两年间热度骤升,其最为有力的推进因素就是 OpenStack社区的实际需求。目前而言,Ceph已经成为OpenStack社区中呼声最高的开源存储方案之一,其实际应用主要涉及块存储和对象存 储,而且开始向文件系统领域扩展。这一部分的相关状况,在后续文章中也将进行介绍。excel
一般而言,开源项目的来源有三:一是学校里的大牛做的课题,论文发够而后开源;二是企业里的大牛搞的产品,机缘巧合因而开源;三是某些大牛忽然显 灵,而后一票人跟着一块儿开源。每一类的例子都有很多,而不一样起源的开源项目也有着自身的不一样特色。具体而言,第一类项目的原理和技术上极可能很有独到之 处,而Ceph就正在此列。相比之下,第二类项目的设计实现极可能颇为成熟,而且在开源以前或者开源初期就得到生产环境下的实际部署应用机会。这种出身背 景上的因素,对于一个开源项目的后续发展颇有可能产生影响。
言归正传。Ceph项目起源于其创始人Sage Weil在加州大学Santa Cruz分校攻读博士期间的研究课题。项目的起始时间为2004年。在2006年的OSDI学术会议上,Sage发表了介绍Ceph的论文,并在该篇论文 的末尾提供了Ceph项目的下载连接。由此,Ceph开始广为人知。
Ceph使用C++语言开发。对于一个典型的强调性能的系统项目,这一选择能够理解。
做为开源项目,Ceph遵循LGPL协议。
根据Inktank官方网站上的信息,Cpeh的生态系统参加下图:
Ceph ecosystem
不难看出,图中列出的厂商或组织带有明显的云计算气息。
随着Ceph的热度不断增长,Sage Weil于 2011年创立了Inktank公司以主导Ceph的开发和社区维护。目前,Ceph的发布周期为三个月。
在展开后续的技术讨论以前,适度八卦Sage Weil的人生经历实在是颇有必要,由于这位兄台委实是 IT男青年中百里挑一的在工程、研究、创业三个领域都有涉猎且都很有建树的神人。
Sage在工程上的能力天然没必要多言,而他发表Ceph论文的OSDI也是计算机操做系统领域数一数二的最高水平学术会议。至于创业方面,Sage是 DreamHost的联合创始人,彼时是1997年,他刚上大学不久。。。有兴趣的同窗能够去LinkedIn研究一下Sage的我的简历,基本上是想工做就工做,想上学就上学,想创业就创业,想读博就读博,为所欲为,天马行空,使人油然而生一种表示敬佩的冲动。