openstack-manuals/doc/config-ref-rst/source/compute/hypervisor-xen-libvirt.rst
KATO Tomoyuki 0d48b8b10a [config-ref] Convert compute Xen libvirt to RST
Change-Id: Ib8fc7b7f4a3f5961a0fc1e37434c235849878b24
Implements: blueprint config-ref-rst
2015-12-05 09:27:02 +09:00

231 lines
9.7 KiB
ReStructuredText

===============
Xen via Libvirt
===============
OpenStack Compute supports the Xen Project Hypervisor (or Xen). Xen can be
integrated with OpenStack Compute via the `libvirt <http://libvirt.org/>`_
`toolstack <http://wiki.xen.org/wiki/Choice_of_Toolstacks>`_ or via the
`XAPI <http://xenproject.org/developers/teams/xapi.html>`_
`toolstack <http://wiki.xen.org/wiki/Choice_of_Toolstacks>`_.
This section describes how to set up OpenStack Compute with Xen and libvirt.
For information on how to set up Xen with XAPI refer to
:doc:`hypervisor-xen-api`.
Installing Xen with Libvirt
~~~~~~~~~~~~~~~~~~~~~~~~~~~
At this stage we recommend using the baseline that we use for the
`Xen Project OpenStack CI Loop <http://wiki.xenproject.org/wiki/
OpenStack_CI_Loop_for_Xen-Libvirt>`_, which contains the most recent
stability fixes to both Xen and Libvirt.
`Xen 4.5.1 <http://www.xenproject.org/downloads/xen-archives/xen-45-series/
xen-451.html>`_ (or newer) and `Libvirt 1.2.15 <http://libvirt.org/sources/>`_
(or newer) contain the most recent OpenStack improvements for Xen.
The necessary Xen changes have also been backported to the Xen 4.4.3 stable
branch (not yet released at this stage). Please check with the Linux and
FreeBSD distros you are intending to use as `Dom 0 <http://wiki.xenproject.org/
wiki/Category:Host_Install>`_, whether the relevant version of Xen and
Libvirt are available as installable packages.
The latest releases of Xen and libvirt packages that fulfil the above
minimum requirements for the various openSUSE distributions can always be
found and installed from the `Open Build Service <https://build.opensuse.org/
project/show/Virtualization>`_ Virtualization project.
To install these latest packages, add the Virtualization repository to your
software management stack and get the newest packages from there.
More information about the latest Xen and Libvirt packages are available
`here <https://build.opensuse.org/package/show/Virtualization/xen>`__ and
`here <https://build.opensuse.org/package/show/Virtualization/libvirt>`__.
Alternatively, it is possible to use the Ubuntu LTS 14.04 Xen Package
**4.4.1-0ubuntu0.14.04.4** (Xen 4.4.1) and apply the patches outlined
`here <http://wiki.xenproject.org/wiki/OpenStack_CI_Loop_for_Xen-Libvirt
#Baseline>`__.
You can also use the Ubuntu LTS 14.04 libvirt package **1.2.2
libvirt_1.2.2-0ubuntu13.1.7** as baseline and update it to libvirt version
1.2.15, or 1.2.14 with the patches outlined `here <http://wiki.xenproject.org/
wiki/OpenStack_CI_Loop_for_Xen-Libvirt#Baseline>`__ applied.
Note that this will require rebuilding these packages partly from source.
For further information and latest developments, you may want to consult
the Xen Project's `mailing lists for OpenStack related issues and questions
<http://lists.xenproject.org/cgi-bin/mailman/listinfo/wg-openstack>`_.
Configuring Xen with Libvirt
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
To enable Xen via libvirt, ensure the following options are set in
``/etc/nova/nova.conf`` on all hosts running the ``nova-compute`` service.
.. code-block:: ini
compute_driver = libvirt.LibvirtDriver
[libvirt]
virt_type = xen</programlisting></para>
Additional configuration options
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Use the following as a guideline for configuring Xen for use in OpenStack:
#. **Dom0 Memory**: Set it between 1GB and 4GB by adding the following
parameter to the Xen Boot Options in the `grub.conf <http://
xenbits.xen.org/docs/unstable/misc/xen-command-line.html>`_ file.
.. code-block:: ini
dom0_mem=1024M
.. note::
The above memory limits are suggestions and should be based on the
available compute host resources. For large hosts that will run many
hundreds of instances, the suggested values may need to be higher.
.. note::
The location of the grub.conf file depends on the host Linux
distribution that you are using. Please refer to the distro
documentation for more details (see `Dom 0 <http://wiki.xenproject.org
/wiki/Category:Host_Install>`_ for more resources).
#. **Dom0 vcpus**: Set the virtual CPUs to 4 and employ CPU pinning by adding
the following parameters to the Xen Boot Options in the `grub.conf
<http://xenbits.xen.org/docs/unstable/misc/xen-command-line.html>`_ file.
.. code-block:: ini
dom0_max_vcpus=4 dom0_vcpus_pin
.. note::
Note that the above virtual CPU limits are suggestions and should be
based on the available compute host resources. For large hosts, that
will run many hundred of instances, the suggested values may need to
be higher.
#. **PV vs HVM guests**: A Xen virtual machine can be paravirtualized (PV)
or hardware virtualized (HVM). The virtualization mode determines the
interaction between Xen, Dom 0, and the guest VM's kernel. PV guests are
aware of the fact that they are virtualized and will co-operate with Xen
and Dom 0. The choice of virtualization mode determines performance
characteristics. For an overview of Xen virtualization modes, see
`Xen Guest Types <http://wiki.xen.org/wiki/Xen_Overview#Guest_Types>`_.
In OpenStack, customer VMs may run in either PV or HVM mode.
The mode is a property of the operating system image used by the VM, and
is changed by adjusting the image metadata stored in the Image service.
The image metadata can be changed using the :command:`nova` or
:command:`glance` commands.
To choose one of the HVM modes (HVM, HVM with PV Drivers or PVHVM),
use :command:`nova` or :command:`glance` to set the ``vm_mode``
property to ``hvm``.
To choose one of the HVM modes (HVM, HVM with PV Drivers or PVHVM),
use one of the following two commands:
.. code-block:: console
$ nova image-meta img-uuid set vm_mode=hvm
.. code-block:: console
$ glance image-update img-uuid --property vm_mode=hvm
To chose PV mode, which is supported by NetBSD, FreeBSD and Linux,
use one of the following two commands
.. code-block:: console
$ nova image-meta img-uuid set vm_mode=xen
.. code-block:: console
$ glance image-update img-uuid --property vm_mode=xen
.. note::
The default for virtualization mode in nova is PV mode.
#. **Image Formats**: Xen supports raw, qcow2 and vhd image formats.
For more information on image formats, refer to the `OpenStack Virtual
Image Guide <http://docs.openstack.org/image-guide/introduction.html>`__
and the `Storage Options Guide on the Xen Project Wiki
<http://wiki.xenproject.org/wiki/Storage_options>`_.
#. **Image Metadata**: In addition to the ``vm_mode`` property discussed
above, the ``hypervisor_type`` property is another important component
of the image metadata, especially if your cloud contains mixed hypervisor
compute nodes. Setting the ``hypervisor_type`` property allows the nova
scheduler to select a compute node running the specified hypervisor when
launching instances of the image. Image metadata such as ``vm_mode``,
``hypervisor_type``, architecture, and others can be set when importing
the image to the Image service. The metadata can also be changed using
the :command:`nova` or :command:`glance` commands:
.. code-block:: console
$ nova image-meta img-uuid set hypervisor_type=xen vm_mode=hvm
.. code-block:: console
$ glance image-update img-uuid --property hypervisor_type=xen --property vm_mode=hvm
For more more information on image metadata, refer to the
`OpenStack Virtual Image Guide <http://docs.openstack.org/image-guide/
image-metadata.html>`__.
To customize the libvirt driver, use the configuration option settings
documented in :ref:`nova-xen`.
Troubleshoot Xen with Libvirt
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
**Important Log Files**: When an instance fails to start, or when you come
across other issues, you should first consult the following log files:
* ``/var/log/nova/compute.log``
(for more information refer to :doc:`nova-logs`).
* ``/var/log/libvirt/libxl/libxl-driver.log``,
* ``/var/log/xen/qemu-dm-${instancename}.log``,
* ``/var/log/xen/xen-hotplug.log``,
* ``/var/log/xen/console/guest-${instancename}``
(to enable see `Enabling Guest Console Logs <http://wiki.xen.org/wiki/
Reporting_Bugs_against_Xen#Guest_console_logs>`_) and
* Host Console Logs (read `Enabling and Retrieving Host Console Logs
<http://wiki.xen.org/wiki/Reporting_Bugs_against_Xen#Host_console_logs>`_).
If you need further help you can ask questions on the mailing lists
`xen-users@ <http://lists.xenproject.org/cgi-bin/mailman/listinfo/
xen-users>`_, `wg-openstack@ <http://lists.xenproject.org/cgi-bin/mailman/
listinfo/wg-openstack>`_ or `raise a bug <http://wiki.xen.org/wiki/
Reporting_Bugs_against_Xen>`_ against Xen.
Known issues
~~~~~~~~~~~~
Xen via libvirt is currently only supported with nova-network.
Fixes for a number of bugs are currently being worked on to make sure
that Xen via libvirt will also work with Networking service.
Additional information and resources
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The following section contains links to other useful resources.
* `wiki.xenproject.org/wiki/OpenStack <http://wiki.xenproject.org/wiki/
OpenStack>`_ - OpenStack Documentation on the Xen Project wiki
* `wiki.xenproject.org/wiki/OpenStack_CI_Loop_for_Xen-Libvirt
<http://wiki.xenproject.org/wiki/OpenStack_CI_Loop_for_Xen-Libvirt>`_
- Information about the Xen Project OpenStack CI Loop
* `wiki.xenproject.org/wiki/OpenStack_via_DevStack
<http://wiki.xenproject.org/wiki/OpenStack_via_DevStack>`_
- How to set up OpenStack via DevStack
* `Mailing lists for OpenStack related issues and questions
<http://lists.xenproject.org/cgi-bin/mailman/listinfo/wg-openstack>`_
- This list is dedicated to coordinating bug fixes and issues across Xen,
libvirt and OpenStack and the CI loop.