Openstack(十七)部署快存储cinder

时间:2022-09-24 23:08:36

官方部署文档:https://docs.openstack.org/ocata/zh_CN/install-guide-rdo/cinder.html

OpenStack的存储组件—Cinder和Swift—让你在你的私有云里构建块存储和对象的存储系统,Openstack从Folsom开始使用Cinder替换原来的Nova-Volume服务,为Openstack云平台提供块存储服务,Cinder接口提供了一些标准功能,允许创建和附加块设备到虚拟机,如“创建卷”,“删除卷”和“附加卷”。还有更多高级的功能,支持扩展容量的能力,快照和创建虚拟机镜像克隆,主要涉及到的组件如下:

cinder-api:接受API请求,并将其路由到“cinder-volume“执行,即请求cinder要先请求此对外API。

cinder-volume:与块存储服务和例如“cinder-scheduler“的进程进行直接交互。它也可以与这些进程通过一个消息队列进行交互。“cinder-volume“服务响应送到块存储服务的读写请求来维持状态。它也可以和多种存储提供者在驱动架构下进行交互。

cinder-scheduler守护进程:选择最优存储提供节点来创建卷。其与“nova-scheduler“组件类似。

cinder-backup守护进程:“cinder-backup“服务提供任何种类备份卷到一个备份存储提供者。就像“cinder-volume“服务,它与多种存储提供者在驱动架构下进行交互。

消息队列:在块存储的进程之间路由信息。

17.1创建cinder数据库

# mysql -uroot –p

> CREATE DATABASE cinder;

> GRANT ALL PRIVILEGES ON cinder.* TO 'cinder'@'%'  IDENTIFIED BY 'cinde

r123';

> flush privileges;

17.2控制端数据访问验证

# mysql -ucinder -h192.168.10.100 -pcinder123

Openstack(十七)部署快存储cinder

17.3控制端cinder服务注册

17.3.1创建cinder用户并授权

# source  admin-ocata.sh

# openstack user create --domain default --password-prompt cinder

User Password:

Repeat User Password:

+---------------------+----------------------------------+

| Field               | Value                            |

+---------------------+----------------------------------+

| domain_id           | 81672c29064942aea8fb754820ddb76a |

| enabled             | True                             |

| id                  | f12af1d5583e4b179354c3b4d8d0d778 |

| name                | cinder                           |

| options             | {}                               |

| password_expires_at | None                             |

+---------------------+----------------------------------+

#授权admin权限

#  openstack role add --project service --user cinder admin

17.3.2创建服务

# v2,v3版本创建

# openstack service create --name cinderv2 --description "OpenStack Block Storage" volumev2

# v2,v3版本创建

# openstack service create --name cinderv3 --description "OpenStack Block Storage" volumev3

17.3.3注册V2版本endpoint

#公共端点:

# openstack endpoint create --region RegionOne volumev2 public http://192.168.10.100:8776/v2/%\(project_id\)s

+--------------+----------------------------------------------+

| Field        | Value                                        |

+--------------+----------------------------------------------+

| enabled      | True                                         |

| id           | cf87da53a7754996972b7ef2baf73933             |

| interface    | public                                       |

| region       | RegionOne                                    |

| region_id    | RegionOne                                    |

| service_id   | 8077b7de84fc4b32a288306459bad10b             |

| service_name | cinderv2                                     |

| service_type | volumev2                                     |

| url          | http://192.168.10.100:8776/v2/%(project_id)s |

+--------------+----------------------------------------------+

#私有端点:

# openstack endpoint create --region RegionOne volumev2 internal http://192.168.10.100:8776/v2/%\(project_id\)s

+--------------+----------------------------------------------+

| Field        | Value                                        |

+--------------+----------------------------------------------+

| enabled      | True                                         |

| id           | 4d8cfb82cd4a4015876df6aafc8bb219             |

| interface    | internal                                     |

| region       | RegionOne                                    |

| region_id    | RegionOne                                    |

| service_id   | 8077b7de84fc4b32a288306459bad10b             |

| service_name | cinderv2                                     |

| service_type | volumev2                                     |

| url          | http://192.168.10.100:8776/v2/%(project_id)s |

+--------------+----------------------------------------------+

#管理端点:

# openstack endpoint create --region RegionOne volumev2 admin http://192.168.10.100:8776/v2/%\(project_id\)s

+--------------+----------------------------------------------+

| Field        | Value                                        |

+--------------+----------------------------------------------+

| enabled      | True                                         |

| id           | 686d554b483a4a52b36c6b6a6c3a2feb             |

| interface    | admin                                        |

| region       | RegionOne                                    |

| region_id    | RegionOne                                    |

