深入解析OpenStack Cinder:块存储服务详解

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
实时数仓Hologres,5000CU*H 100GB 3个月
简介: 本文介绍了OpenStack及其块存储服务Cinder。OpenStack是一个开源云计算管理平台,提供基础设施即服务(IaaS),核心服务包括计算、网络、存储等。Cinder主要用于为虚拟机提供持久性块存储,具备多种功能,如卷操作、备份、快照及与实例的交互等。此外,还详细介绍了Cinder的工作流程、命令行操作及不同存储插件的使用。

目录

OpenStack简介

Openstack中的存储:

虚机对块存储的要求:

Cinder介绍

主要组件

Cinder 基本功能

Cinder命令行

通用命令

卷操作

卷快照操作

卷备份操作

卷与实例的操作

卷迁移

其他

Cinder工作流程

Cinder插件


OpenStack简介

OpenStack是一个开源的云计算管理平台项目,它是一套用于部署和管理云端计算资源的软件。OpenStack提供了基础设施即服务(IaaS)的应用程序,允许用户和管理员从个人电脑到大型多租户环境部署和管理大量的计算、存储和网络资源池。OpenStack的核心服务包括Nova(计算)、Neutron(网络)、Cinder(块存储)、Swift(对象存储)、Glance(镜像服务)和Keystone(身份验证服务)等。

Openstack中的存储:

      image.gif 编辑

虚机对块存储的要求:

一般在我们创建实例,也是虚机的时候会伴随着创建一个卷,他会创建并挂载在我们的虚机上,随之我们可以对卷进行操作等。在我们删除虚机的时候卷也随之删除。

image.gif 编辑

Cinder介绍

Cinder是OpenStack中的块存储服务,主要用于为虚拟机提供持久性块存储设备。它的设计目标是为虚拟机提供一个独立于虚拟机生命周期之外的数据存储,这样即使虚拟机关机了,数据仍然会被保存下来。

主要组件

  • cinder-api:提供RESTful API来处理客户端请求,如创建、删除和附加卷等。
  • cinder-scheduler:根据策略选择合适的后端存储节点来创建卷。
  • cinder-volume:在选定的后端存储上执行实际的卷创建、快照、备份等操作。
  • cinder-backup:处理卷的备份与恢复操作。
  • cinder的数据库:用于存储状态信息和其他元数据。
  • Cinder的开发工作主要集中在scheduler和driver,以便提供更多的调度算法、更多的功能、以及指出更多的后端存储
  • Cinder组件之间的RPC靠消息队列(Queue)实现
  • Volume元数据和状态保存在Database中,一般是在cinder库中的volume中,我们从cinder list看到的数据都是从中拿取。

image.gif 编辑

Cinder 基本功能

  1. 卷操作
  • 创建卷
  • 从已有卷创建卷(克隆)
  • 扩展卷
  • 删除卷
  1. 卷-虚机操作
  • 挂载卷到虚机
  • 分离虚机卷
  1. 卷-快照操作
  • 创建卷的快照
  • 从已有卷快照创建卷
  • 删除快照
  1. 卷-镜像操作
  • 从镜像创建卷
  • 从卷创建镜像

部分截图:

image.gif 编辑

image.gif 编辑

image.gif 编辑

Cinder命令行

通用命令

  • cinder --version: 显示Cinder客户端的版本信息。
  • cinder help: 显示所有可用命令的帮助信息。
  • cinder help <command>: 获取特定命令的帮助信息。

卷操作

  • cinder list: 列出所有的卷。
  • cinder show <volume-id>: 显示特定卷的详细信息。
  • cinder create <size>: 创建指定大小的新卷。
  • cinder delete <volume-id>: 删除指定的卷。
  • cinder delete --force <volume-id>: 无视状态删除指定的卷
  • cinder resize <volume-id> <new-size>: 扩展或缩小卷的大小。
  • cinder extend <volume-id> <new-size>: 扩展卷的大小。
  • cinder type-create <type-name>: 创建新的卷类型。
  • cinder type-list: 列出所有卷类型。
  • cinder type-key <type-name> set <key>=<value>: 设置卷类型的键值。
  • cinder type-key <type-name> unset <key>: 移除卷类型的键值。

