Ubuntu 20.04
Sponsored Link

OpenStack Victoria : Use Cinder Storage (LVM)
2020/10/20
 
It's possible to use Virtual Storages provided by Cinder if an Instance needs more disks.
Configure Virtual storage with LVM backend on here.
It needs there are some free spaces on disks of Storage Node.
------------+---------------------------+---------------------------+------------
            |                           |                           |
        eth0|10.0.0.30              eth0|10.0.0.50              eth0|10.0.0.51
+-----------+-----------+   +-----------+-----------+   +-----------+-----------+
|    [ Control Node ]   |   |    [ Network Node ]   |   |    [ Compute Node ]   |
|                       |   |                       |   |                       |
|  MariaDB    RabbitMQ  |   |        L2 Agent       |   |        Libvirt        |
|  Memcached  httpd     |   |        L3 Agent       |   |     Nova Compute      |
|  Keystone   Glance    |   |     Metadata Agent    |   |        L2 Agent       |
|  Nova API             |   |     Cinder Volume     |   |                       |
|  Neutron Server       |   |                       |   |                       |
|  Metadata Agent       |   |                       |   |                       |
|  Cinder API           |   |                       |   |                       |
+-----------------------+   +-----------------------+   +-----------------------+

[1] Create a volume group for Cinder on Storage Node.
root@storage:~#
pvcreate /dev/sdb1

Physical volume "/dev/sdb1" successfully created
root@storage:~#
vgcreate -s 32M vg_volume01 /dev/sdb1

Volume group "vg_volume01" successfully created
[2] Configure Cinder Volume on Storage Node.
root@storage:~#
apt -y install tgt thin-provisioning-tools
root@storage:~#
vi /etc/cinder/cinder.conf
# add the value to [enabled_backends] param

enabled_backends =
lvm
# add to the end

[lvm]
target_helper = tgtadm
target_protocol = iscsi
# IP address of Storage Node
target_ip_address = 10.0.0.50
# volume group name created on [1]
volume_group = vg_volume01
volume_driver = cinder.volume.drivers.lvm.LVMVolumeDriver
volumes_dir = $state_path/volumes

root@storage:~#
systemctl restart cinder-volume tgt
[3] Configure Nova on Compute Node.
root@node01:~#
vi /etc/nova/nova.conf
# add to the end

[cinder]
os_region_name = RegionOne
root@node01:~#
systemctl restart nova-compute
[4] Login as a common user you'd like to add volumes to own instances.
For example, create a virtual disk [disk01] with 10GB.
It's OK to work on any node. (example below is on Control Node)
# set environment variable

ubuntu@dlp ~(keystone)$
echo "export OS_VOLUME_API_VERSION=3" >> ~/keystonerc

ubuntu@dlp ~(keystone)$
source ~/keystonerc
ubuntu@dlp ~(keystone)$
openstack volume create --size 10 disk01

+---------------------+--------------------------------------+
| Field               | Value                                |
+---------------------+--------------------------------------+
| attachments         | []                                   |
| availability_zone   | nova                                 |
| bootable            | false                                |
| consistencygroup_id | None                                 |
| created_at          | 2020-10-20T05:10:06.000000           |
| description         | None                                 |
| encrypted           | False                                |
| id                  | 7886f57b-da0a-4bbd-817b-bd8ff70ff1b5 |
| 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             | a13cfae0e5eb466fae71a636a6ffb6b4     |
+---------------------+--------------------------------------+

ubuntu@dlp ~(keystone)$
openstack volume list

+--------------------------------------+--------+-----------+------+-------------+
| ID                                   | Name   | Status    | Size | Attached to |
+--------------------------------------+--------+-----------+------+-------------+
| 7886f57b-da0a-4bbd-817b-bd8ff70ff1b5 | disk01 | available |   10 |             |
+--------------------------------------+--------+-----------+------+-------------+
[5] Attach the virtual disk to an Instance.
For the exmaple below, the disk is connected as [/dev/vdb]. It's possible to use it as a storage to create a file system on it.
ubuntu@dlp ~(keystone)$
openstack server list

+--------------------------------------+-------------+---------+-------------------------------------+------------+----------+
| ID                                   | Name        | Status  | Networks                            | Image      | Flavor   |
+--------------------------------------+-------------+---------+-------------------------------------+------------+----------+
| 10abf4e3-d5d9-4b57-a5a0-7cb767442dcc | Ubuntu_2004 | SHUTOFF | private=192.168.100.188, 10.0.0.236 | Ubuntu2004 | m1.small |
+--------------------------------------+-------------+---------+-------------------------------------+------------+----------+

ubuntu@dlp ~(keystone)$
openstack server add volume Ubuntu_2004 disk01
# the status of attached disk turns [in-use] like follows

ubuntu@dlp ~(keystone)$
openstack volume list

+--------------------------------------+--------+--------+------+--------------------------------------+
| ID                                   | Name   | Status | Size | Attached to                          |
+--------------------------------------+--------+--------+------+--------------------------------------+
| 7886f57b-da0a-4bbd-817b-bd8ff70ff1b5 | disk01 | in-use |   10 | Attached to Ubuntu_2004 on /dev/vdb  |
+--------------------------------------+--------+--------+------+--------------------------------------+

# detach the disk

ubuntu@dlp ~(keystone)$
openstack server remove volume Ubuntu_2004 disk01

Matched Content