(some fixes) |
(Retarget to Fedora 20 as requested by Feature owner) |
||
(16 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
= Virt Device Failover = | |||
= | |||
== Summary == | == Summary == | ||
Support for transparent failover between an assigned and an emulated device, allows enabling the migration and overcommit dynamically, while still gaining the performance benefits of device assignment and without disrupting the guest operation. | |||
Support for transparent failover between an assigned and an emulated device, | |||
allows enabling the migration and overcommit dynamically, while | |||
still gaining the performance benefits of device assignment | |||
and without disrupting the guest operation. | |||
== Owner == | == Owner == | ||
* Name: [[User:Mst|Michael S. Tsirkin]] | |||
* Name: [[User: | * Email: mst@redhat.com | ||
* Name: [[User:Ghammer| Gal Hammer]] | * Name: [[User:Ghammer|Gal Hammer]] | ||
* Email: ghammer@redhat.com | |||
* Name: [[User:crobinso|Cole Robinson]] | |||
* Email: | * Email: crobinso@redhat.com | ||
* Email: | * Name: [[User:laine|Laine Stump]] | ||
* Email: laine@redhat.com | |||
== Current status == | == Current status == | ||
* Targeted release: [[Fedora | * Targeted release: [[Releases/20|Fedora 20]] | ||
* Last updated: | * Last updated: 2013-03-15 | ||
* Percentage of completion: 50% | * Percentage of completion: 50% | ||
== Detailed Description == | == Detailed Description == | ||
For virtual machines, device assignment is the best | For virtual machines, device assignment is the best | ||
option for performance. However, when a device is assigned to a VM, both | option for performance. However, when a device is assigned to a VM, both | ||
Line 48: | Line 35: | ||
while device configuration is preserved. Once e.g. migration | while device configuration is preserved. Once e.g. migration | ||
completes, the reverse switch can take place. | completes, the reverse switch can take place. | ||
Thus the device is controlled by: | |||
* before migration: device specific driver loaded in guest | |||
* during migration: driver loaded in host, virtio or emulated device driver loaded in guest | |||
* after migration: device specific driver loaded in guest | |||
At the kernel level, for networking, this can be done by and creating | At the kernel level, for networking, this can be done by and creating | ||
a bond in a failover configuration, and for storage, using multipath, | team (or a bond) in a failover configuration, and for storage, using multipath, | ||
on top of both the assigned and the emulated device. | on top of both the assigned and the emulated device. | ||
== Benefit to Fedora == | == Benefit to Fedora == | ||
Complex virt setups now have less operational caveats, which makes things simpler for users. | |||
== Scope == | == Scope == | ||
Work left to do: | Work left to do: | ||
* kvm needs to be extended to notify the guest that the two devices are setup in a fallback configuration | * kvm needs to be extended to notify the guest that the two devices are setup in a fallback configuration<br>In particular, add support for sending dbus commands to qemu-ga.<br>Need to configure security policy appropriately to allow control of what's allowed, cleanly. | ||
* For networking, | * For networking, NetworkManager in fedora will support bonding:<br>https://fedoraproject.org/wiki/Features/NetworkManagerBonding <br>and teaming<br>https://fedoraproject.org/wiki/Features/NetworkManagerTeaming <br>NM can be controlled using dbus. | ||
* For storage, need to setup device-mapper-multipath to autodetect this configuration | * For storage, need to setup device-mapper-multipath to autodetect this configuration | ||
* libvirt has to be extended to specify this configuration | * libvirt has to be extended to specify this configuration | ||
* libvirt has to be extended to request failover, and ack on guest ack of the failover | * libvirt has to be extended to request failover, and ack on guest ack of the failover | ||
* above covers linux guests | * above covers linux guests<br>if possible, guest agent for windows should be extended to add this support in windows guests as well | ||
== How To Test == | == How To Test == | ||
Two systems with device assignment (IOMMU) support are required to | Two systems with device assignment (IOMMU) support are required to | ||
test this feature. | test this feature. | ||
To test the feature, specify an assigned device, | To test the feature, specify an assigned device, | ||
start guest and migrate. | start guest and migrate. | ||
XXX: Explicit test steps here for test day | |||
== User Experience == | == User Experience == | ||
User will see that they can specify an assigned network or storage | User will see that they can specify an assigned network or storage | ||
device and still migrate the guest seamlessly. | device and still migrate the guest seamlessly. | ||
== Dependencies == | == Dependencies == | ||
For networking, | For networking, | ||
https://fedoraproject.org/wiki/Features/NetworkManagerBonding | https://fedoraproject.org/wiki/Features/NetworkManagerBonding | ||
== Contingency Plan == | == Contingency Plan == | ||
None necessary, revert to previous release behaviour. | None necessary, revert to previous release behaviour. | ||
== Documentation == | == Documentation == | ||
Links to related upstream documentation: | Links to related upstream documentation: | ||
www.linux-kvm.org/page/Hotadd_pci_devices | http://www.linux-kvm.org/page/Hotadd_pci_devices | ||
https://access.redhat.com/knowledge/docs/en-US/Red_Hat_Enterprise_Linux/6/html-single/DM_Multipath/index.html | https://access.redhat.com/knowledge/docs/en-US/Red_Hat_Enterprise_Linux/6/html-single/DM_Multipath/index.html | ||
unixfoo.blogspot.com/2007/10/yet-to-add.html | http://unixfoo.blogspot.com/2007/10/yet-to-add.html | ||
== Release Notes == | == Release Notes == | ||
* KVM guests with assigned host devices can now be migrated across hosts. The assigned device will be replaced during migration with an emulated device in a transparent manner. | |||
== Comments and Discussion == | == Comments and Discussion == | ||
* See [[Talk:Features/KVM_Device_Failover]] | * See [[Talk:Features/KVM_Device_Failover]] | ||
[[Category:FeatureReadyForWrangler]] | [[Category:FeatureReadyForWrangler]] | ||
[[Category:Virtualization]] | |||
Latest revision as of 09:54, 15 March 2013
Virt Device Failover
Summary
Support for transparent failover between an assigned and an emulated device, allows enabling the migration and overcommit dynamically, while still gaining the performance benefits of device assignment and without disrupting the guest operation.
Owner
- Name: Michael S. Tsirkin
- Email: mst@redhat.com
- Name: Gal Hammer
- Email: ghammer@redhat.com
- Name: Cole Robinson
- Email: crobinso@redhat.com
- Name: Laine Stump
- Email: laine@redhat.com
Current status
- Targeted release: Fedora 20
- Last updated: 2013-03-15
- Percentage of completion: 50%
Detailed Description
For virtual machines, device assignment is the best option for performance. However, when a device is assigned to a VM, both migration and memory overcommit are currently disabled.
This feature aims at removing the performance/features tradeoff, by switching to an emulated device in a way that is almost transparent to users, for configurations where both host and guest are Fedora.
Fedora should detect that the emulated device serves as a failover for the assigned device. When requested by the hypervisor, it will stop and eject the assigned device, switching to failover. After this point, migration and memory overcommit are possible, while device configuration is preserved. Once e.g. migration completes, the reverse switch can take place.
Thus the device is controlled by:
- before migration: device specific driver loaded in guest
- during migration: driver loaded in host, virtio or emulated device driver loaded in guest
- after migration: device specific driver loaded in guest
At the kernel level, for networking, this can be done by and creating team (or a bond) in a failover configuration, and for storage, using multipath, on top of both the assigned and the emulated device.
Benefit to Fedora
Complex virt setups now have less operational caveats, which makes things simpler for users.
Scope
Work left to do:
- kvm needs to be extended to notify the guest that the two devices are setup in a fallback configuration
In particular, add support for sending dbus commands to qemu-ga.
Need to configure security policy appropriately to allow control of what's allowed, cleanly. - For networking, NetworkManager in fedora will support bonding:
https://fedoraproject.org/wiki/Features/NetworkManagerBonding
and teaming
https://fedoraproject.org/wiki/Features/NetworkManagerTeaming
NM can be controlled using dbus. - For storage, need to setup device-mapper-multipath to autodetect this configuration
- libvirt has to be extended to specify this configuration
- libvirt has to be extended to request failover, and ack on guest ack of the failover
- above covers linux guests
if possible, guest agent for windows should be extended to add this support in windows guests as well
How To Test
Two systems with device assignment (IOMMU) support are required to test this feature. To test the feature, specify an assigned device, start guest and migrate.
XXX: Explicit test steps here for test day
User Experience
User will see that they can specify an assigned network or storage device and still migrate the guest seamlessly.
Dependencies
For networking, https://fedoraproject.org/wiki/Features/NetworkManagerBonding
Contingency Plan
None necessary, revert to previous release behaviour.
Documentation
Links to related upstream documentation:
http://www.linux-kvm.org/page/Hotadd_pci_devices https://access.redhat.com/knowledge/docs/en-US/Red_Hat_Enterprise_Linux/6/html-single/DM_Multipath/index.html http://unixfoo.blogspot.com/2007/10/yet-to-add.html
Release Notes
- KVM guests with assigned host devices can now be migrated across hosts. The assigned device will be replaced during migration with an emulated device in a transparent manner.