卷快照操作

  • cinder snapshot-create <volume-id> [--name <snapshot-name>]: 为指定的卷创建快照。
  • cinder snapshot-list: 列出所有的快照。
  • cinder snapshot-show <snapshot-id>: 显示特定快照的详细信息。
  • cinder snapshot-delete <snapshot-id>: 删除指定的快照。
  • cinder snapshot-update <snapshot-id> <metadata>: 更新快照的元数据。
  • cinder snapshot-restore <snapshot-id>: 从快照恢复卷。

卷备份操作

  • cinder backup-create <volume-id> [--name <backup-name>]: 创建卷的备份。
  • cinder backup-restore <backup-id> <volume-id>: 将备份恢复到指定的卷。
  • cinder backup-list: 列出所有的备份。
  • cinder backup-show <backup-id>: 显示特定备份的详细信息。
  • cinder backup-delete <backup-id>: 删除指定的备份。

卷与实例的操作

  • cinder attach <volume-id> <instance-id> <device>: 将卷挂载到实例上的指定设备。
  • cinder detach <volume-id>: 将卷从实例上分离。
  • cinder initialize-connection <volume-id> <instance-id>: 初始化卷与实例之间的连接。
  • cinder terminate-connection <volume-id> <instance-id>: 终止卷与实例之间的连接。

卷迁移

  • cinder migration-start <volume-id> <host>: 开始将卷迁移到另一台主机。
  • cinder migration-check <volume-id> <host>: 检查卷迁移的状态。
  • cinder migration-complete <volume-id>: 完成卷迁移。
  • cinder migration-cancel <volume-id>: 取消正在进行的卷迁移。
  • cinder migration-get-progress <volume-id>: 获取卷迁移进度。

其他

  • cinder service-list: 列出所有运行的服务。

Cinder工作流程

  1. 用户通过cinder-api请求创建一个新的卷。
  2. cinder-api通过RPC将请求发送给cinder-scheduler。
  3. cinder-scheduler基于配置的权重算法选择一个最合适的volume节点。
  4. cinder-volume服务在被选中的节点上创建卷,并将结果返回给cinder-scheduler。
  5. cinder-scheduler更新请求状态并将结果返回给cinder-api。
  6. cinder-api最终将结果返回给用户。

image.gif 编辑

Cinder插件

        image.gif 编辑

由上图可见,Cinder是多样化的,可以对接多种样式的存储,在我们一般日常使用中lvm是作为我们最简单的测试和开发。

image.gif 编辑

ISCSI简介:

       ISCSI(Internet Small Computer System Interface)是一种协议,它允许在IP网络上传输SCSI指令和数据。iSCSI Target则是指接收来自iSCSI Initiator SCSI命令的服务器或设备。简单来说,iSCSI Target就像是一个存储服务器,它提供块级别的数据存储访问给网络上的其他设备。

       举个栗子:你有一个磁盘,我想用你的磁盘,我就可以通过一种协议去把你的磁盘挂载到我的本地。这个协议就是ISCSI,其中挂载的细节我在此就不赘述了。大家有兴趣可以自行搜索。

回归Cinder里面的ISCSI机制,在Cinder中Control节点会把lvm卷通过ISCSI挂载给他的计算节点。因为我了解的也不够深刻,我只能理解表面的一层意思是不让让自己的控制节点负载过大。

image.gif 编辑


