mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
ovirt auto migrate vm (#54542)
* ovirt auto migrate vm * ovirt vm auto migrage only without host * repair ovirt auto migrate vm
This commit is contained in:
parent
88a1efb774
commit
e0f0816385
1 changed files with 20 additions and 4 deletions
|
@ -740,6 +740,11 @@ options:
|
||||||
- "If I(true), the VM will migrate even if it is defined as non-migratable."
|
- "If I(true), the VM will migrate even if it is defined as non-migratable."
|
||||||
version_added: "2.8"
|
version_added: "2.8"
|
||||||
type: bool
|
type: bool
|
||||||
|
migrate:
|
||||||
|
description:
|
||||||
|
- "If I(true), the VM will migrate to any available host."
|
||||||
|
version_added: "2.8"
|
||||||
|
type: bool
|
||||||
next_run:
|
next_run:
|
||||||
description:
|
description:
|
||||||
- "If I(true), the update will not be applied to the VM immediately and will be only applied when virtual machine is restarted."
|
- "If I(true), the update will not be applied to the VM immediately and will be only applied when virtual machine is restarted."
|
||||||
|
@ -940,6 +945,12 @@ EXAMPLES = '''
|
||||||
name: myvm
|
name: myvm
|
||||||
host: host1
|
host: host1
|
||||||
|
|
||||||
|
- name: Migrate VM to any available host
|
||||||
|
ovirt_vm:
|
||||||
|
state: running
|
||||||
|
name: myvm
|
||||||
|
migrate: true
|
||||||
|
|
||||||
- name: Change VMs CD
|
- name: Change VMs CD
|
||||||
ovirt_vm:
|
ovirt_vm:
|
||||||
name: myvm
|
name: myvm
|
||||||
|
@ -1537,9 +1548,9 @@ class VmsModule(BaseModule):
|
||||||
def _migrate_vm(self, entity):
|
def _migrate_vm(self, entity):
|
||||||
vm_host = self.param('host')
|
vm_host = self.param('host')
|
||||||
vm_service = self._service.vm_service(entity.id)
|
vm_service = self._service.vm_service(entity.id)
|
||||||
if vm_host is not None:
|
|
||||||
# In case VM is preparing to be UP, wait to be up, to migrate it:
|
# In case VM is preparing to be UP, wait to be up, to migrate it:
|
||||||
if entity.status == otypes.VmStatus.UP:
|
if entity.status == otypes.VmStatus.UP:
|
||||||
|
if vm_host is not None:
|
||||||
hosts_service = self._connection.system_service().hosts_service()
|
hosts_service = self._connection.system_service().hosts_service()
|
||||||
current_vm_host = hosts_service.host_service(entity.host.id).get().name
|
current_vm_host = hosts_service.host_service(entity.host.id).get().name
|
||||||
if vm_host != current_vm_host:
|
if vm_host != current_vm_host:
|
||||||
|
@ -1547,7 +1558,11 @@ class VmsModule(BaseModule):
|
||||||
vm_service.migrate(host=otypes.Host(name=vm_host), force=self.param('force_migrate'))
|
vm_service.migrate(host=otypes.Host(name=vm_host), force=self.param('force_migrate'))
|
||||||
self._wait_for_UP(vm_service)
|
self._wait_for_UP(vm_service)
|
||||||
self.changed = True
|
self.changed = True
|
||||||
|
elif self.param('migrate'):
|
||||||
|
if not self._module.check_mode:
|
||||||
|
vm_service.migrate(force=self.param('force_migrate'))
|
||||||
|
self._wait_for_UP(vm_service)
|
||||||
|
self.changed = True
|
||||||
return entity
|
return entity
|
||||||
|
|
||||||
def _wait_for_UP(self, vm_service):
|
def _wait_for_UP(self, vm_service):
|
||||||
|
@ -2214,6 +2229,7 @@ def main():
|
||||||
export_domain=dict(default=None),
|
export_domain=dict(default=None),
|
||||||
export_ova=dict(type='dict'),
|
export_ova=dict(type='dict'),
|
||||||
force_migrate=dict(type='bool'),
|
force_migrate=dict(type='bool'),
|
||||||
|
migrate=dict(type='bool', default=None),
|
||||||
next_run=dict(type='bool'),
|
next_run=dict(type='bool'),
|
||||||
)
|
)
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
Loading…
Reference in a new issue