Openstack Queens版本双节点架构笔记10,Ceph安装2:

安装和配置存储节点

 

先决条件

在存储节点上安装和配置Block Storage服务之前,必须准备存储设备。

 

 注意

 

在控制节点上执行这些步骤(实验做双节点没有做存储节点,所以存储节点的安装在控制节点)。

 

安装支持实用程序包:

安装LVM包:

# yum install lvm2 device-mapper-persistent-data

启动LVM元数据服务并将其配置为在系统引导时启动:

# systemctl enable lvm2-lvmetad.service

# systemctl start lvm2-lvmetad.service

创建LVM物理卷/dev/sdb:

# pvcreate /dev/sdb

 

Physical volume "/dev/sdb" successfully created

创建LVM卷组cinder-volumes:

 

Block Storage服务在此卷组中创建逻辑卷。

# vgcreate cinder-volumes /dev/sdb

 

Volume group "cinder-volumes" successfully created

只有实例才能访问块存储卷。但是,底层操作系统管理与卷关联的设备。默认情况下,LVM卷扫描工具会扫描 /dev目录以查找包含卷的块存储设备。如果项目在其卷上使用LVM,则扫描工具会检测这些卷并尝试对其进行缓存,这可能会导致底层操作系统和项目卷出现各种问题。您必须重新配置LVM以仅扫描包含cinder-volumes卷组的设备。编辑 /etc/lvm/lvm.conf文件并完成以下操作:

 

在该devices部分中,添加一个接受/dev/sdb设备的过滤 器并拒绝所有其他设备:

devices {

...

filter = [ "a/sdb/", "r/.*/"]

Each item in the filter array begins with a for accept or r for reject and includes a regular expression for the device name. The array must end with r/.*/ to reject any remaining devices. You can use the vgs -vvvv command to test filters.

警告

 

如果存储节点在操作系统磁盘上使用LVM,则还必须将关联的设备添加到过滤器。例如,如果/dev/sda设备包含操作系统:

filter = [ "a/sda/", "a/sdb/", "r/.*/"]

同样,如果计算节点在操作系统磁盘上使用LVM,则还必须修改/etc/lvm/lvm.conf这些节点上的文件中的过滤器 以仅包括操作系统磁盘。例如,如果/dev/sda 设备包含操作系统:

filter = [ "a/sda/", "r/.*/"]

安装和配置组件

安装包:

# yum install openstack-cinder targetcli python-keystone

编辑/etc/cinder/cinder.conf文件并完成以下操作:

 

在该[database]部分中,配置数据库访问:

[database]

# ...

connection = mysql+pymysql://cinder:CINDER_DBPASS@controller/cinder

 

替换CINDER_DBPASS为您为Block Storage数据库选择的密码。

在该[DEFAULT]部分中,配置RabbitMQ 消息队列访问:

[DEFAULT]

# ...

transport_url = rabbit://openstack:RABBIT_PASS@controller

替换RABBIT_PASS为您为openstack帐户选择的密码RabbitMQ。

在[DEFAULT]和[keystone_authtoken]部分中,配置身份服务访问:

[DEFAULT]

# ...

auth_strategy = keystone

 

[keystone_authtoken]

# ...

auth_uri = http://controller:5000

auth_url = http://controller:5000

memcached_servers = controller:11211

auth_type = password

project_domain_id = default

user_domain_id = default

project_name = service

username = cinder

password = CINDER_PASS

替换CINDER_PASS为您cinder在Identity服务中为用户选择的密码 。

 

注意

 

注释掉或删除该[keystone_authtoken]部分中的任何其他选项 。

在该[DEFAULT]部分中,配置my_ip选项:

[DEFAULT]

# ...

my_ip = MANAGEMENT_INTERFACE_IP_ADDRESS

替换MANAGEMENT_INTERFACE_IP_ADDRESS为存储节点上管理网络接口的IP地址,对于示例体系结构中的第一个节点,通常为10.0.0.41 。

 

在本[lvm]节中,使用LVM驱动程序,cinder-volumes卷组,iSCSI协议和相应的iSCSI服务配置LVM后端。如果该[lvm]部分不存在,请创建它:

[lvm]

volume_driver = cinder.volume.drivers.lvm.LVMVolumeDriver

volume_group = cinder-volumes

iscsi_protocol = iscsi

iscsi_helper = lioadm

在该[DEFAULT]部分中,启用LVM后端:

[DEFAULT]

# ...

enabled_backends = lvm

注意

 

后端名称是任意的。例如,本指南使用驱动程序的名称作为后端的名称。

 

在该[DEFAULT]部分中,配置Image服务API的位置:

[DEFAULT]

# ...

glance_api_servers = http://controller:9292

在该[oslo_concurrency]部分中,配置锁定路径:

[oslo_concurrency]

# ...

lock_path = /var/lib/cinder/tmp

完成安装

启动Block Storage卷服务(包括其依赖项)并将其配置为在系统引导时启动:

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

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

 

 

 

安装和配置控制器节点

 

本节介绍如何在控制器节点上安装和配置代号为cinder的块存储服务。此服务至少需要一个为实例提供卷的附加存储节点。

 

先决条件

在安装和配置Block Storage服务之前,必须创建数据库,服务凭据和API端点。

 

要创建数据库,请完成以下步骤:

 

使用数据库访问客户端以root用户身份连接到数据库服务器:

$ mysql -u root -p

创建cinder数据库:

MariaDB [(none)]> CREATE DATABASE cinder;

授予对cinder数据库的适当访问权限:

MariaDB [(none)]> GRANT ALL PRIVILEGES ON cinder.* TO 'cinder'@'localhost' \

  IDENTIFIED BY 'CINDER_DBPASS';

MariaDB [(none)]> GRANT ALL PRIVILEGES ON cinder.* TO 'cinder'@'%' \

  IDENTIFIED BY 'CINDER_DBPASS';

替换CINDER_DBPASS为合适的密码。

 

退出数据库访问客户端。

 

来源admin凭据来访问仅管理员CLI命令:

$ . admin-openrc

要创建服务凭据,请完成以下步骤:

 

创建cinder用户:

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

 

User Password:

Repeat User Password:

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

| Field               | Value                            |

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

| domain_id           | default                          |

| enabled             | True                             |

| id                  | 9d7e33de3e1a498390353819bc7d245d |

| name                | cinder                           |

| options             | {}                               |

| password_expires_at | None                             |

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

Add the admin role to the cinder user:

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

注意

 

此命令不提供输出。

 

创建cinderv2和cinderv3服务实体:

 

$ openstack service create --name cinderv2 \

  --description "OpenStack Block Storage" volumev2

 

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

| Field       | Value                            |

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

| description | OpenStack Block Storage          |

| enabled     | True                             |

| id          | eb9fd245bdbc414695952e93f29fe3ac |

| name        | cinderv2                         |

| type        | volumev2                         |

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

 $ openstack service create --name cinderv3 \

  --description "OpenStack Block Storage" volumev3

 

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

| Field       | Value                            |

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

| description | OpenStack Block Storage          |

| enabled     | True                             |

| id          | ab3bbbef780845a1a283490d281e7fda |

| name        | cinderv3                         |

| type        | volumev3                         |

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

创建Block Storage服务API端点:

$ openstack endpoint create --region RegionOne \

  volumev2 public http://controller:8776/v2/%\(project_id\)s

 

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

| Field        | Value                                    |

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

| enabled      | True                                     |

| id           | 513e73819e14460fb904163f41ef3759         |

| interface    | public                                   |

| region       | RegionOne                                |

| region_id    | RegionOne                                |

| service_id   | eb9fd245bdbc414695952e93f29fe3ac         |

| service_name | cinderv2                                 |

| service_type | volumev2                                 |

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

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

 

$ openstack endpoint create --region RegionOne \

  volumev2 internal http://controller:8776/v2/%\(project_id\)s

 

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

| Field        | Value                                    |

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

| enabled      | True                                     |

| id           | 6436a8a23d014cfdb69c586eff146a32         |

| interface    | internal                                 |

| region       | RegionOne                                |

| region_id    | RegionOne                                |

| service_id   | eb9fd245bdbc414695952e93f29fe3ac         |

| service_name | cinderv2                                 |

| service_type | volumev2                                 |

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

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

 

$ openstack endpoint create --region RegionOne \

  volumev2 admin http://controller:8776/v2/%\(project_id\)s

 

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

| Field        | Value                                    |

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

| enabled      | True                                     |

| id           | e652cf84dd334f359ae9b045a2c91d96         |

| interface    | admin                                    |

| region       | RegionOne                                |

| region_id    | RegionOne                                |

| service_id   | eb9fd245bdbc414695952e93f29fe3ac         |

| service_name | cinderv2                                 |

| service_type | volumev2                                 |

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

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

$ openstack endpoint create --region RegionOne \

  volumev3 public http://controller:8776/v3/%\(project_id\)s

 

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

| Field        | Value                                    |

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

| enabled      | True                                     |

| id           | 03fa2c90153546c295bf30ca86b1344b         |

| interface    | public                                   |

| region       | RegionOne                                |

| region_id    | RegionOne                                |

| service_id   | ab3bbbef780845a1a283490d281e7fda         |

| service_name | cinderv3                                 |

| service_type | volumev3                                 |

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

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

 

$ openstack endpoint create --region RegionOne \

  volumev3 internal http://controller:8776/v3/%\(project_id\)s

 

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

| Field        | Value                                    |

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

| enabled      | True                                     |

| id           | 94f684395d1b41068c70e4ecb11364b2         |

| interface    | internal                                 |

| region       | RegionOne                                |

| region_id    | RegionOne                                |

| service_id   | ab3bbbef780845a1a283490d281e7fda         |

| service_name | cinderv3                                 |

| service_type | volumev3                                 |

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

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

 

$ openstack endpoint create --region RegionOne \

  volumev3 admin http://controller:8776/v3/%\(project_id\)s

 

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

| Field        | Value                                    |

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

| enabled      | True                                     |

| id           | 4511c28a0f9840c78bacb25f10f62c98         |

| interface    | admin                                    |

| region       | RegionOne                                |

| region_id    | RegionOne                                |

| service_id   | ab3bbbef780845a1a283490d281e7fda         |

| service_name | cinderv3                                 |

| service_type | volumev3                                 |

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

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

注意

 

块存储服务需要每个服务实体的端点。

 

安装和配置组件

安装包:

# yum install openstack-cinder

编辑/etc/cinder/cinder.conf文件并完成以下操作:

 

在该[database]部分中,配置数据库访问:

[database]

# ...

connection = mysql+pymysql://cinder:CINDER_DBPASS@controller/cinder

替换CINDER_DBPASS为您为Block Storage数据库选择的密码。

 

在该[DEFAULT]部分中,配置RabbitMQ 消息队列访问:

[DEFAULT]

# ...

transport_url = rabbit://openstack:RABBIT_PASS@controller

替换RABBIT_PASS为您为openstack帐户选择的密码 RabbitMQ。

 

在[DEFAULT]和[keystone_authtoken]部分中,配置身份服务访问:

[DEFAULT]

# ...

auth_strategy = keystone

 

[keystone_authtoken]

# ...

auth_uri = http://controller:5000

auth_url = http://controller:5000

memcached_servers = controller:11211

auth_type = password

project_domain_id = default

user_domain_id = default

project_name = service

username = cinder

password = CINDER_PASS

替换CINDER_PASS为您cinder在Identity服务中为用户选择的密码。

 

 注意

 

注释掉或删除该[keystone_authtoken]部分中的任何其他选项 。

在该[DEFAULT]部分中,配置my_ip选项以使用控制器节点的管理接口IP地址:

[DEFAULT]

# ...

my_ip = 10.0.0.11

在该[oslo_concurrency]部分中,配置锁定路径:

[oslo_concurrency]

# ...

lock_path = /var/lib/cinder/tmp

填充块存储数据库:

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

注意

 

忽略此输出中的任何弃用消息。

 

配置计算以使用块存储

编辑/etc/nova/nova.conf文件并将以下内容添加到其中:

[cinder]

os_region_name = RegionOne

完成安装

重新启动Compute API服务

# systemctl restart openstack-nova-api.service

启动Block Storage服务并将其配置为在系统引导时启动:

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

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

 

验证Cinder操作

 

验证块存储服务的操作。

 

 注意

 

在控制器节点上执行这些命令。

 

来源admin凭据来访问仅管理员CLI命令:

$ . admin-openrc

列出服务组件以验证每个进程的成功启动:

$ openstack volume service list

 

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

| Binary           | Host       | Zone | Status  | State | Updated_at                 |

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

| cinder-scheduler | controller | nova | enabled | up    | 2016-09-30T02:27:41.000000 |

| cinder-volume    | block@lvm  | nova | enabled | up    | 2016-09-30T02:27:46.000000 |

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

(contrller@LVM节点down没关系。)

Openstack Queens版本双节点架构笔记1,虚拟机环境安装: https://blog.csdn.net/qq_38387984/article/details/83245908 

Openstack Queens版本双节点架构笔记2,Openstack环境安装: https://blog.csdn.net/qq_38387984/article/details/83245941

Openstack Queens版本双节点架构笔记3,Keystone安装:https://blog.csdn.net/qq_38387984/article/details/83274421

Openstack Queens版本双节点架构笔记4,Glance安装:https://blog.csdn.net/qq_38387984/article/details/83274547

Openstack Queens版本双节点架构笔记5,Nova安装:https://blog.csdn.net/qq_38387984/article/details/83274567

Openstack Queens版本双节点架构笔记6,Neutron安装:https://blog.csdn.net/qq_38387984/article/details/83274578

Openstack Queens版本双节点架构笔记7,Dashboard安装:https://blog.csdn.net/qq_38387984/article/details/83274601

Openstack Queens版本双节点架构笔记8,验证Databoard实例 https://blog.csdn.net/qq_38387984/article/details/83502979

Openstack Queens版本双节点架构笔记9,Ceph安装1:https://blog.csdn.net/qq_38387984/article/details/83502996

Openstack Queens版本双节点架构笔记10,Ceph安装2:https://blog.csdn.net/qq_38387984/article/details/83503016

Openstack Queens版本双节点架构笔记11,Ceph安装3:https://blog.csdn.net/qq_38387984/article/details/83503033

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值