相关实践学习
块存储快速入门
块存储是阿里云为云服务器ECS提供的块设备产品。通过体验挂载数据盘、分区格式化数据盘(Linux)、创建云盘快照、重新初始化数据盘、使用快照回滚云盘和卸载数据盘等功能,带您快速入门块存储。
相关文章
|
15天前
|
存储 缓存 算法
分布式锁服务深度解析:以Apache Flink的Checkpointing机制为例
【10月更文挑战第7天】在分布式系统中,多个进程或节点可能需要同时访问和操作共享资源。为了确保数据的一致性和系统的稳定性,我们需要一种机制来协调这些进程或节点的访问,避免并发冲突和竞态条件。分布式锁服务正是为此而生的一种解决方案。它通过在网络环境中实现锁机制,确保同一时间只有一个进程或节点能够访问和操作共享资源。
38 3
|
2月前
|
自然语言处理 数据可视化 BI
文档解析(大模型版)服务体验评测
体验文档解析(大模型版)服务时,清晰的入门指南、操作手册和FAQ至关重要。若存在不足,需增加直观的操作流程说明(如动画演示)、深化高级功能文档,并提供实时在线支持,帮助用户快速解决问题。
|
17天前
|
网络安全 Docker 容器
【Bug修复】秒杀服务器异常,轻松恢复网站访问--从防火墙到Docker服务的全面解析
【Bug修复】秒杀服务器异常,轻松恢复网站访问--从防火墙到Docker服务的全面解析
17 0
|
2月前
|
弹性计算 自然语言处理 数据可视化
|
26天前
|
存储 缓存 网络协议
搭建dns服务常见报错--查看/etc/named.conf没有错误日志信息却显示出错(/etc/named.conf:49: missing ‘;‘ before ‘include‘)及dns介绍
搭建dns服务常见报错--查看/etc/named.conf没有错误日志信息却显示出错(/etc/named.conf:49: missing ‘;‘ before ‘include‘)及dns介绍
|
2月前
|
域名解析 网络协议
DNS服务工作原理
文章详细介绍了DNS服务的工作原理,包括FQDN的概念、名称解析过程、DNS域名分级策略、根服务器的作用、DNS解析流程中的递归查询和迭代查询,以及为何有时基于IP能访问而基于域名不能访问的原因。
167 2
|
3月前
|
存储 数据管理 API
OpenStack的块存储卷管理快照与克隆
【8月更文挑战第27天】
35 4
|
3月前
|
存储 容灾 API
OpenStack的块存储卷管理附着与分离
【8月更文挑战第27天】
79 2
|
3月前
|
Java 缓存 数据库连接
揭秘!Struts 2性能翻倍的秘诀:不可思议的优化技巧大公开
【8月更文挑战第31天】《Struts 2性能优化技巧》介绍了提升Struts 2 Web应用响应速度的关键策略,包括减少配置开销、优化Action处理、合理使用拦截器、精简标签库使用、改进数据访问方式、利用缓存机制以及浏览器与网络层面的优化。通过实施这些技巧,如懒加载配置、异步请求处理、高效数据库连接管理和启用GZIP压缩等,可显著提高应用性能,为用户提供更快的体验。性能优化需根据实际场景持续调整。
68 0
|
3月前
|
开发者 iOS开发 C#
Uno Platform 入门超详细指南:从零开始教你打造兼容 Web、Windows、iOS 和 Android 的跨平台应用,轻松掌握 XAML 与 C# 开发技巧,快速上手示例代码助你迈出第一步
【8月更文挑战第31天】Uno Platform 是一个基于 Microsoft .NET 的开源框架,支持使用 C# 和 XAML 构建跨平台应用,适用于 Web(WebAssembly)、Windows、Linux、macOS、iOS 和 Android。它允许开发者共享几乎全部的业务逻辑和 UI 代码,同时保持原生性能。选择 Uno Platform 可以统一开发体验,减少代码重复,降低开发成本。安装时需先配置好 Visual Studio 或 Visual Studio for Mac,并通过 NuGet 或官网下载工具包。
151 0

推荐镜像

更多