openstack-manuals/doc/config-reference/block-storage/drivers/vmware-vmdk-driver.xml
Matt Dorn 3ffbe45d68 Added vCenter version for storage policies
In the config reference guide, specified that storage policies are
supported in vCenter 5.5 and above.

Change-Id: I3d734928647026c66324a816a9a910336e724cbb
Close-Bug: #1499346
2015-09-24 20:06:24 +00:00

436 lines
20 KiB
XML

<?xml version="1.0" encoding="UTF-8"?>
<section xml:id="vmware-vmdk-driver"
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>VMware VMDK driver</title>
<?dbhtml stop-chunking?>
<para>Use the VMware VMDK driver to enable management of the
OpenStack Block Storage volumes on vCenter-managed data
stores. Volumes are backed by VMDK files on data stores that
use any VMware-compatible storage technology such as NFS,
iSCSI, FiberChannel, and vSAN.</para>
<warning>
<para>The VMware ESX VMDK driver is deprecated as of the
Icehouse release and might be removed in Juno or a
subsequent release. The VMware vCenter VMDK driver
continues to be fully supported.</para>
</warning>
<section xml:id="vmdk_functional_context">
<title>Functional context</title>
<para>The VMware VMDK driver connects to vCenter, through
which it can dynamically access all the data stores
visible from the ESX hosts in the managed cluster.</para>
<para>When you create a volume, the VMDK driver creates a VMDK
file on demand. The VMDK file creation completes only when
the volume is subsequently attached to an instance. The
reason for this requirement is that data stores visible
to the instance determine where to place
the volume. Before the service creates the VMDK file,
attach a volume to the target instance.</para>
<para>The running vSphere VM is automatically reconfigured to
attach the VMDK file as an extra disk. Once attached, you
can log in to the running vSphere VM to rescan and
discover this extra disk.</para>
<para>With the update to ESX version 6.0, the VMDK driver
now supports NFS version 4.1.</para>
</section>
<section xml:id="vmdk_configuration">
<title>Configuration</title>
<para>The recommended volume driver for OpenStack Block
Storage is the VMware vCenter VMDK driver. When you
configure the driver, you must match it with the
appropriate OpenStack Compute driver from VMware and both
drivers must point to the same server.</para>
<para>In the <filename>nova.conf</filename> file, use this
option to define the Compute driver:</para>
<programlisting>compute_driver=vmwareapi.VMwareVCDriver</programlisting>
<para>In the <filename>cinder.conf</filename> file, use this
option to define the volume driver:</para>
<programlisting>volume_driver=cinder.volume.drivers.vmware.vmdk.VMwareVcVmdkDriver</programlisting>
<para>The following table lists various options that the
drivers support for the OpenStack Block Storage
configuration (<filename>cinder.conf</filename>):</para>
<xi:include href="../../../common/tables/cinder-vmware.xml"/>
</section>
<section xml:id="vmdk_disk_type">
<title>VMDK disk type</title>
<para>The VMware VMDK drivers support the creation of VMDK disk file
types <literal>thin</literal>, <literal>lazyZeroedThick</literal>
(sometimes called thick or flat), or <literal>eagerZeroedThick</literal>.
</para>
<para>
A thin virtual disk is allocated and zeroed on demand as the space
is used. Unused space on a Thin disk is available to other users.
</para>
<para>
A lazy zeroed thick virtual disk will have all space allocated at
disk creation. This reserves the entire disk space, so it is not
available to other users at any time.
</para>
<para>
An eager zeroed thick virtual disk is similar to a lazy zeroed thick
disk, in that the entire disk is allocated at creation. However, in
this type, any previous data will be wiped clean on the disk before
the write. This can mean that the disk will take longer to create,
but can also prevent issues with stale data on physical media.
</para>
<para>
Use the <literal>vmware:vmdk_type</literal> extra spec key with the
appropriate value to specify the VMDK disk file type. This table
shows the mapping between the extra spec entry and the VMDK disk
file type:</para>
<table rules="all">
<caption>Extra spec entry to VMDK disk file type
mapping</caption>
<thead>
<tr>
<td>Disk file type</td>
<td>Extra spec key</td>
<td>Extra spec value</td>
</tr>
</thead>
<tbody>
<tr>
<td>thin</td>
<td>vmware:vmdk_type</td>
<td>thin</td>
</tr>
<tr>
<td>lazyZeroedThick</td>
<td>vmware:vmdk_type</td>
<td>thick</td>
</tr>
<tr>
<td>eagerZeroedThick</td>
<td>vmware:vmdk_type</td>
<td>eagerZeroedThick</td>
</tr>
</tbody>
</table>
<para>If you do not specify a <code>vmdk_type</code> extra spec entry,
the disk file type will default to <literal>thin</literal>.</para>
<para>The following example shows how to create a
<code>lazyZeroedThick</code> VMDK volume by using the
appropriate <code>vmdk_type</code>:</para>
<screen><prompt>$</prompt> <userinput>cinder type-create thick_volume</userinput>
<prompt>$</prompt> <userinput>cinder type-key thick_volume set vmware:vmdk_type=thick</userinput>
<prompt>$</prompt> <userinput>cinder create --volume-type thick_volume --display-name volume1 1</userinput></screen>
</section>
<section xml:id="vmdk_clone_type">
<title>Clone type</title>
<para>With the VMware VMDK drivers, you can create a volume
from another source volume or a snapshot point. The VMware
vCenter VMDK driver supports the <literal>full</literal>
and <literal>linked/fast</literal> clone types. Use the
<code>vmware:clone_type</code> extra spec key to
specify the clone type. The following table captures the
mapping for clone types:</para>
<table rules="all">
<caption>Extra spec entry to clone type mapping</caption>
<thead>
<tr>
<td>Clone type</td>
<td>Extra spec key</td>
<td>Extra spec value</td>
</tr>
</thead>
<tbody>
<tr>
<td>full</td>
<td>vmware:clone_type</td>
<td>full</td>
</tr>
<tr>
<td>linked/fast</td>
<td>vmware:clone_type</td>
<td>linked</td>
</tr>
</tbody>
</table>
<para>If you do not specify the clone type, the default is
<literal>full</literal>.</para>
<para>The following example shows linked cloning from a
source volume, which is created from an image:</para>
<screen><prompt>$</prompt> <userinput>cinder type-create fast_clone</userinput>
<prompt>$</prompt> <userinput>cinder type-key fast_clone set vmware:clone_type=linked</userinput>
<prompt>$</prompt> <userinput>cinder create --image-id 9cb87f4f-a046-47f5-9b7c-d9487b3c7cd4 --volume-type fast_clone --display-name source-vol 1</userinput>
<prompt>$</prompt> <userinput>cinder create --source-volid 25743b9d-3605-462b-b9eb-71459fe2bb35 --display-name dest-vol 1</userinput></screen>
<note>
<para>The VMware ESX VMDK driver ignores the extra spec
entry and always creates a <literal>full</literal>
clone.</para>
</note>
</section>
<section xml:id="vcenter_storage_policies">
<title>Use vCenter storage policies to specify back-end data
stores</title>
<?dbhtml stop-chunking?>
<para>This section describes how to configure back-end data
stores using storage policies. In vCenter 5.5 and greater,
you can create one or more storage policies and expose them
as a Block Storage volume-type to a vmdk volume. The storage
policies are exposed to the vmdk driver through the extra spec
property with the
<literal>vmware:storage_profile</literal> key.</para>
<para>For example, assume a storage policy in vCenter named
<literal>gold_policy.</literal> and a Block Storage
volume type named <literal>vol1</literal> with the extra
spec key <literal>vmware:storage_profile</literal> set to
the value <literal>gold_policy</literal>. Any Block
Storage volume creation that uses the
<literal>vol1</literal> volume type places the volume
only in data stores that match the
<literal>gold_policy</literal> storage policy.</para>
<para>The Block Storage back-end configuration for vSphere
data stores is automatically determined based on the
vCenter configuration. If you configure a connection to
connect to vCenter version 5.5 or later in the
<filename>cinder.conf</filename> file, the use of
storage policies to configure back-end data stores is
automatically supported.</para>
<note>
<para>You must configure any data stores that you
configure for the Block Storage service for the
Compute service.</para>
</note>
<procedure>
<title>To configure back-end data stores by using storage
policies</title>
<step>
<para>In vCenter, tag the data stores to be used for
the back end.</para>
<para>OpenStack also supports policies that are
created by using vendor-specific capabilities; for
example vSAN-specific storage policies.</para>
<note>
<para>The tag value serves as the policy. For
details, see <xref linkend="vmware-spbm"
/>.</para>
</note>
</step>
<step>
<para>Set the extra spec key
<literal>vmware:storage_profile</literal> in
the desired Block Storage volume types to the
policy name that you created in the previous
step.</para>
</step>
<step>
<para>Optionally, for the
<option>vmware_host_version</option>
parameter, enter the version number of your
vSphere platform. For example,
<userinput>5.5</userinput>.</para>
<para>This setting overrides the default location for
the corresponding WSDL file. Among other
scenarios, you can use this setting to prevent
WSDL error messages during the development phase
or to work with a newer version of vCenter.</para>
</step>
<step>
<para>Complete the other vCenter configuration
parameters as appropriate.</para>
</step>
</procedure>
<note>
<para>The following considerations apply to configuring
SPBM for the Block Storage service:</para>
<itemizedlist>
<listitem>
<para>Any volume that is created without an
associated policy (that is to say, without an
associated volume type that specifies
<literal>vmware:storage_profile</literal>
extra spec), there is no policy-based
placement for that volume.</para>
</listitem>
</itemizedlist>
</note>
</section>
<section xml:id="vmdk_supported_operations">
<title>Supported operations</title>
<para>The VMware vCenter and ESX VMDK drivers support these
operations:</para>
<itemizedlist>
<listitem>
<para>Create, delete, attach, and detach volumes.</para>
<note>
<para>When a volume is attached to an instance, a reconfigure
operation is performed on the instance to add the volume's
VMDK to it. The user must manually rescan and mount the device
from within the guest operating system.</para>
</note>
</listitem>
<listitem>
<para>Create, list, and delete volume snapshots.</para>
<note>
<para>Allowed only if volume is not attached to an
instance.</para>
</note>
</listitem>
<listitem>
<para>Create a volume from a snapshot.</para>
</listitem>
<listitem>
<para>Copy an image to a volume.</para>
<note>
<para>Only images in <literal>vmdk</literal> disk format
with <literal>bare</literal> container format are
supported. The <option>vmware_disktype</option> property
of the image can be <literal>preallocated</literal>,
<literal>sparse</literal>,
<literal>streamOptimized</literal> or
<literal>thin</literal>.
</para>
</note>
</listitem>
<listitem>
<para>Copy a volume to an image.</para>
<note>
<itemizedlist>
<listitem>
<para>Allowed only if the volume is not attached to an
instance.</para>
</listitem>
<listitem>
<para>This operation creates a
<literal>streamOptimized</literal> disk image.</para>
</listitem>
</itemizedlist>
</note>
</listitem>
<listitem>
<para>Clone a volume.</para>
<note>
<para>Supported only if the source volume is not attached to an
instance.</para>
</note>
</listitem>
<listitem>
<para>Backup a volume.</para>
<note>
<para>This operation creates a backup of the volume in
<literal>streamOptimized</literal> disk format.</para>
</note>
</listitem>
<listitem>
<para>Restore backup to new or existing volume.</para>
<note>
<para>Supported only if the existing volume doesn't contain
snapshots.</para>
</note>
</listitem>
<listitem>
<para>Change the type of a volume.</para>
<note>
<para>This operation is supported only if the volume state is
<literal>available</literal>.
</para>
</note>
</listitem>
<listitem>
<para>Extend a volume.</para>
</listitem>
</itemizedlist>
<note>
<para>Although the VMware ESX VMDK driver supports these
operations, it has not been extensively tested.</para>
</note>
</section>
<section xml:id="vmware-spbm">
<title>Storage policy-based configuration in vCenter</title>
<para>You can configure Storage Policy-Based Management (SPBM)
profiles for vCenter data stores supporting the Compute,
Image Service, and Block Storage components of an OpenStack
implementation.</para>
<para>In a vSphere OpenStack deployment, SPBM enables you to
delegate several data stores for storage, which reduces
the risk of running out of storage space. The policy logic
selects the data store based on accessibility and
available storage space.</para>
</section>
<section xml:id="vmdk_prereqs">
<title>Prerequisites</title>
<itemizedlist>
<listitem>
<para>Determine the data stores to be used by the SPBM
policy.</para>
</listitem>
<listitem>
<para>Determine the tag that identifies the data
stores in the OpenStack component
configuration.</para>
</listitem>
<listitem>
<para>Create separate policies or sets of data stores
for separate OpenStack components.</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="vmdk_storage_policies">
<title>Create storage policies in vCenter</title>
<procedure>
<title>To create storage policies in vCenter</title>
<step>
<para>In vCenter, create the tag that identifies the
data stores:</para>
<substeps>
<step>
<para>From the Home screen, click
<guimenuitem>Tags</guimenuitem>.</para>
</step>
<step>
<para>Specify a name for the tag.</para>
</step>
<step>
<para>Specify a tag category. For example,
<filename>spbm-cinder</filename>.</para>
</step>
</substeps>
</step>
<step>
<para>Apply the tag to the data stores to be used by
the SPBM policy.</para>
<note>
<para>For details about creating tags in vSphere,
see the <link
xlink:href="http://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.vsphere.vcenterhost.doc/GUID-379F40D3-8CD6-449E-89CB-79C4E2683221.html"
>vSphere documentation</link>.</para>
</note>
</step>
<step>
<para>In vCenter, create a tag-based storage policy
that uses one or more tags to identify a set of
data stores.</para>
<note>
<para>For details about creating storage policies in vSphere,
see the <link
xlink:href="http://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.vsphere.storage.doc/GUID-89091D59-D844-46B2-94C2-35A3961D23E7.html"
>vSphere documentation</link>.</para>
</note>
</step>
</procedure>
</section>
<section xml:id="data_store_selection">
<title>Data store selection</title>
<para>If storage policy is enabled, the driver initially
selects all the data stores that match the associated
storage policy.</para>
<para>If two or more data stores match the storage policy, the
driver chooses a data store that is connected to the
maximum number of hosts.</para>
<para>In case of ties, the driver chooses the data store with
lowest space utilization, where space utilization is
defined by the
<literal>(1-freespace/totalspace)</literal>
meters.</para>
<para>These actions reduce the number of volume migrations
while attaching the volume to instances.</para>
<para>The volume must be migrated if the ESX host for the
instance cannot access the data store that contains the
volume.</para>
</section>
</section>