On 11.10.2016 17:30, Cole Robinson
wrote:
Thank you, Cole. I have found strange behavior in Virtuozzo containers.On 10/05/2016 12:01 PM, Mikhail Feoktistov wrote:In _do_async_install we have a race. We create domain in guest.start_install() and it begins to start. Then we check vm.is_shutoff() but domain doesn't have "running" state. It's still starting. Then we try to start it by vm.startup() and we get an exception from libvirt.Interesting. Sounds like we need another state field in libvirt to indicate a VM is 'starting' but not yet 'running', similar to shutdown vs shutoff. But anyways. We don't see this with typical virt-manager usage since the libvirt qemu driver vm.create() call will always leave the VM in the running state if it returns successfullyThis patch change this logic. Do not raise exception in the following cases: We stop domain which is already stopped We start domain which is already started The same logic is in Nova project in Openstack --- virtManager/domain.py | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/virtManager/domain.py b/virtManager/domain.py index a707f25..c18395f 100644 --- a/virtManager/domain.py +++ b/virtManager/domain.py @@ -1372,7 +1372,11 @@ class vmmDomain(vmmLibvirtObject): @vmmLibvirtObject.lifecycle_action def shutdown(self): self._install_abort = True - self._backend.shutdown() + try: + self._backend.shutdown() + except libvirt.libvirtError, e: + if e.get_error_code() != libvirt.VIR_ERR_OPERATION_INVALID: + raise @vmmLibvirtObject.lifecycle_action def reboot(self): @@ -1401,7 +1405,11 @@ class vmmDomain(vmmLibvirtObject): for error in pre_startup_ret: raise RuntimeError(error) - self._backend.create() + try: + self._backend.create() + except libvirt.libvirtError, e: + if e.get_error_code() != libvirt.VIR_ERR_OPERATION_INVALID: + raise @vmmLibvirtObject.lifecycle_action def suspend(self):Can we isolate this OPERATION_INVALID handling to virtManager/create.py ? Adding this to generic code means we need to check that skipping this error is appropriate for all uses. In create.py we can at least add a comment that this is required for virtuozzo installs I need to research it, and after that I'll send another patch. Please ignore this patch. Thanks, Cole |
_______________________________________________ virt-tools-list mailing list virt-tools-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/virt-tools-list