| service_id   | 8077b7de84fc4b32a288306459bad10b             |

| service_name | cinderv2                                     |

| service_type | volumev2                                     |

| url          | http://192.168.10.100:8776/v2/%(project_id)s |

+--------------+----------------------------------------------+

17.3.4注册V3版本endpoint

#公共端点:

# openstack endpoint create --region RegionOne volumev3 public http://192.168.10.100:8776/v3/%\(project_id\)s

+--------------+----------------------------------------------+

| Field        | Value                                        |

+--------------+----------------------------------------------+

| enabled      | True                                         |

| id           | 729e23316e964ff6bc6315f4d95e590a             |

| interface    | public                                       |

| region       | RegionOne                                    |

| region_id    | RegionOne                                    |

| service_id   | 4234b69629ac4e6bbabcd72c8bb0ab81             |

| service_name | cinderv3                                     |

| service_type | volumev3                                     |

| url          | http://192.168.10.100:8776/v3/%(project_id)s |

+--------------+----------------------------------------------+

#私有端点:

# openstack endpoint create --region RegionOne volumev3 internal http://192.168.10.100:8776/v3/%\(project_id\)s

+--------------+----------------------------------------------+

| Field        | Value                                        |

+--------------+----------------------------------------------+

| enabled      | True                                         |

| id           | 0541cfdf2d99477fb4105aac045f0399             |

| interface    | internal                                     |

| region       | RegionOne                                    |

| region_id    | RegionOne                                    |

| service_id   | 4234b69629ac4e6bbabcd72c8bb0ab81             |

| service_name | cinderv3                                     |

| service_type | volumev3                                     |

| url          | http://192.168.10.100:8776/v3/%(project_id)s |

+--------------+----------------------------------------------+

#管理端点:

# openstack endpoint create --region RegionOne volumev3 admin http://192.168.10.100:8776/v3/%\(project_id\)s

+--------------+----------------------------------------------+

| Field        | Value                                        |

+--------------+----------------------------------------------+

| enabled      | True                                         |

| id           | 3b45ed17bb724479a49df89e49a0e2ae             |

| interface    | admin                                        |

| region       | RegionOne                                    |

| region_id    | RegionOne                                    |

| service_id   | 4234b69629ac4e6bbabcd72c8bb0ab81             |

| service_name | cinderv3                                     |

| service_type | volumev3                                     |

| url          | http://192.168.10.100:8776/v3/%(project_id)s |

+--------------+----------------------------------------------+

17.4配置haproxy负载

# vim /etc/haproxy/haproxy.cfg

listen cinder

bind 192.168.10.100:8776

mode tcp

log global

balance source

server cinder-server 192.168.10.201:8776 check inter 5000 rise 3 fall 3

# systemctl reload haproxy.service

17.5安装并配置cinder组件

17.5.1控制端安装cinder

#  yum install openstack-cinder –y

17.5.2编辑配置文件cinder.conf

# vim /etc/cinder/cinder.conf

1:[DEFAULT]

263:my_ip = 192.168.10.201

376:auth_strategy = keystone

3243:transport_url = rabbit://openstack:123456@192.168.10.205

3518:[database]

3546:connection = mysql+pymysql://cinder:cinder123@192.168.10.100/cinder

3767:[keystone_authtoken]

3768:auth_uri = http://192.168.10.100:5000

3769:auth_url = http://192.168.10.100:35357

3770:memcached_servers = 192.168.10.100:11211

3771:auth_type = password

3772:project_domain_name = default

3773:user_domain_name = default

3774:project_name = service

3775:username = cinder

3776:password = cinder

3996:[oslo_concurrency]

4012:lock_path = /var/lib/cinder/tmp

17.5.3同步并验证数据库

# su -s /bin/sh -c "cinder-manage db sync" cinder

17.5.4验证数据库同步成功

# mysql -ucinder -h192.168.10.100 -pcinder123

Openstack(十七)部署快存储cinder

17.5.5控制端重启nova-api服务

#  systemctl restart openstack-nova-api.service

17.5.6启动块存储服务cinder

# systemctl enable openstack-cinder-api.service openstack-cinder-scheduler.service

# systemctl start openstack-cinder-api.service openstack-cinder-scheduler.service

17.5.7验证cinder日志

# tail -f /var/log/cinder/*.log

Openstack(十七)部署快存储cinder

17.6配置计算节点使用cinder存储

17.6.1编辑配置文件nova.conf

# vim /etc/nova/nova.conf

3982 [cinder]

4031 os_region_name=RegionOne

17.6.2重启nova服务

# systemctl restart libvirtd.service openstack-nova-compute.service

17.6.3验证cinder控制端

