2d2367fa22
updated config option docs, and general copy-editing. Change-Id: I05cc3807ecc741c476ffd8883fe2aded95afe580 Partial-Bug: 1255215
205 lines
9.5 KiB
XML
205 lines
9.5 KiB
XML
<section xml:id="xensm" xmlns="http://docbook.org/ns/docbook"
|
|
xmlns:xi="http://www.w3.org/2001/XInclude"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink" version="5.0">
|
|
<title>XenAPI Storage Manager volume driver</title>
|
|
<para>The Xen Storage Manager volume driver (xensm) is a XenAPI
|
|
hypervisor specific volume driver, and can be used to provide
|
|
basic storage functionality, including volume creation and
|
|
destruction, on a number of different storage back-ends. It
|
|
also enables the capability of using more sophisticated
|
|
storage back-ends for operations like cloning/snapshots, etc.
|
|
The list below shows some of the storage plug-ins already
|
|
supported in Citrix XenServer and Xen Cloud Platform
|
|
(XCP):</para>
|
|
<orderedlist>
|
|
<listitem>
|
|
<para>NFS VHD: Storage repository (SR) plug-in that
|
|
stores disks as Virtual Hard Disk (VHD) files on a
|
|
remote Network File System (NFS).</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Local VHD on LVM: SR plug-in tjat represents disks
|
|
as VHD disks on Logical Volumes (LVM) within a
|
|
locally-attached Volume Group.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>HBA LUN-per-VDI driver: SR plug-in that represents
|
|
Logical Units (LUs) as Virtual Disk Images (VDIs)
|
|
sourced by host bus adapters (HBAs). For example,
|
|
hardware-based iSCSI or FC support.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>NetApp: SR driver for mapping of LUNs to VDIs on a
|
|
NETAPP server, providing use of fast snapshot and
|
|
clone features on the filer.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>LVHD over FC: SR plug-in that represents disks as
|
|
VHDs on Logical Volumes within a Volume Group created
|
|
on an HBA LUN. For example, hardware-based iSCSI or FC
|
|
support.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>iSCSI: Base ISCSI SR driver, provides a LUN-per-VDI.
|
|
Does not support creation of VDIs but accesses
|
|
existing LUNs on a target.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>LVHD over iSCSI: SR plug-in that represents disks
|
|
as Logical Volumes within a Volume Group created on an
|
|
iSCSI LUN.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>EqualLogic: SR driver for mapping of LUNs to VDIs on
|
|
a EQUALLOGIC array group, providing use of fast
|
|
snapshot and clone features on the array.</para>
|
|
</listitem>
|
|
</orderedlist>
|
|
<section xml:id="xensmdesign">
|
|
<title>Design and operation</title>
|
|
<simplesect>
|
|
<title>Definitions</title>
|
|
<itemizedlist>
|
|
<listitem>
|
|
<para><emphasis role="bold">Back-end:</emphasis> A
|
|
term for a particular storage back-end. This
|
|
could be iSCSI, NFS, NetApp etc.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para><emphasis role="bold"
|
|
>Back-end-config:</emphasis> All the
|
|
parameters required to connect to a specific
|
|
back-end. For example, for NFS, this would be
|
|
the server, path, and so on.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para><emphasis role="bold">Flavor:</emphasis>
|
|
This term is equivalent to volume "types". A
|
|
user friendly term to specify some notion of
|
|
quality of service. For example, "gold" might
|
|
mean that the volumes use a back-end where
|
|
backups are possible. A flavor can be
|
|
associated with multiple back-ends. The volume
|
|
scheduler, with the help of the driver,
|
|
decides which back-end is used to create a
|
|
volume of a particular flavor. Currently, the
|
|
driver uses a simple "first-fit" policy, where
|
|
the first back-end that can successfully create
|
|
this volume is the one that is used.</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</simplesect>
|
|
<simplesect>
|
|
<title>Operation</title>
|
|
<para>The admin uses the nova-manage command detailed
|
|
below to add flavors and back-ends.</para>
|
|
<para>One or more <systemitem class="service"
|
|
>cinder-volume</systemitem> service instances are
|
|
deployed for each availability zone. When an instance
|
|
is started, it creates storage repositories (SRs) to
|
|
connect to the back-ends available within that zone.
|
|
All <systemitem class="service"
|
|
>cinder-volume</systemitem> instances within a
|
|
zone can see all the available back-ends. These
|
|
instances are completely symmetric and hence should be
|
|
able to service any <literal>create_volume</literal>
|
|
request within the zone.</para>
|
|
<note>
|
|
<title>On XenServer, PV guests required</title>
|
|
<para>Note that when using XenServer you can only
|
|
attach a volume to a PV guest.</para>
|
|
</note>
|
|
</simplesect>
|
|
</section>
|
|
<section xml:id="xensmconfig">
|
|
<title>Configure XenAPI Storage Manager</title>
|
|
<simplesect>
|
|
<title>Prerequisites</title>
|
|
<orderedlist>
|
|
<listitem>
|
|
<para>xensm requires that you use either Citrix
|
|
XenServer or XCP as the hypervisor. The NetApp
|
|
and EqualLogic back-ends are not supported on
|
|
XCP.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Ensure all <emphasis role="bold"
|
|
>hosts</emphasis> running volume and
|
|
compute services have connectivity to the
|
|
storage system.</para>
|
|
</listitem>
|
|
</orderedlist>
|
|
</simplesect>
|
|
<simplesect>
|
|
<title>Configuration</title>
|
|
<itemizedlist>
|
|
<listitem>
|
|
<para>
|
|
<emphasis role="bold">Set the following
|
|
configuration options for the nova volume
|
|
service: (<systemitem class="service"
|
|
>nova-compute</systemitem> also
|
|
requires the volume_driver configuration
|
|
option.)</emphasis>
|
|
</para>
|
|
<programlisting>
|
|
--volume_driver="nova.volume.xensm.XenSMDriver"
|
|
--use_local_volumes=False
|
|
</programlisting>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
<emphasis role="bold">The back-end
|
|
configurations that the volume driver uses
|
|
need to be created before starting the
|
|
volume service.</emphasis>
|
|
</para>
|
|
<programlisting>
|
|
<prompt>$</prompt> nova-manage sm flavor_create <label> <description>
|
|
|
|
<prompt>$</prompt> nova-manage sm flavor_delete <label>
|
|
|
|
<prompt>$</prompt> nova-manage sm backend_add <flavor label> <SR type> [config connection parameters]
|
|
|
|
Note: SR type and config connection parameters are in keeping with the XenAPI Command Line Interface. http://support.citrix.com/article/CTX124887
|
|
|
|
<prompt>$</prompt> nova-manage sm backend_delete <back-end-id>
|
|
|
|
</programlisting>
|
|
<para>Example: For the NFS storage manager
|
|
plug-in, the steps below may be used.</para>
|
|
<programlisting>
|
|
<prompt>$</prompt> nova-manage sm flavor_create gold "Not all that glitters"
|
|
|
|
<prompt>$</prompt> nova-manage sm flavor_delete gold
|
|
|
|
<prompt>$</prompt> nova-manage sm backend_add gold nfs name_label=myback-end server=myserver serverpath=/local/scratch/myname
|
|
|
|
<prompt>$</prompt> nova-manage sm backend_remove 1
|
|
</programlisting>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
<emphasis role="bold">Start <systemitem
|
|
class="service"
|
|
>cinder-volume</systemitem> and
|
|
<systemitem class="service"
|
|
>nova-compute</systemitem> with the
|
|
new configuration options.</emphasis>
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</simplesect>
|
|
<simplesect>
|
|
<title>Create and access the volumes from VMs</title>
|
|
<para>Currently, the flavors have not been tied to the
|
|
volume types API. As a result, we simply end up
|
|
creating volumes in a "first fit" order on the given
|
|
back-ends.</para>
|
|
<para>The standard euca-* or OpenStack API commands (such
|
|
as volume extensions) should be used for creating,
|
|
destroying, attaching, or detaching volumes.</para>
|
|
</simplesect>
|
|
</section>
|
|
</section>
|