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:
Swapnil Kulkarni (coolsvap) 2016-05-17 08:09:57 +05:30
parent d87b4f63a2
commit 42d3e77e5a

View File

@ -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``