# openstack volume service list

Openstack(十七)部署快存储cinder

17.7配置存储节点

17.7.1添加磁盘

在负载服务器(或其他指定服务器)新添加一块50G的磁盘然后点确定:

Openstack(十七)部署快存储cinder

17.7.2安装LVM包

#  yum install lvm2 –y

17.7.3启动LVM并设置为开机启动

#  systemctl enable lvm2-lvmetad.service

#  systemctl start lvm2-lvmetad.service

17.7.4动态识别新磁盘

# ll /sys/class/scsi_host/host

host0/ host1/ host2/

# echo "- - -" > /sys/class/scsi_host/host0/scan

# echo "- - -" > /sys/class/scsi_host/host1/scan

# echo "- - -" > /sys/class/scsi_host/host2/scan

17.7.5验证磁盘

#fdisk -l

Openstack(十七)部署快存储cinder

17.7.6创建物理卷和卷组

#  pvcreate /dev/sdb

Physical volume "/dev/sdb" successfully created.

#  vgcreate cinder-volumes /dev/sdb

Volume group "cinder-volumes" successfully created

17.8存储安装并配置组件

在负载服务器安装配置

17.8.1安装组件

#  yum install openstack-cinder targetcli python-keystone –y

17.8.2编辑配置文件cinder.conf

# vim /etc/cinder/cinder.conf

1:[DEFAULT]

283:my_ip = 192.168.10.205

288:glance_api_servers = http://192.168.10.100:9292

400:auth_strategy = keystone

404:enabled_backends = lvm

1210:transport_url = rabbit://openstack:123456@192.168.10.205

3730:[database]

3749:connection = mysql+pymysql://cinder:cinder123@192.168.10.100/cinder

3973:[keystone_authtoken]

3974:auth_uri = http://192.168.10.100:5000

3975:auth_url = http://192.168.10.100:35357

3976:memcached_servers = 192.168.10.100:11211

3977:auth_type = password

3978:project_domain_name = default

3979:user_domain_name = default

3980:project_name = service

3981:username = cinder

3982:password = cinder

4249:[oslo_concurrency]

4263:lock_path = /var/lib/cinder/tmp

4904:[lvm]

4905:volume_driver = cinder.volume.drivers.lvm.LVMVolumeDriver

4906:volume_group = cinder-volumes

4907:iscsi_protocol = iscsi

4908:iscsi_helper = lioadm

4909:volume_backend_name=Openstack-lvm

17.8.3启动服务并设置为开机启动

#  systemctl enable openstack-cinder-volume.service target.service

#  systemctl start openstack-cinder-volume.service target.service

17.8.4验证日志

Openstack(十七)部署快存储cinder

17.8.5控制端验证cinder注册

# openstack volume service list

Openstack(十七)部署快存储cinder

17.9验证卷使用

17.9.1创建卷

使用admin或者demo用户登录到管理界面,点击卷—创建卷:

Openstack(十七)部署快存储cinder

17.9.2填写卷信息

Openstack(十七)部署快存储cinder

17.9.3查看卷状态

Openstack(十七)部署快存储cinder

17.9.4关联到虚拟机

Openstack(十七)部署快存储cinder

17.9.5关联到目标虚拟机

Openstack(十七)部署快存储cinder

17.9.6连接后的卷状态

Openstack(十七)部署快存储cinder

17.9.7虚拟机验证磁盘

Openstack(十七)部署快存储cinder

17.9.8格式化磁盘

# mkfs.ext4 /dev/vdb

Openstack(十七)部署快存储cinder

17.9.9挂载磁盘并复制数据

Openstack(十七)部署快存储cinder

17.9.10磁盘挂载至其他虚拟机

新创建一个虚拟机,用于将上一步关联的卷分离后挂载到新的虚拟机上进行测试。

17.9.10.1卸载卷

在之前的虚拟机将卷卸载。

Openstack(十七)部署快存储cinder

17.9.10.2磁盘分离

点击项目-卷-管理连接:

Openstack(十七)部署快存储cinder

17.9.10.3分离卷

Openstack(十七)部署快存储cinder

17.9.10.4确认分离

Openstack(十七)部署快存储cinder

17.9.10.5挂载至新实例

在管理连接界面,将卷关联至test-vm2:

Openstack(十七)部署快存储cinder

17.9.10.6关联成功

Openstack(十七)部署快存储cinder

17.9.10.7新实例验证磁盘

验证可以挂载关联的磁盘并可以查看之前的数据

Openstack(十七)部署快存储cinder

