Update Cinder guide
Co-Authored-By: Serguei Bezverkhi <sbezverk@cisco.com> partially-implements: blueprint documentation-rework Depends-On: I2f709f8589fdbf62e3d0b265452fd58f413bee65 Change-Id: I19fe617b52b5b4a013f0a589ca21c0c932be4ad2
This commit is contained in:
parent
d87b4f63a2
commit
42d3e77e5a
@ -9,19 +9,19 @@ Overview
|
|||||||
|
|
||||||
Currently Kolla can deploy the cinder services:
|
Currently Kolla can deploy the cinder services:
|
||||||
|
|
||||||
- cinder-api
|
- cinder-api
|
||||||
- cinder-scheduler
|
- cinder-scheduler
|
||||||
- cinder-backup
|
- cinder-backup
|
||||||
- cinder-volume
|
- cinder-volume
|
||||||
|
|
||||||
The cinder implementation defaults to using LVM storage. The default
|
The cinder implementation defaults to using LVM storage. The default
|
||||||
implementation requires a volume group be set up. This can either be
|
implementation requires a volume group be set up. This can either be
|
||||||
a real physical volume or a loopback mounted file for development.
|
a real physical volume or a loopback mounted file for development.
|
||||||
|
|
||||||
Create a Volume Group
|
Create a Volume Group
|
||||||
=====================
|
=====================
|
||||||
Use pvcreate and vgcreate to create the volume group. For example with
|
Use ``pvcreate`` and ``vgcreate`` to create the volume group. For example
|
||||||
the devices /dev/sdb and /dev/sdc:
|
with the devices ``/dev/sdb`` and ``/dev/sdc``:
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
@ -30,11 +30,9 @@ the devices /dev/sdb and /dev/sdc:
|
|||||||
pvcreate /dev/sdb /dev/sdc
|
pvcreate /dev/sdb /dev/sdc
|
||||||
vgcreate cinder-volumes /dev/sdb /dev/sdc
|
vgcreate cinder-volumes /dev/sdb /dev/sdc
|
||||||
|
|
||||||
During development, it may be desirable to use file backed block storage. It
|
During development, it may be desirable to use file backed block storage. It
|
||||||
is possible to use a file and mount it as a block device via the loopback
|
is possible to use a file and mount it as a block device via the loopback
|
||||||
system.
|
system. ::
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
mknod /dev/loop2 b 7 2
|
mknod /dev/loop2 b 7 2
|
||||||
dd if=/dev/zero of=/var/lib/cinder_data.img bs=1G count=20
|
dd if=/dev/zero of=/var/lib/cinder_data.img bs=1G count=20
|
||||||
@ -49,13 +47,11 @@ Create a volume as follows:
|
|||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
$ openstack volume create --size 1 steak_volume
|
$ openstack volume create --size 1 steak_volume
|
||||||
<bunch of stuff printed>
|
<bunch of stuff printed>
|
||||||
|
|
||||||
Verify it is available. If it says "error" here something went wrong during
|
Verify it is available. If it says "error" here something went wrong during
|
||||||
LVM creation of the volume.
|
LVM creation of the volume. ::
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
$ openstack volume list
|
$ openstack volume list
|
||||||
+--------------------------------------+--------------+-----------+------+-------------+
|
+--------------------------------------+--------------+-----------+------+-------------+
|
||||||
@ -76,7 +72,7 @@ Check the console log added the disk:
|
|||||||
|
|
||||||
openstack console log show steak_server
|
openstack console log show steak_server
|
||||||
|
|
||||||
A /dev/vdb should appear in the console log, at least when booting cirros.
|
A ``/dev/vdb`` should appear in the console log, at least when booting cirros.
|
||||||
If the disk stays in the available state, something went wrong during the
|
If the disk stays in the available state, something went wrong during the
|
||||||
iSCSI mounting of the volume to the guest VM.
|
iSCSI mounting of the volume to the guest VM.
|
||||||
|
|
||||||
@ -84,52 +80,34 @@ Cinder LVM2 backend with iSCSI
|
|||||||
==============================
|
==============================
|
||||||
|
|
||||||
As of Newton-1 milestone, Kolla supports LVM2 as cinder backend. It is
|
As of Newton-1 milestone, Kolla supports LVM2 as cinder backend. It is
|
||||||
accomplished by introducing two new containers tgtd and iscsid.
|
accomplished by introducing two new containers ``tgtd`` and ``iscsid``.
|
||||||
tgtd container serves as a bridge between cinder-volume process and a server
|
tgtd container serves as a bridge between cinder-volume process and a server
|
||||||
hosting Logical Volume Groups (LVG). iscsid container serves as a bridge
|
hosting Logical Volume Groups (LVG). ``iscsid`` container serves as a bridge
|
||||||
between nova-compute process and the server hosting LVG.
|
between nova-compute process and the server hosting LVG.
|
||||||
|
|
||||||
There are two methods to apply new configuration to cinder:
|
In order to use iSCSI as a Cinder's backend, these two parameters must be
|
||||||
- New deployments: create cinder.conf and place it at /etc/kolla/config
|
specified in ``globals.yml``. ::
|
||||||
folder, then add below configuration lines and run kolla deloyment.
|
|
||||||
- Existing cinder deployments: modify cinder.conf located at /etc/kolla/config
|
|
||||||
by adding below configuration lines and run kolla reconfigure.
|
|
||||||
|
|
||||||
::
|
cinder_iscsi_ip_address: "X.X.X.X"
|
||||||
|
cinder_volume_group: << lvg_name >>
|
||||||
|
|
||||||
[DEFAULT]
|
|
||||||
enabled_backends = {local_lvm_name}
|
|
||||||
volume_name_template=volume-%s
|
|
||||||
|
|
||||||
[{local_lvm_name}]
|
|
||||||
lvm_type = default
|
|
||||||
volume_group = {lvg_name}
|
|
||||||
volume_driver = cinder.volume.drivers.lvm.LVMVolumeDriver
|
|
||||||
volume_backend_name = {local_lvm_name}
|
|
||||||
iscsi_helper=tgtadm
|
|
||||||
iscsi_ip_address={management_ip_address_of_server_hosting_LVG}
|
|
||||||
iscsi_protocol=iscsi
|
|
||||||
::
|
|
||||||
|
|
||||||
Where:
|
Where:
|
||||||
|
|
||||||
- local_lvm_name is a name chosen by a user for a spefic LVM2 backend, multiple
|
- X.X.X.X - is IP address of a server hosting LVG
|
||||||
LVM2 backend can be confiugred and each should have a unique name.
|
- ``lvg_name`` - is a name of LVG on that server.
|
||||||
- lvg_name is a name Logical Volume Group created for cinder to store volumes.
|
|
||||||
- management_ip_address_of_server_hosting_LVG is IP address of an interface
|
|
||||||
where cinder process is bound to. (Do not use VIP address here, LVG does not
|
|
||||||
move from server to server as VIP address does in case of a server failure).
|
|
||||||
|
|
||||||
NOTE: For Ubuntu and LVM2/iSCSI
|
NOTE: For Ubuntu and LVM2/iSCSI
|
||||||
|
|
||||||
iscsd process uses configfs which is normally mounted at /sys/kernel/config to
|
``iscsd`` process uses configfs which is normally mounted at
|
||||||
store discovered targets information, on centos/rhel type of systems this special
|
``/sys/kernel/config`` to store discovered targets information, on centos/rhel
|
||||||
file system gets mounted automatically, which is not the case on debian/ubuntu.
|
type of systems this special file system gets mounted automatically, which is
|
||||||
Since iscsid container runs on every nova compute node, the following steps must
|
not the case on debian/ubuntu. Since ``iscsid`` container runs on every nova
|
||||||
be completed on every Ubuntu server targeted for nova compute role.
|
compute node, the following steps must be completed on every Ubuntu server
|
||||||
|
targeted for nova compute role.
|
||||||
|
|
||||||
- Add configfs module to /etc/modules
|
- Add configfs module to ``/etc/modules``
|
||||||
- Rebuild initramfs using: "update-initramfs -u" command
|
- Rebuild initramfs using: ``update-initramfs -u`` command
|
||||||
- Make sure configfs gets mounted during a server boot up process. There are
|
- Make sure configfs gets mounted during a server boot up process. There are
|
||||||
multiple ways to accomplish it, one example is adding this command to
|
multiple ways to accomplish it, one example is adding this command to
|
||||||
"mount -t configfs configfs /sys/kernel/config" to /etc/rc.local
|
"mount -t configfs configfs ``/sys/kernel/config`` to ``/etc/rc.local``
|
||||||
|
Loading…
Reference in New Issue
Block a user