OpenStack Caracal : Cinder ストレージを利用 (LVM)2024/08/07 |
仮想マシンインスタンスには一定容量のディスクは割り当てられていますが、 ディスクが足りなくなった場合やデータは別で保管しておきたい場合等は、 Cinder が提供するブロックストレージ機能を利用することができます。
当例ではバックエンドとして LVM を利用した仮想ストレージを設定します。 ------------+--------------------------+--------------------------+------------ | | | eth0|10.0.0.30 eth0|10.0.0.50 eth0|10.0.0.51 +-----------+-----------+ +-----------+-----------+ +-----------+-----------+ | [ dlp.srv.world ] | | [ network.srv.world ] | | [ node01.srv.world ] | | (Control Node) | | (Network Node) | | (Compute Node) | | | | | | | | MariaDB RabbitMQ | | Open vSwitch | | Libvirt | | Memcached Nginx | | Neutron Server | | Nova Compute | | Keystone httpd | | OVN-Northd | | Open vSwitch | | Glance Nova API | | Nginx iSCSI Target | | OVN Metadata Agent | | Cinder API | | Cinder Volume | | OVN-Controller | +-----------------------+ +-----------------------+ +-----------------------+ |
[1] | Cinder が利用するボリュームグループを、Storage ノード上のディスクの空き領域に作成しておきます。 |
[root@network ~]# pvcreate /dev/sdb1 Physical volume "/dev/sdb1" successfully created [root@network ~]# vgcreate -s 32M vg_volume01 /dev/sdb1 Volume group "vg_volume01" successfully created |
[2] | Storage ノード上の Cinder Volume の設定です。 |
[root@network ~]#
vi /etc/cinder/cinder.conf # [DEFAULT] セクション内の任意の場所へ追記 enabled_backends = lvm # 最終行へ追記 [lvm] target_helper = lioadm target_protocol = iscsi target_ip_address = $my_ip # 作成したボリュームグループ名 volume_group = vg_volume01 volume_driver = cinder.volume.drivers.lvm.LVMVolumeDriver volumes_dir = $state_path/volumes systemctl restart openstack-cinder-volume |
[3] | Storage ノードで Firewalld を有効にしている場合は、サービスの許可が必要です。 |
[root@network ~]# firewall-cmd --add-service=iscsi-target success [root@network ~]# firewall-cmd --runtime-to-permanent success |
[4] | Compute ノードの Nova の設定です。 |
[root@node01 ~]#
vi /etc/nova/nova.conf # [keystone_authtoken] セクションへ追記 [keystone_authtoken] ..... ..... service_token_roles = service service_token_roles_required = true # 最終行へ追記 [service_user] send_service_user_token = true auth_url = https://dlp.srv.world:5000 auth_type = password project_domain_name = Default user_domain_name = Default project_name = service username = nova password = servicepassword insecure = false [cinder] os_region_name = RegionOne
[root@node01 ~]#
systemctl restart openstack-nova-compute
# SELinux 有効の場合はポリシーの変更も必要
[root@node01 ~]#
vi iscsiadm.te # 以下の内容で新規作成 module iscsiadm 1.0; require { type iscsid_t; class capability dac_override; } #============= iscsid_t ============== allow iscsid_t self:capability dac_override; checkmodule -m -M -o iscsiadm.mod iscsiadm.te [root@node01 ~]# semodule_package --outfile iscsiadm.pp --module iscsiadm.mod [root@node01 ~]# semodule -i iscsiadm.pp |
[5] | インスタンスにボリュームを追加したい任意のユーザーで作業します。 例として [disk01] という名称のボリュームを [10GB] で作成します。作業場所はどこでもよいですが、当例では Control ノード上で行います。 |
# 事前に環境変数を設定 [cent@dlp ~(keystone)]$ echo "export OS_VOLUME_API_VERSION=3" >> ~/keystonerc [cent@dlp ~(keystone)]$ source ~/keystonerc
openstack volume create --size 10 disk01 +---------------------+--------------------------------------+ | Field | Value | +---------------------+--------------------------------------+ | attachments | [] | | availability_zone | nova | | bootable | false | | consistencygroup_id | None | | created_at | 2024-08-07T01:22:28.718832 | | description | None | | encrypted | False | | id | efcd48f8-51ca-41a2-8544-e04e5aa1c64d | | multiattach | False | | name | disk01 | | properties | | | replication_status | None | | size | 10 | | snapshot_id | None | | source_volid | None | | status | creating | | type | __DEFAULT__ | | updated_at | None | | user_id | 8a9b46168b42480f889ad4fad3ca6ee4 | +---------------------+--------------------------------------+[cent@dlp ~(keystone)]$ openstack volume list +--------------------------------------+--------+-----------+------+-------------+ | ID | Name | Status | Size | Attached to | +--------------------------------------+--------+-----------+------+-------------+ | efcd48f8-51ca-41a2-8544-e04e5aa1c64d | disk01 | available | 10 | | +--------------------------------------+--------+-----------+------+-------------+ |
[6] | 作成した仮想ディスクをインスタンスに接続します。 以下の例では [/dev/vdb] というデバイスとしてインスタンスに接続されました。 以上でインスタンス上から [/dev/vdb] にファイルシステムを作成して、ストレージとして利用することができます。 |
[cent@dlp ~(keystone)]$ openstack server list +--------------------------------------+------------+---------+------------------------------------+----------------+----------+ | ID | Name | Status | Networks | Image | Flavor | +--------------------------------------+------------+---------+------------------------------------+----------------+----------+ | 1d0c2140-098d-4a1a-a705-82d7755d7c84 | CentOS-St9 | SHUTOFF | private=10.0.0.250, 192.168.100.65 | CentOS-Stream9 | m1.small | +--------------------------------------+------------+---------+------------------------------------+----------------+----------+[cent@dlp ~(keystone)]$ openstack server add volume CentOS-St9 disk01 +-----------------------+--------------------------------------+ | Field | Value | +-----------------------+--------------------------------------+ | ID | efcd48f8-51ca-41a2-8544-e04e5aa1c64d | | Server ID | 1d0c2140-098d-4a1a-a705-82d7755d7c84 | | Volume ID | efcd48f8-51ca-41a2-8544-e04e5aa1c64d | | Device | /dev/vdb | | Tag | None | | Delete On Termination | False | +-----------------------+--------------------------------------+ # 接続された仮想ディスクは [in-use] ステータスになる [cent@dlp ~(keystone)]$ openstack volume list +--------------------------------------+--------+--------+------+-------------------------------------+ | ID | Name | Status | Size | Attached to | +--------------------------------------+--------+--------+------+-------------------------------------+ | efcd48f8-51ca-41a2-8544-e04e5aa1c64d | disk01 | in-use | 10 | Attached to CentOS-St9 on /dev/vdb | +--------------------------------------+--------+--------+------+-------------------------------------+ # 接続した仮想ディスクを接続解除する場合は以下 [cent@dlp ~(keystone)]$ openstack server remove volume CentOS-St9 disk01 |
Sponsored Link |
|