Openstack(十七)部署快存储cinder的更多相关文章

  1. openstack(liberty):部署实验平台(三,简单版本软件安装 之cinder,swift)

    今天这里追加存储相关的部署,主要是Block和Object,为了看到效果,简单的部署在单节点上,即Block一个节点,Object对应一个节点. 读者可能会觉得我这个图和之前的两个post有点点不同, ...

  2. CentOS7安装OpenStack(Rocky版)-09.安装Cinder存储服务组件(控制节点)

    本文分享openstack的Cinder存储服务组件,cinder服务可以提供云磁盘(卷),类似阿里云云盘 ----------------------- 完美的分隔线  -------------- ...

  3. Openstack块存储cinder安装配置

    openstack service create --name cinderv2 \ --description "OpenStack Block Storage" volumev ...

  4. openstack havana块存储Cinder磁盘加密方法研究

    http://blog.csdn.net/cloudresearch/article/details/19092219 在openstack havana的release note中有如下介绍“Att ...

  5. OpenStack Havana 部署在Ubuntu 12.04 Server 【OVS+GRE】(一)——控制节点的安装

      序:OpenStack Havana 部署在Ubuntu 12.04 Server [OVS+GRE] 控制节点: 1.准备Ubuntu 安装好Ubuntu12.04 server 64bits后 ...

  6. openstack第五章:cinder

    第五篇cinder— 存储服务   一.cinder 介绍:   理解 Block Storage 操作系统获得存储空间的方式一般有两种: 通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接 ...

  7. OpenStack大规模部署详解

    https://blog.csdn.net/karamos/article/details/80130443 0.前言今年的2月22日,OpenStack发布了15个版本Ocata. 走过了7年的发展 ...

  8. openstack 安装部署

    环境准备 本次搭建的是openstack kilo版本,计算节点和控制节点采用linux bridge的方式连接 1.两台服务器 controller 172.16.201.9 compute01 1 ...

  9. OpenStack Havana 部署在Ubuntu 12.04 Server 【OVS+GRE】(三)——计算节点的安装

    序:OpenStack Havana 部署在Ubuntu 12.04 Server [OVS+GRE] 计算节点: 1.准备结点 安装好ubuntu 12.04 Server 64bits后,进入ro ...

随机推荐

  1. Python语言特性之2:元类

    问题:Python中的元类(metaclasses)是什么?一般使用它干什么? 原地址:http://*.com/questions/100003/what-is-a-meta ...

  2. Android Handler机制(一)---Message源码分析

    Message: 定义: public final class Message implements Parcelable Message类是个final类,就是说不能被继承,同时Message类实现 ...

  3. Karma:2. 集成 Karma 和 mocha 进行单元测试

    上一篇文章讨论了如何集成 Karma 和 Jasmine,地址见:Karma:1. 集成 Karma 和 Jasmine 进行单元测试 这篇文章讨论如何 Karma 集成 mocha 测试框架. 安装 ...

  4. 追溯ASP.NET发展史

    2000年全新平台的ASP.NET 1.0正式发布,发展速度异常惊人,2003年升级为1.1版本.ASP.NET 1.1发布之后,更加激发了Web应用程序开发人员对ASP.NET的兴趣,并且对网络技术 ...

  5. java将office文档pdf文档转换成swf文件在线预览

    第一步,安装openoffice.org openoffice.org是一套sun的开源office办公套件,能在widows,linux,solaris等操作系统上执行. 主要模块有writer(文 ...

  6. HTTP Status 500 - Servlet.init() for servlet htmlWebConfig threw exception

    HTTP Status 500 - Servlet.init() for servlet htmlWebConfig threw exception

  7. POJ 2378-Tree Cutting(树形dp)

    题意: n个节点的树,删除一个点,得到的最大联通分支大小不大于总节点数的一半,求这样点的集合 分析:和上题一样 #include <map> #include <set> #i ...

  8. tRNAscan-SE

    tRNAscan-SE是一款可以在基因组上扫描tRNA的序列,也就是说你给定一组基因序列(fasta数据格式),可以用这个软件去预测这个序列是不是tRNA.具体的实现原理,我不搞生物,所以也就不太明白 ...

  9. 百度ueditor 上传图片后如何设置样式

    最近项目中遇到一个问题,UEditor上传图片后,在内容展示会修改图片样式.但是表情也是img标签,所以全局修改是有问题的, 所以只能着手修改一下插件的代码. 首先找到图片上传的服务器段文件.这里主要 ...

  10. IOS开发之路三(XML解析之GDataXML的使用)

    最近再做一个项目需要用到xml的解析.今天查了一些资料自己做了一个小demo.纯OC没有界面.. 在IOS平台上进行XML文档的解析有很多种方法,在SDK里面有自带的解析方法,但是大多情况下都倾向于用 ...