一、块存储服务

    块存储服务提供对 volume 从创建到删除整个生命周期的管理

    从 instance 的角度看,挂载的每一个 Volume 都是一块硬盘。

    OpenStack 提供 Block Storage Service 的是 Cinder,其具体功能是:

    • 提供 REST API 使用户能够查询和管理 volume、volume snapshot 以及 volume type

    • 提供 scheduler 调度 volume 创建请求,合理优化存储资源的分配

    • 通过 driver 架构支持多种 back-end(后端)存储方式,包括 LVM,NFS,Ceph 和其他诸如 EMC、IBM 等商业存储产品和方案


二、cinder架构

openstack组件之cinder_cinder

1、cinder-api:接收 API 请求,调用 cinder-volume 执行操作。

2、cinder-volume:管理 volume 的服务,与 volume provider协调工作,管理 volume 的生命周期。运行 cinder-volume 服务的节点被称作为存储节点。

3、cinder-scheduler:scheduler 通过调度算法选择最合适的存储节点创建 volume。

4、volume provider :数据的存储设备,为 volume 提供物理存储空间。 

cinder-volume 支持多种 volume provider,每种 volume provider 通过自己的 driver 与cinder-volume 协调工作。

5、Message Queue:Cinder 各个子服务通过消息队列实现进程间通信和相互协作。因为有了消息队列,子服务之间实现了解耦,这种松散的结构也是分布式系统的重要特征。

6、Database:Cinder 有一些数据需要存放到数据库中,一般使用 MySQL。数据库是安装在控制节点上的


三、物理部署方案

    cinder 的服务会部署在两类节点上,控制节点和存储节点。 

    cinder-api 和 cinder-scheduler 部署在控制节点上。

    cinder-volume 在存储节点上。

    RabbitMQ 和 MySQL 通常部署在控制节点上。

    volume provider 一般来讲是独立的。

    cinder-volume 使用 driver 与 volume provider 通信并协调工作。

    所以只需要将 driver 与 cinder-volume 放到一起就可以了。


四、从 volume 创建流程看 cinder-* 子服务如何协同工作

openstack组件之cinder_组件_02

1、客户(以是 OpenStack 最终用户,也可以是其他程序)向 API(cinder-api)发送请求:“帮我创建一个 volume”

2、API 对请求做一些必要处理后,向 Messaging(RabbitMQ)发送了一条消息:“让 Scheduler 选择合适的存储节点”

3、Scheduler(cinder-scheduler)从 Messaging 获取到 API 发给它的消息,然后执行调度算法,从若干计存储点中选出节点 A

4、Scheduler 向 Messaging 发送了一条消息:“让存储节点 A 创建这个 volume”

5、存储节点 A 的 Volume(cinder-volume)从 Messaging 中获取到 Scheduler 发给它的消息,然后通过 driver 在 volume provider 上创建 volume。


五、子服务详解

1、cinder-api 

    cinder-api对接收到的 HTTP API(Volume 生命周期相关的操作)请求会做如下处理:

    • 检查客户端传人的参数是否合法有效

    • 调用 cinder 其他子服务的处理客户端请求

    • 将 cinder 其他子服务返回的结果序列号并返回给客户端

2、cinder-scheduler

    创建Volume时,cinder-scheduler会基于容量、Volume Type等条件选择出最合适的存储节点,然后让其创建Volume

3、cinder-volume

    • cinder-volume 在存储节点上运行,OpenStack 对 Volume 的操作,最后都是交给 cinder-volume 来完成的。 

    • cinder-volume 自身并不管理真正的存储设备,存储设备是由 volume provider 管理的。

    • cinder-volume 与 volume provider 一起实现 volume 生命周期的管理。它们之间是通过driver实现通信。


六、卷的操作

1、挂载

2、卸载

3、删除