Difference between revisions of "HypervisorSupportMatrix"
Line 49: | Line 49: | ||
Most [[OpenStack]] development is done with the KVM and XEN hypervisors. This means that (currently at least) you are more likely to find community support for issues with these hypervisors. All features that are currently supported in KVM are also supported in QEMU. | Most [[OpenStack]] development is done with the KVM and XEN hypervisors. This means that (currently at least) you are more likely to find community support for issues with these hypervisors. All features that are currently supported in KVM are also supported in QEMU. | ||
− | As far as the Xen hypervisor is concerned, it is worth noting the following definitions: | + | As far as the [[Xen]] hypervisor is concerned, it is worth noting the following definitions: |
* [[XenServer]]: Open Source but commercially supported product from Citrix (Free edition also available) | * [[XenServer]]: Open Source but commercially supported product from Citrix (Free edition also available) | ||
Line 55: | Line 55: | ||
* XenAPI: The management API exposed by [[XenServer]] and XCP. | * XenAPI: The management API exposed by [[XenServer]] and XCP. | ||
* XAPI: The primary daemon on [[XenServer]] and Xen Cloud Platform; the one that exposes the XenAPI. | * XAPI: The primary daemon on [[XenServer]] and Xen Cloud Platform; the one that exposes the XenAPI. | ||
+ | * [[Xen/Libvirt|Xen via Libvirt]]: Xen hypervisor management using the libvirt Xen driver. | ||
Nova has support for [[XenServer]] and XCP through the XenAPI virt layer. Note that this does not imply support for other Xen-based platforms such as those shipped with RHEL 6 or SUSE, which is provided via the libvirt layer (i.e. Xen via libvirt). | Nova has support for [[XenServer]] and XCP through the XenAPI virt layer. Note that this does not imply support for other Xen-based platforms such as those shipped with RHEL 6 or SUSE, which is provided via the libvirt layer (i.e. Xen via libvirt). | ||
Line 73: | Line 74: | ||
| '''[https://blueprints.launchpad.net/nova/+spec/powervm-compute-driver PowerVM]''' | | '''[https://blueprints.launchpad.net/nova/+spec/powervm-compute-driver PowerVM]''' | ||
| '''[http://www.docker.io Docker]''' | | '''[http://www.docker.io Docker]''' | ||
+ | | '''[[Xen/Libvirt]]''' | ||
|- | |- | ||
| Launch | | Launch | ||
Line 84: | Line 86: | ||
| ✔ | | ✔ | ||
| ✔ | | ✔ | ||
+ | | ✔ *(12) | ||
|- | |- | ||
| Reboot | | Reboot | ||
Line 94: | Line 97: | ||
| ✔ | | ✔ | ||
| ✔*(11) | | ✔*(11) | ||
+ | | ✔ | ||
| ✔ | | ✔ | ||
|- | |- | ||
Line 105: | Line 109: | ||
| ✔ | | ✔ | ||
| ✔ | | ✔ | ||
+ | | ✔ | ||
| ✔ | | ✔ | ||
|- | |- | ||
Line 117: | Line 122: | ||
| ✔ | | ✔ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Rescue | | Rescue | ||
Line 128: | Line 134: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Pause | | Pause | ||
Line 139: | Line 146: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Un-pause | | Un-pause | ||
Line 150: | Line 158: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Suspend | | Suspend | ||
Line 161: | Line 170: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Resume | | Resume | ||
Line 172: | Line 182: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Inject Networking | | Inject Networking | ||
Line 182: | Line 193: | ||
| ✔ | | ✔ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
− | | | + | | |
+ | | | ||
|- | |- | ||
| Inject File | | Inject File | ||
Line 194: | Line 206: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Serial Console Output | | Serial Console Output | ||
Line 205: | Line 218: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| ✔ | | ✔ | ||
+ | | | ||
|- | |- | ||
| VNC Console | | VNC Console | ||
Line 216: | Line 230: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| SPICE Console | | SPICE Console | ||
Line 227: | Line 242: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Attach Volume | | Attach Volume | ||
Line 238: | Line 254: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Detach Volume | | Detach Volume | ||
Line 249: | Line 266: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Live Migration | | Live Migration | ||
Line 260: | Line 278: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Snapshot | | Snapshot | ||
Line 271: | Line 290: | ||
| ✔ | | ✔ | ||
| ✔ | | ✔ | ||
+ | | ✔ * (13) | ||
|- | |- | ||
| iSCSI | | iSCSI | ||
Line 281: | Line 301: | ||
| ✔ | | ✔ | ||
| | | | ||
+ | | | ||
| | | | ||
| | | | ||
Line 292: | Line 313: | ||
| | | | ||
| | | | ||
+ | | | ||
| | | | ||
| | | | ||
Line 303: | Line 325: | ||
| | | | ||
| | | | ||
+ | | | ||
| | | | ||
| | | | ||
Line 316: | Line 339: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Get Guest Info | | Get Guest Info | ||
Line 327: | Line 351: | ||
| ✔ | | ✔ | ||
| ✔ | | ✔ | ||
+ | | | ||
|- | |- | ||
| Get Host Info | | Get Host Info | ||
Line 338: | Line 363: | ||
| ✔ | | ✔ | ||
| ✔ | | ✔ | ||
+ | | | ||
|- | |- | ||
| Glance Integration | | Glance Integration | ||
Line 348: | Line 374: | ||
| ✔ | | ✔ | ||
| ✔ | | ✔ | ||
+ | | ✔ | ||
| ✔ | | ✔ | ||
|- | |- | ||
Line 359: | Line 386: | ||
| | | | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
| | | | ||
|- | |- | ||
Line 371: | Line 399: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| | | | ||
+ | | ✔ | ||
|- | |- | ||
| Flat Networking | | Flat Networking | ||
Line 382: | Line 411: | ||
| ✔ | | ✔ | ||
| | | | ||
+ | | ✔ | ||
|- | |- | ||
| Security Groups | | Security Groups | ||
Line 393: | Line 423: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| | | | ||
+ | | ✔ | ||
|- | |- | ||
| Firewall Rules | | Firewall Rules | ||
Line 404: | Line 435: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| | | | ||
+ | | ✔ | ||
|- | |- | ||
| Routing | | Routing | ||
Line 415: | Line 447: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| | | | ||
+ | | ✔ | ||
|- | |- | ||
| nova diagnostics | | nova diagnostics | ||
Line 426: | Line 459: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Config Drive | | Config Drive | ||
Line 437: | Line 471: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | ✔ | ||
|- | |- | ||
| Auto configure disk | | Auto configure disk | ||
Line 448: | Line 483: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Evacuate | | Evacuate | ||
Line 459: | Line 495: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| | | | ||
+ | | ✔ | ||
|- | |- | ||
| Volume swap | | Volume swap | ||
Line 470: | Line 507: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|- | |- | ||
| Volume rate limiting | | Volume rate limiting | ||
Line 481: | Line 519: | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
| style="color: red" | ✗ | | style="color: red" | ✗ | ||
+ | | | ||
|} | |} | ||
Line 494: | Line 533: | ||
# https://bugs.launchpad.net/nova/+bug/1192192 | # https://bugs.launchpad.net/nova/+bug/1192192 | ||
# The PowerVM driver currently only supports hard reboot. | # The PowerVM driver currently only supports hard reboot. | ||
+ | # Copy on write images are not suported (see bug XXX). | ||
+ | # Only cold-snapshots are available. | ||
=== Description of features === | === Description of features === |
Revision as of 11:13, 21 November 2013
Contents
Compute Drivers
OpenStack Compute (Nova) has an abstraction layer for compute drivers. This is what allows you to choose which hypervisor(s) to use for your Nova deployment. The reality is that the support of each of the options is not equal. They are not tested the same amount. They also do not all support the same features. The purpose of this page is to describe the current support state of each compute driver in terms of testing and functionality.
Driver Testing Status
Group A
These drivers are fully supported. Test coverage includes:
- unit tests that gate commits
- functional testing that gate commits
Drivers in this group include:
- libvirt (qemu/KVM on x86)
Group B
These drivers are in a bit of a middle ground. Test coverage includes:
- unit tests that gate commits
- functional testing providing by an external system that does not gate commits, but advises patch authors and reviewers of results in gerrit (the code review system).
Drivers in this group include:
- VMware
- XenAPI on x86
Group C
NOTE: Drivers in Group C will be deprecated by the Icehouse release. See HypervisorSupportMatrix/DeprecationPlan for details.
These drivers have minimal testing and may or may not work at any given time. Use them at your own risk. Test coverage includes:
- (maybe) unit tests that gate commits
- no public functional testing
Drivers in this group include.
- baremetal
- docker
- Hyper-V
- Xen via libvirt
- LXC via libvirt
- powervm
Hypervisor feature support matrix
This is an attempt to help new users decide on a hypervisor based on features that can be controlled through compute.
Most OpenStack development is done with the KVM and XEN hypervisors. This means that (currently at least) you are more likely to find community support for issues with these hypervisors. All features that are currently supported in KVM are also supported in QEMU.
As far as the Xen hypervisor is concerned, it is worth noting the following definitions:
- XenServer: Open Source but commercially supported product from Citrix (Free edition also available)
- Xen Cloud Platform (XCP): Open-source equivalent of XenServer (and the development project for the toolstack). Everything said about XenServer below applies equally to XCP.
- XenAPI: The management API exposed by XenServer and XCP.
- XAPI: The primary daemon on XenServer and Xen Cloud Platform; the one that exposes the XenAPI.
- Xen via Libvirt: Xen hypervisor management using the libvirt Xen driver.
Nova has support for XenServer and XCP through the XenAPI virt layer. Note that this does not imply support for other Xen-based platforms such as those shipped with RHEL 6 or SUSE, which is provided via the libvirt layer (i.e. Xen via libvirt).
Please help keep this list up-to-date.
Legend: ✔ indicates support, ✗ indicates the feature is not supported, * indicates there is a caveat to the functionality (caveats need to be documented!), and a blank cell generally indicates more testing is needed to make a judgment.
Feature | XenServer/XCP | KVM on x86 | QEMU on x86 | LXC via libvirt | ESXi/VC | Hyper-V | Baremetal | PowerVM | Docker | Xen/Libvirt |
Launch | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ *(12) |
Reboot | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔*(11) | ✔ | ✔ |
Terminate | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ |
Resize | ✔ | ✔ | ✔ | ✔ | ✔ | ✗ | ||||
Rescue | ✔ | ✔ | ✔ | ✔ | ✗ | ✗ | ||||
Pause | ✔ | ✔ | ✔ | ✗ | ✔ | ✗ | ✗ | ✔ | ||
Un-pause | ✔ | ✔ | ✔ | ✗ | ✔ | ✗ | ✗ | ✔ | ||
Suspend | ✔ | ✔ | ✔ | ✔ | ✔ | ✗ | ✗ | ✔ | ||
Resume | ✔ | ✔ | ✔ | ✔ | ✔ | ✗ | ✗ | ✔ | ||
Inject Networking | ✔*(1)(2) | ✔*(1) | ✔*(1) | ✔* | ✔ | ✔ | ✗ | |||
Inject File | ✔ | ✔* | ✔* | ✗*(6) | ✔ | ✗ | ✗ | |||
Serial Console Output | ✔(4) | ✔ | ✔ | ✗ | ✔ | ✗ | ✔* | ✗ | ✔ | |
VNC Console | ✔* | ✔* | ✔* | ✔ | ✔ | ✗ | ✗ | |||
SPICE Console | ✗ | ✔ | ✔ | ✗ | ✗ | ✗ | ✗ | ✗ | ||
Attach Volume | ✔ | ✔ | ✔ | ✗ | ✔ | ✔ | ✗ | ✗ | ✔ | |
Detach Volume | ✔ | ✔ | ✔ | ✗ | ✔ | ✔ | ✗ | ✗ | ✔ | |
Live Migration | ✔ | ✔ | ✔ | ✗ (10) | ✔ | ✗ | ✗ | ✔ | ||
Snapshot | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ * (13) | ||
iSCSI | ✔ | ✔ | ✔ | ✔ | ✔ | |||||
iSCSI CHAP | ✔ | ✔ | ||||||||
Fibre Channel | ✔ | ✔ | ||||||||
Set Admin Pass | ✔ | ✗ | ✗ | ✗ | ✗*(6) | ✗ | ✗ | |||
Get Guest Info | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | |||
Get Host Info | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | |||
Glance Integration | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | |
Service Control | ✔ | ✔ | ✔ | ✔ | ✗ | |||||
VLAN Networking | ✔ | ✔ | ✔ | ✔ | ✔ | ✗*(7) | ✗ | ✔ | ||
Flat Networking | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | |
Security Groups | ✔ | ✔ | ✔ | ✔ | ✗*(9) | ✗ | ✔ | |||
Firewall Rules | ✔ | ✔ | ✔ | ✗ | ✔ | |||||
Routing | ✔ | ✔ | ✔ | ✔ | ✗*(7) | ✗ | ✔ | |||
nova diagnostics | ✔ | ✔ | ✔ | ✗ | ✗ | ✔ | ||||
Config Drive | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✗ | ✗ | ✔ | |
Auto configure disk | ✔ | ✗ | ✗ | |||||||
Evacuate | ✔ | ✔ | ✗ | ✔ | ||||||
Volume swap | ✗ | ✔ | ✔ | ✗ | ✗ | ✗ | ✗ | ✗ | ||
Volume rate limiting | ✗ | ✔ | ✔ | ✗ | ✗ | ✗ | ✗ | ✗ |
- Inject Networking only works with nova-network in Flat mode, and only with Debian/Ubuntu based virtual machines, and only at boot time
- XenServer integration also supports using a guest agent to inject networking settings, at any time when a VM has the guest agent installed, through an admin API extension
- (unused)
- XenAPI support for serial console was added in Havana
- (unsued)
- Functionality provided by cloudbase-init for windows http://www.cloudbase.it/cloud-init-for-windows-instances/
- Vlan and Routing is only supported on Hyper-V when using the Quantum Hyper-V Plugin; VlanManager mode is not supported with nova-network.
- Support of Xen using Libvirt
- Security Groups supported on VC/ESX Driver when using the Quantum NVP Plugin
- https://bugs.launchpad.net/nova/+bug/1192192
- The PowerVM driver currently only supports hard reboot.
- Copy on write images are not suported (see bug XXX).
- Only cold-snapshots are available.
Description of features
Auto configure disk
Automatically reconfigure the size of the partition to match the size of the flavor's root drive before booting.
nova diagnostics
The `nova diagnostics` command will provide some information about resource use associated with an instance. See the OpenStack Compute admin guide for more details.
Set Admin Pass
This feature is the use of a guest agent to change the administrative (root) password on an instance.