ceph初步

简介: ceph初步

   最近工作涉及到了ceph相关的内容,虽然只是一点点皮毛,但是还是有必要去了解下,以备不时之需,方便与他人交流和沟通。        在网上也找了一些介绍,很多都介绍的有点不清不楚,有头无尾,找了一个比较清晰的介绍来做一下记录,从中提取一些关键点。完整部分见阅读原文。

  • 介绍

       Ceph是一个统一的分布式存储系统,其设计初衷是提供较好的性能、可靠性和可扩展性。在经过多年的发展之后,目前已得到众多云计算厂商的支持并被广泛应用。RedHat及OpenStack都可与Ceph整合以支持虚拟机镜像的后端存储。

  • 优势
  1. 高性能
  1. 摒弃了传统的集中式存储元数据寻址的方案,采用CRUSH算法,数据分布均衡,并行度高
  2. 考虑了容灾域的隔离,能够实现各类负载的副本放置规则,例如跨机房、机架感知等
  3. 能够支持上千个存储节点的规模。支持TB到PB级的数据
  1. 高可用
  1. 副本数可以灵活控制
  2. 支持故障域分隔,数据强一致性
  3. 多种故障场景自动进行修复自愈没有单点故障,自动管理
  1. 高扩展性
  1. 去中心化
  2. 扩展灵活
  3. 随着节点增加,性能线性增长
  1. 特性丰富
  1. 支持三种存储接口:对象存储,块设备存储,文件存储
  2. 支持自定义接口,支持多种语言驱动


  • 基本结构

  • Ceph的底层是RADOS,RADOS本身也是分布式存储系统,Ceph所有的存储功能都是基于RADOS实现的。RADOS采用C++开发,所提供的原生Librados API包括C和C++两种。
  • Ceph的上层应用调用本机上的librados API,再由后者通过socket与RADOS集群中的其他节点通信并完成各种操作。
  • RADOS GateWay、RBD其作用是在librados库的基础上提供抽象层次更高、更便于应用或客户端使用的上层接口。
  • 其中RADOS GW是一个提供与Amazon S3和Swift兼容的RESTful API的gateway,以供相应的对象存储应用开发使用。
  • RBD则提供了一个标准的块设备接口,常用于在虚拟化的场景下为虚拟机创建volume。
  • 目前,RedHat已经将RBD驱动集成在KVM/QEMU中,以提供虚拟机访问性能。这两种方式目前在云计算中应用的比较多。
  • CephFS则提供了POSIX接口,用户可直接通过客户端挂载使用。它是内核态的程序,所有无需调用用户空间的librados库。它通过内核中的net模块来与RADOS进行交互。


  • 基本组件

如上图所示,Ceph主要有三个基本进程:

  • OSD
  • 用于集群中所有数据与对象的存储。处理集群数据的复制、恢复、回填、再均衡。并向其他osd守护进程发送心跳,然后向Mon提供一些监控信息。
  • 当Ceph存储集群设定的数据有两个副本时(一共存两份),则至少需要两个OSD守护进程,即两个OSD节点,集群才能到达active+clean状态。
  • MDS(可选)
  • 为Ceph文件系统提供元数据计算、缓存与同步。在Ceph中,元数据也是存储在osd节点中的,mds类似于元数据的代理缓存服务器。MDS进程并不是必须的进程,只有需要使用CephFS时,才需要配置MDS节点。
  • Monitor
  • 监控整个集群的状态,维护集群的cluster MAP二进制表,保证集群数据的一致性。ClusterMAP描述了对象块存储的物理位置,以及一个将设备聚合到物理位置的桶列表。


  • 基本概念
  • Object
  • Ceph最底层的存储单元,每个Object包含元数据和原始数据。
  • PG
  • 全称Placement Groups,是一个逻辑的概念,一个PG包含多个OSD。引入PG这一层其实是为了更好的分配数据和定位数据。
  • RADOS
  • 全称Reliable Autonomic Distributed Object Store,是Ceph集群的精华,用户实现数据分配、Failover等集群操作。
  • Librados
  • Librados是RADOS提供的库。因为RADOS很难直接访问,因此上层的RBD、RGW和CephFS都是通过Librados访问的。
  • CRUSH
  • 是Ceph使用的数据分布算法,让数据分配到预期的地方。
  • RBD
  • 全称RADOS block device,是Ceph对外提供的块设备服务。
  • RGW
  • 全称RADOS GateWay,是Ceph对外提供的对象存储服务,接口与S3、Swift兼容。
  • CephFS
  • 全称Ceph File System,是Ceph对外提供的文件系统服务。
相关文章
|
存储 算法 关系型数据库
【CEPH-初识篇】ceph详细介绍、搭建集群及使用,带你认识新大陆
你好,我是无名小歌。 今天给大家分享一个分布式存储系统ceph。 什么是ceph? Ceph在一个统一的系统中独特地提供对象、块和文件存储。Ceph 高度可靠、易于管理且免费。Ceph 的强大功能可以改变您公司的 IT 基础架构和管理大量数据的能力。Ceph 提供了非凡的可扩展性——数以千计的客户端访问 PB 到 EB 的数据。ceph存储集群相互通信以动态复制和重新分配数据。
1168 0
【CEPH-初识篇】ceph详细介绍、搭建集群及使用,带你认识新大陆
|
9月前
|
存储 缓存 运维
Ceph 是什么
Ceph 是什么
104 0
|
存储 Prometheus 监控
使用cephadm安装ceph octopus
使用cephadm安装ceph octopus
使用cephadm安装ceph octopus
|
存储 算法 Ubuntu
Ceph 心得分享
##Ceph ceph :统一开、分布式的云存储 统一指的是 ceph 在业内同 openstack 、swift 一样可以当作 块存储、文件存储、对象存储来使用。并自带了分布式的特性,保证了生产业务的高可用。其主要核心高频的使用点就是 Ceph 的块存储以及对象存储,我们逐一介绍。 ###块存储特性 * 通过 ceph clients 使用块设备 * 精简配置 * 动态扩容
535 0
Ceph 心得分享
|
存储 关系型数据库 块存储
|
监控 网络安全 开发工具
ceph部署
初次部署ceph,走了很多弯路,特别是ceph网站提供的yum源,有些问题安装总是出错,总结下此次安装成功的步骤,留个脚印!
10975 0
|
开发工具 块存储
Ceph-ansible 部署Ceph
Ceph-ansible 部署Ceph   1、安装notario yum install -y python-pip pip install notario 这个包用yum装的版本是不符合要求的,需要使用pip进行安装   2、下载ceph-ansible的代码到本地 git clone https://github.
5884 0
|
Ubuntu 开发工具 块存储
|
Ubuntu 开发工具 块存储