Class: OpenNebula::VirtualMachine
- Inherits:
-
PoolElement
- Object
- XMLElement
- PoolElement
- OpenNebula::VirtualMachine
- Defined in:
- lib/opennebula/virtual_machine.rb
Defined Under Namespace
Modules: Driver
Constant Summary collapse
- VM_METHODS =
Constants and Class Methods
{ :info => "vm.info", :allocate => "vm.allocate", :action => "vm.action", :migrate => "vm.migrate", :deploy => "vm.deploy", :chown => "vm.chown", :chmod => "vm.chmod", :monitoring => "vm.monitoring", :attach => "vm.attach", :detach => "vm.detach", :rename => "vm.rename", :update => "vm.update", :resize => "vm.resize", :snapshotcreate => "vm.snapshotcreate", :snapshotrevert => "vm.snapshotrevert", :snapshotdelete => "vm.snapshotdelete", :attachnic => "vm.attachnic", :detachnic => "vm.detachnic", :recover => "vm.recover", :disksaveas => "vm.disksaveas", :disksnapshotcreate => "vm.disksnapshotcreate", :disksnapshotrevert => "vm.disksnapshotrevert", :disksnapshotdelete => "vm.disksnapshotdelete", :disksnapshotrename => "vm.disksnapshotrename", :diskresize => "vm.diskresize", :updateconf => "vm.updateconf", :lock => "vm.lock", :unlock => "vm.unlock", :schedadd => "vm.schedadd", :scheddelete => "vm.scheddelete", :schedupdate => "vm.schedupdate", :attachsg => "vm.attachsg", :detachsg => "vm.detachsg", :backup => "vm.backup", :updatenic => "vm.updatenic" }
- VM_STATE =
%w{INIT PENDING HOLD ACTIVE STOPPED SUSPENDED DONE FAILED POWEROFF UNDEPLOYED CLONING CLONING_FAILURE}
- LCM_STATE =
%w{ LCM_INIT PROLOG BOOT RUNNING MIGRATE SAVE_STOP SAVE_SUSPEND SAVE_MIGRATE PROLOG_MIGRATE PROLOG_RESUME EPILOG_STOP EPILOG SHUTDOWN CANCEL FAILURE CLEANUP_RESUBMIT UNKNOWN HOTPLUG SHUTDOWN_POWEROFF BOOT_UNKNOWN BOOT_POWEROFF BOOT_SUSPENDED BOOT_STOPPED CLEANUP_DELETE HOTPLUG_SNAPSHOT HOTPLUG_NIC HOTPLUG_SAVEAS HOTPLUG_SAVEAS_POWEROFF HOTPLUG_SAVEAS_SUSPENDED SHUTDOWN_UNDEPLOY EPILOG_UNDEPLOY PROLOG_UNDEPLOY BOOT_UNDEPLOY HOTPLUG_PROLOG_POWEROFF HOTPLUG_EPILOG_POWEROFF BOOT_MIGRATE BOOT_FAILURE BOOT_MIGRATE_FAILURE PROLOG_MIGRATE_FAILURE PROLOG_FAILURE EPILOG_FAILURE EPILOG_STOP_FAILURE EPILOG_UNDEPLOY_FAILURE PROLOG_MIGRATE_POWEROFF PROLOG_MIGRATE_POWEROFF_FAILURE PROLOG_MIGRATE_SUSPEND PROLOG_MIGRATE_SUSPEND_FAILURE BOOT_UNDEPLOY_FAILURE BOOT_STOPPED_FAILURE PROLOG_RESUME_FAILURE PROLOG_UNDEPLOY_FAILURE DISK_SNAPSHOT_POWEROFF DISK_SNAPSHOT_REVERT_POWEROFF DISK_SNAPSHOT_DELETE_POWEROFF DISK_SNAPSHOT_SUSPENDED DISK_SNAPSHOT_REVERT_SUSPENDED DISK_SNAPSHOT_DELETE_SUSPENDED DISK_SNAPSHOT DISK_SNAPSHOT_REVERT DISK_SNAPSHOT_DELETE PROLOG_MIGRATE_UNKNOWN PROLOG_MIGRATE_UNKNOWN_FAILURE DISK_RESIZE DISK_RESIZE_POWEROFF DISK_RESIZE_UNDEPLOYED HOTPLUG_NIC_POWEROFF HOTPLUG_RESIZE HOTPLUG_SAVEAS_UNDEPLOYED HOTPLUG_SAVEAS_STOPPED BACKUP BACKUP_POWEROFF }
- SHORT_VM_STATES =
{ "INIT" => "init", "PENDING" => "pend", "HOLD" => "hold", "ACTIVE" => "actv", "STOPPED" => "stop", "SUSPENDED" => "susp", "DONE" => "done", "FAILED" => "fail", "POWEROFF" => "poff", "UNDEPLOYED" => "unde", "CLONING" => "clon", "CLONING_FAILURE" => "fail" }
- SHORT_LCM_STATES =
{ "PROLOG" => "prol", "BOOT" => "boot", "RUNNING" => "runn", "MIGRATE" => "migr", "SAVE_STOP" => "save", "SAVE_SUSPEND" => "save", "SAVE_MIGRATE" => "save", "PROLOG_MIGRATE" => "migr", "PROLOG_RESUME" => "prol", "EPILOG_STOP" => "epil", "EPILOG" => "epil", "SHUTDOWN" => "shut", "CANCEL" => "shut", "FAILURE" => "fail", "CLEANUP_RESUBMIT" => "clea", "UNKNOWN" => "unkn", "HOTPLUG" => "hotp", "SHUTDOWN_POWEROFF" => "shut", "BOOT_UNKNOWN" => "boot", "BOOT_POWEROFF" => "boot", "BOOT_SUSPENDED" => "boot", "BOOT_STOPPED" => "boot", "CLEANUP_DELETE" => "clea", "HOTPLUG_SNAPSHOT" => "snap", "HOTPLUG_NIC" => "hotp", "HOTPLUG_SAVEAS" => "hotp", "HOTPLUG_SAVEAS_POWEROFF" => "hotp", "HOTPLUG_SAVEAS_SUSPENDED" => "hotp", "SHUTDOWN_UNDEPLOY" => "shut", "EPILOG_UNDEPLOY" => "epil", "PROLOG_UNDEPLOY" => "prol", "BOOT_UNDEPLOY" => "boot", "HOTPLUG_PROLOG_POWEROFF" => "hotp", "HOTPLUG_EPILOG_POWEROFF" => "hotp", "BOOT_MIGRATE" => "boot", "BOOT_FAILURE" => "fail", "BOOT_MIGRATE_FAILURE" => "fail", "PROLOG_MIGRATE_FAILURE" => "fail", "PROLOG_FAILURE" => "fail", "EPILOG_FAILURE" => "fail", "EPILOG_STOP_FAILURE" => "fail", "EPILOG_UNDEPLOY_FAILURE" => "fail", "PROLOG_MIGRATE_POWEROFF" => "migr", "PROLOG_MIGRATE_POWEROFF_FAILURE" => "fail", "PROLOG_MIGRATE_SUSPEND" => "migr", "PROLOG_MIGRATE_SUSPEND_FAILURE" => "fail", "BOOT_UNDEPLOY_FAILURE" => "fail", "BOOT_STOPPED_FAILURE" => "fail", "PROLOG_RESUME_FAILURE" => "fail", "PROLOG_UNDEPLOY_FAILURE" => "fail", "DISK_SNAPSHOT_POWEROFF" => "snap", "DISK_SNAPSHOT_REVERT_POWEROFF" => "snap", "DISK_SNAPSHOT_DELETE_POWEROFF" => "snap", "DISK_SNAPSHOT_SUSPENDED" => "snap", "DISK_SNAPSHOT_REVERT_SUSPENDED"=> "snap", "DISK_SNAPSHOT_DELETE_SUSPENDED"=> "snap", "DISK_SNAPSHOT" => "snap", "DISK_SNAPSHOT_DELETE" => "snap", "PROLOG_MIGRATE_UNKNOWN" => "migr", "PROLOG_MIGRATE_UNKNOWN_FAILURE" => "fail", "DISK_RESIZE" => "drsz", "DISK_RESIZE_POWEROFF" => "drsz", "DISK_RESIZE_UNDEPLOYED" => "drsz", "HOTPLUG_NIC_POWEROFF" => "hotp", "HOTPLUG_RESIZE" => "hotp", "HOTPLUG_SAVEAS_UNDEPLOYED" => "hotp", "HOTPLUG_SAVEAS_STOPPED" => "hotp", "BACKUP" => "back", "BACKUP_POWEROFF" => "back", }
- HISTORY_ACTION =
%w{none migrate live-migrate shutdown shutdown-hard undeploy undeploy-hard hold release stop suspend resume boot delete delete-recreate reboot reboot-hard resched unresched poweroff poweroff-hard disk-attach disk-detach nic-attach nic-detach disk-snapshot-create disk-snapshot-delete terminate terminate-hard disk-resize deploy chown chmod updateconf rename resize update snapshot-resize snapshot-delete snapshot-revert disk-saveas disk-snapshot-revert recover retry monitor disk-snapshot-rename alias-attach alias-detach poweroff-migrate poweroff-hard-migrate backup nic-update }
- EXTERNAL_IP_ATTRS =
[ 'GUEST_IP', 'AWS_IP_ADDRESS', 'AWS_PUBLIC_IP_ADDRESS', 'AWS_PRIVATE_IP_ADDRESS', 'AZ_IPADDRESS', 'SL_PRIMARYIPADDRESS' ]
Class Method Summary collapse
-
.build_xml(pe_id = nil) ⇒ Object
Creates a VirtualMachine description with just its identifier this method should be used to create plain VirtualMachine objects.
- .get_history_action(action) ⇒ Object
Instance Method Summary collapse
-
#allocate(description, hold = false) ⇒ nil, OpenNebula::Error
Allocates a new VirtualMachine in OpenNebula.
-
#backup(ds_id, reset = false) ⇒ Integer, OpenNebula::Error
Generate a backup for the VM (backup config must be set).
-
#chmod(owner_u, owner_m, owner_a, group_u, group_m, group_a, other_u, other_m, other_a) ⇒ nil, OpenNebula::Error
Changes the permissions.
-
#chmod_octet(octet) ⇒ nil, OpenNebula::Error
Changes the permissions.
-
#chown(uid, gid) ⇒ Object
- Changes the owner/group uid
-
Integer the new owner id.
-
#delete(recreate = false) ⇒ Object
Deletes a VM from the pool.
-
#deploy(host_id, enforce = false, ds_id = -1,, extra_template = "") ⇒ nil, OpenNebula::Error
Initiates the instance of the VM on the target host.
-
#deploy_id ⇒ Object
Returns the deploy_id of the VirtualMachine (numeric value).
-
#disk_attach(disk_template) ⇒ nil, OpenNebula::Error
(also: #attachdisk)
Attaches a disk to a running VM.
-
#disk_detach(disk_id) ⇒ nil, OpenNebula::Error
(also: #detachdisk)
Detaches a disk from a running VM.
-
#disk_resize(disk_id, size) ⇒ nil, OpenNebula::Error
Changes the size of a disk.
-
#disk_saveas(disk_id, image_name, image_type = "", snap_id = -1)) ⇒ Integer, OpenNebula::Error
Set the specified vm’s disk to be saved as a new image.
-
#disk_snapshot_create(disk_id, name) ⇒ Integer, OpenNebula::Error
Takes a new snapshot of a disk.
-
#disk_snapshot_delete(disk_id, snap_id) ⇒ nil, OpenNebula::Error
Deletes a disk snapshot.
-
#disk_snapshot_rename(disk_id, snap_id, new_name) ⇒ nil, OpenNebula::Error
Renames a disk snapshot.
-
#disk_snapshot_revert(disk_id, snap_id) ⇒ nil, OpenNebula::Error
Reverts disk state to a previously taken snapshot.
- #get_history_record(seq) ⇒ Object
-
#gid ⇒ Object
Returns the group identifier [return] Integer the element’s group ID.
-
#hold ⇒ Object
Sets a VM to hold state, scheduler will not deploy it.
-
#info(decrypt = false) ⇒ Object
(also: #info!)
Retrieves the information of the given VirtualMachine.
-
#initialize(xml, client) ⇒ VirtualMachine
constructor
Class constructor.
-
#lcm_state ⇒ Object
Returns the LCM state of the VirtualMachine (numeric value).
-
#lcm_state_str ⇒ Object
Returns the LCM state of the VirtualMachine (string value).
-
#live_migrate(host_id, enforce = false) ⇒ Object
deprecated
Deprecated.
use #migrate instead
-
#migrate(host_id, live = false, enforce = false, ds_id = -1,, mtype = 0) ⇒ nil, OpenNebula::Error
Moves a running VM to the specified host.
-
#monitoring(xpath_expressions) ⇒ Hash<String, Array<Array<int>>>, OpenNebula::Error
Retrieves this VM’s monitoring data from OpenNebula.
-
#monitoring_xml ⇒ String
Retrieves this VM’s monitoring data from OpenNebula, in XML.
-
#nic_attach(nic_template) ⇒ nil, OpenNebula::Error
Attaches a NIC to a running VM.
-
#nic_detach(nic_id) ⇒ nil, OpenNebula::Error
Detaches a NIC from a running VM.
-
#nic_update(nic_id, nic_template, append = false) ⇒ nil, OpenNebula::Error
Updates a NIC for a running VM.
-
#poweroff(hard = false) ⇒ Object
Powers off a running VM.
-
#reboot(hard = false) ⇒ Object
Reboots an already deployed VM.
-
#recover(result) ⇒ nil, OpenNebula::Error
Recovers an ACTIVE VM.
-
#release ⇒ Object
Releases a VM from hold state.
-
#rename(name) ⇒ nil, OpenNebula::Error
Renames this VM.
- #replace(opts = {}) ⇒ Object
-
#resched ⇒ Object
Sets the re-scheduling flag for the VM.
-
#resize(capacity_template, enforce) ⇒ nil, OpenNebula::Error
Resize the VM.
-
#resume ⇒ Object
Resumes the execution of a saved VM.
-
#sched_action_add(sched_template) ⇒ nil, OpenNebula::Error
Add sched actions.
-
#sched_action_delete(sched_id) ⇒ nil, OpenNebula::Error
Delete sched action.
-
#sched_action_update(sched_id, sched_template) ⇒ nil, OpenNebula::Error
Update sched_action.
-
#sg_attach(nic_id, sg_id) ⇒ nil, OpenNebula::Error
Attaches a Security Groupt to a running VM.
-
#sg_detach(nic_id, sg_id) ⇒ nil, OpenNebula::Error
Detaches a Security Group from a running VM.
-
#snapshot_create(name = "") ⇒ Integer, OpenNebula::Error
Creates a new VM snapshot.
-
#snapshot_delete(snap_id) ⇒ nil, OpenNebula::Error
Deletes a VM snapshot.
-
#snapshot_revert(snap_id) ⇒ nil, OpenNebula::Error
Reverts to a snapshot.
-
#state ⇒ Object
Returns the VM state of the VirtualMachine (numeric value).
-
#state_str ⇒ Object
Returns the VM state of the VirtualMachine (string value).
-
#status ⇒ Object
Returns the short status string for the VirtualMachine.
-
#stop ⇒ Object
Stops a running VM.
-
#suspend ⇒ Object
Saves a running VM.
-
#terminate(hard = false) ⇒ Object
(also: #shutdown)
Shutdowns an already deployed VM.
-
#undeploy(hard = false) ⇒ Object
Shuts down an already deployed VM, saving its state in the system DS.
-
#unresched ⇒ Object
Unsets the re-scheduling flag for the VM.
-
#update(new_template = nil, append = false) ⇒ nil, OpenNebula::Error
Replaces the template contents.
-
#updateconf(new_conf, append = false) ⇒ nil, OpenNebula::Error
Changes the attributes of a VM in power off, failure and undeploy states.
-
#user_template_str(indent = true) ⇒ String
Returns the <USER_TEMPLATE> element in text form.
-
#user_template_xml ⇒ String
Returns the <USER_TEMPLATE> element in XML form.
- #wait_state(state, timeout = 120) ⇒ Object
- #wait_state2(state, lcm_state, timeout = 120) ⇒ Object
Methods inherited from PoolElement
#id, #name, new_with_id, #to_str
Methods inherited from XMLElement
#[], #add_element, #attr, #delete_element, #each, #each_xpath, #element_xml, #has_elements?, #initialize_xml, #name, #retrieve_elements, #retrieve_xmlelements, #set_content, #template_like_str, #template_str, #template_xml, #text, #to_hash, #to_xml, #xml_nil?
Constructor Details
#initialize(xml, client) ⇒ VirtualMachine
Class constructor
292 293 294 295 296 |
# File 'lib/opennebula/virtual_machine.rb', line 292 def initialize(xml, client) LockableExt.make_lockable(self, VM_METHODS) super(xml,client) end |
Class Method Details
.build_xml(pe_id = nil) ⇒ Object
Creates a VirtualMachine description with just its identifier this method should be used to create plain VirtualMachine objects. id
the id of the vm
Example:
vm = VirtualMachine.new(VirtualMachine.build_xml(3),rpc_client)
277 278 279 280 281 282 283 284 285 |
# File 'lib/opennebula/virtual_machine.rb', line 277 def VirtualMachine.build_xml(pe_id=nil) if pe_id vm_xml = "<VM><ID>#{pe_id}</ID></VM>" else vm_xml = "<VM></VM>" end XMLElement.build_xml(vm_xml, 'VM') end |
.get_history_action(action) ⇒ Object
287 288 289 |
# File 'lib/opennebula/virtual_machine.rb', line 287 def VirtualMachine.get_history_action(action) return HISTORY_ACTION[action.to_i] end |
Instance Method Details
#allocate(description, hold = false) ⇒ nil, OpenNebula::Error
Allocates a new VirtualMachine in OpenNebula
318 319 320 |
# File 'lib/opennebula/virtual_machine.rb', line 318 def allocate(description, hold=false) super(VM_METHODS[:allocate], description, hold) end |
#backup(ds_id, reset = false) ⇒ Integer, OpenNebula::Error
Generate a backup for the VM (backup config must be set)
in case of success, Error otherwise.
806 807 808 |
# File 'lib/opennebula/virtual_machine.rb', line 806 def backup(ds_id, reset = false) return @client.call(VM_METHODS[:backup], @pe_id, ds_id, reset) end |
#chmod(owner_u, owner_m, owner_a, group_u, group_m, group_a, other_u, other_m, other_a) ⇒ nil, OpenNebula::Error
Changes the permissions. Each [Integer] argument must be 1 to allow, 0 deny, -1 do not change
603 604 605 606 607 |
# File 'lib/opennebula/virtual_machine.rb', line 603 def chmod(owner_u, owner_m, owner_a, group_u, group_m, group_a, other_u, other_m, other_a) super(VM_METHODS[:chmod], owner_u, owner_m, owner_a, group_u, group_m, group_a, other_u, other_m, other_a) end |
#chmod_octet(octet) ⇒ nil, OpenNebula::Error
Changes the permissions.
594 595 596 |
# File 'lib/opennebula/virtual_machine.rb', line 594 def chmod_octet(octet) super(VM_METHODS[:chmod], octet) end |
#chown(uid, gid) ⇒ Object
Changes the owner/group
- uid
-
Integer the new owner id. Set to -1 to leave the current one
- gid
-
Integer the new group id. Set to -1 to leave the current one
- return
-
nil in case of success or an Error object
585 586 587 |
# File 'lib/opennebula/virtual_machine.rb', line 585 def chown(uid, gid) super(VM_METHODS[:chown], uid, gid) end |
#delete(recreate = false) ⇒ Object
Deletes a VM from the pool
748 749 750 751 752 753 754 |
# File 'lib/opennebula/virtual_machine.rb', line 748 def delete(recreate=false) if recreate recover(4) else recover(3) end end |
#deploy(host_id, enforce = false, ds_id = -1,, extra_template = "") ⇒ nil, OpenNebula::Error
Initiates the instance of the VM on the target host.
370 371 372 373 374 375 376 377 378 379 380 381 382 383 |
# File 'lib/opennebula/virtual_machine.rb', line 370 def deploy(host_id, enforce=false, ds_id=-1, extra_template="") enforce ||= false ds_id ||= -1 extra_template ||= "" self.info return call(VM_METHODS[:deploy], @pe_id, host_id.to_i, enforce, ds_id.to_i, extra_template) end |
#deploy_id ⇒ Object
Returns the deploy_id of the VirtualMachine (numeric value)
852 853 854 |
# File 'lib/opennebula/virtual_machine.rb', line 852 def deploy_id self['DEPLOY_ID'] end |
#disk_attach(disk_template) ⇒ nil, OpenNebula::Error Also known as: attachdisk
Attaches a disk to a running VM
437 438 439 |
# File 'lib/opennebula/virtual_machine.rb', line 437 def disk_attach(disk_template) return call(VM_METHODS[:attach], @pe_id, disk_template) end |
#disk_detach(disk_id) ⇒ nil, OpenNebula::Error Also known as: detachdisk
Detaches a disk from a running VM
448 449 450 |
# File 'lib/opennebula/virtual_machine.rb', line 448 def disk_detach(disk_id) return call(VM_METHODS[:detach], @pe_id, disk_id) end |
#disk_resize(disk_id, size) ⇒ nil, OpenNebula::Error
Changes the size of a disk
732 733 734 |
# File 'lib/opennebula/virtual_machine.rb', line 732 def disk_resize(disk_id, size) return call(VM_METHODS[:diskresize], @pe_id, disk_id, size.to_s) end |
#disk_saveas(disk_id, image_name, image_type = "", snap_id = -1)) ⇒ Integer, OpenNebula::Error
Set the specified vm’s disk to be saved as a new image
current disk image state
554 555 556 557 558 559 560 561 562 563 564 |
# File 'lib/opennebula/virtual_machine.rb', line 554 def disk_saveas(disk_id, image_name, image_type="", snap_id=-1) return Error.new('ID not defined') if !@pe_id rc = @client.call(VM_METHODS[:disksaveas], @pe_id, disk_id, image_name, image_type, snap_id) return rc end |
#disk_snapshot_create(disk_id, name) ⇒ Integer, OpenNebula::Error
Takes a new snapshot of a disk
688 689 690 |
# File 'lib/opennebula/virtual_machine.rb', line 688 def disk_snapshot_create(disk_id, name) return call(VM_METHODS[:disksnapshotcreate], @pe_id, disk_id, name) end |
#disk_snapshot_delete(disk_id, snap_id) ⇒ nil, OpenNebula::Error
Deletes a disk snapshot
710 711 712 |
# File 'lib/opennebula/virtual_machine.rb', line 710 def disk_snapshot_delete(disk_id, snap_id) return call(VM_METHODS[:disksnapshotdelete], @pe_id, disk_id, snap_id) end |
#disk_snapshot_rename(disk_id, snap_id, new_name) ⇒ nil, OpenNebula::Error
Renames a disk snapshot
722 723 724 |
# File 'lib/opennebula/virtual_machine.rb', line 722 def disk_snapshot_rename(disk_id, snap_id, new_name) return call(VM_METHODS[:disksnapshotrename], @pe_id, disk_id, snap_id, new_name) end |
#disk_snapshot_revert(disk_id, snap_id) ⇒ nil, OpenNebula::Error
Reverts disk state to a previously taken snapshot
699 700 701 |
# File 'lib/opennebula/virtual_machine.rb', line 699 def disk_snapshot_revert(disk_id, snap_id) return call(VM_METHODS[:disksnapshotrevert], @pe_id, disk_id, snap_id) end |
#get_history_record(seq) ⇒ Object
856 857 858 |
# File 'lib/opennebula/virtual_machine.rb', line 856 def get_history_record(seq) retrieve_xmlelements('//HISTORY')[seq].to_xml end |
#gid ⇒ Object
Returns the group identifier
- return
-
Integer the element’s group ID
847 848 849 |
# File 'lib/opennebula/virtual_machine.rb', line 847 def gid self['GID'].to_i end |
#hold ⇒ Object
Sets a VM to hold state, scheduler will not deploy it
408 409 410 |
# File 'lib/opennebula/virtual_machine.rb', line 408 def hold action('hold') end |
#info(decrypt = false) ⇒ Object Also known as: info!
Retrieves the information of the given VirtualMachine.
303 304 305 |
# File 'lib/opennebula/virtual_machine.rb', line 303 def info(decrypt = false) super(VM_METHODS[:info], 'VM', decrypt) end |
#lcm_state ⇒ Object
Returns the LCM state of the VirtualMachine (numeric value)
825 826 827 |
# File 'lib/opennebula/virtual_machine.rb', line 825 def lcm_state self['LCM_STATE'].to_i end |
#lcm_state_str ⇒ Object
Returns the LCM state of the VirtualMachine (string value)
830 831 832 |
# File 'lib/opennebula/virtual_machine.rb', line 830 def lcm_state_str LCM_STATE[lcm_state] end |
#live_migrate(host_id, enforce = false) ⇒ Object
use #migrate instead
538 539 540 |
# File 'lib/opennebula/virtual_machine.rb', line 538 def live_migrate(host_id, enforce=false) migrate(host_id, true, enforce) end |
#migrate(host_id, live = false, enforce = false, ds_id = -1,, mtype = 0) ⇒ nil, OpenNebula::Error
Moves a running VM to the specified host. With live=true the migration is done withdout downtime.
532 533 534 535 |
# File 'lib/opennebula/virtual_machine.rb', line 532 def migrate(host_id, live=false, enforce=false, ds_id=-1, mtype=0) call(VM_METHODS[:migrate], @pe_id, host_id.to_i, live==true, enforce, ds_id.to_i, mtype) end |
#monitoring(xpath_expressions) ⇒ Hash<String, Array<Array<int>>>, OpenNebula::Error
Retrieves this VM’s monitoring data from OpenNebula
626 627 628 |
# File 'lib/opennebula/virtual_machine.rb', line 626 def monitoring(xpath_expressions) return super(VM_METHODS[:monitoring], xpath_expressions) end |
#monitoring_xml ⇒ String
Retrieves this VM’s monitoring data from OpenNebula, in XML
633 634 635 636 637 |
# File 'lib/opennebula/virtual_machine.rb', line 633 def monitoring_xml() return Error.new('ID not defined') if !@pe_id return @client.call(VM_METHODS[:monitoring], @pe_id) end |
#nic_attach(nic_template) ⇒ nil, OpenNebula::Error
Attaches a NIC to a running VM
459 460 461 |
# File 'lib/opennebula/virtual_machine.rb', line 459 def nic_attach(nic_template) return call(VM_METHODS[:attachnic], @pe_id, nic_template) end |
#nic_detach(nic_id) ⇒ nil, OpenNebula::Error
Detaches a NIC from a running VM
468 469 470 |
# File 'lib/opennebula/virtual_machine.rb', line 468 def nic_detach(nic_id) return call(VM_METHODS[:detachnic], @pe_id, nic_id) end |
#nic_update(nic_id, nic_template, append = false) ⇒ nil, OpenNebula::Error
Updates a NIC for a running VM
480 481 482 |
# File 'lib/opennebula/virtual_machine.rb', line 480 def nic_update(nic_id, nic_template, append = false) return call(VM_METHODS[:updatenic], @pe_id, nic_id, nic_template, append ? 1 : 0) end |
#poweroff(hard = false) ⇒ Object
Powers off a running VM
398 399 400 |
# File 'lib/opennebula/virtual_machine.rb', line 398 def poweroff(hard=false) action(hard ? 'poweroff-hard' : 'poweroff') end |
#reboot(hard = false) ⇒ Object
Reboots an already deployed VM
403 404 405 |
# File 'lib/opennebula/virtual_machine.rb', line 403 def reboot(hard=false) action(hard ? 'reboot-hard' : 'reboot') end |
#recover(result) ⇒ nil, OpenNebula::Error
Recovers an ACTIVE VM
retry (2), delete (3), delete-recreate (4), delete-db (5)
743 744 745 |
# File 'lib/opennebula/virtual_machine.rb', line 743 def recover(result) return call(VM_METHODS[:recover], @pe_id, result) end |
#release ⇒ Object
Releases a VM from hold state
413 414 415 |
# File 'lib/opennebula/virtual_machine.rb', line 413 def release action('release') end |
#rename(name) ⇒ nil, OpenNebula::Error
Renames this VM
645 646 647 |
# File 'lib/opennebula/virtual_machine.rb', line 645 def rename(name) return call(VM_METHODS[:rename], @pe_id, name) end |
#replace(opts = {}) ⇒ Object
354 355 356 |
# File 'lib/opennebula/virtual_machine.rb', line 354 def replace(opts = {}) super(opts, "USER_TEMPLATE") end |
#resched ⇒ Object
Sets the re-scheduling flag for the VM
504 505 506 |
# File 'lib/opennebula/virtual_machine.rb', line 504 def resched action('resched') end |
#resize(capacity_template, enforce) ⇒ nil, OpenNebula::Error
Resize the VM
577 578 579 |
# File 'lib/opennebula/virtual_machine.rb', line 577 def resize(capacity_template, enforce) return call(VM_METHODS[:resize], @pe_id, capacity_template, enforce) end |
#resume ⇒ Object
Resumes the execution of a saved VM
428 429 430 |
# File 'lib/opennebula/virtual_machine.rb', line 428 def resume action('resume') end |
#sched_action_add(sched_template) ⇒ nil, OpenNebula::Error
Add sched actions
777 778 779 |
# File 'lib/opennebula/virtual_machine.rb', line 777 def sched_action_add(sched_template) return call(VM_METHODS[:schedadd], @pe_id, sched_template) end |
#sched_action_delete(sched_id) ⇒ nil, OpenNebula::Error
Delete sched action
786 787 788 |
# File 'lib/opennebula/virtual_machine.rb', line 786 def sched_action_delete(sched_id) return call(VM_METHODS[:scheddelete], @pe_id, sched_id.to_i) end |
#sched_action_update(sched_id, sched_template) ⇒ nil, OpenNebula::Error
Update sched_action
796 797 798 799 |
# File 'lib/opennebula/virtual_machine.rb', line 796 def sched_action_update(sched_id, sched_template) return call(VM_METHODS[:schedupdate], @pe_id, sched_id.to_i, sched_template) end |
#sg_attach(nic_id, sg_id) ⇒ nil, OpenNebula::Error
Attaches a Security Groupt to a running VM
490 491 492 |
# File 'lib/opennebula/virtual_machine.rb', line 490 def sg_attach(nic_id, sg_id) return call(VM_METHODS[:attachsg], @pe_id, nic_id, sg_id) end |
#sg_detach(nic_id, sg_id) ⇒ nil, OpenNebula::Error
Detaches a Security Group from a running VM
499 500 501 |
# File 'lib/opennebula/virtual_machine.rb', line 499 def sg_detach(nic_id, sg_id) return call(VM_METHODS[:detachsg], @pe_id, nic_id, sg_id) end |
#snapshot_create(name = "") ⇒ Integer, OpenNebula::Error
Creates a new VM snapshot
655 656 657 658 659 660 |
# File 'lib/opennebula/virtual_machine.rb', line 655 def snapshot_create(name="") return Error.new('ID not defined') if !@pe_id name ||= "" return @client.call(VM_METHODS[:snapshotcreate], @pe_id, name) end |
#snapshot_delete(snap_id) ⇒ nil, OpenNebula::Error
Deletes a VM snapshot
678 679 680 |
# File 'lib/opennebula/virtual_machine.rb', line 678 def snapshot_delete(snap_id) return call(VM_METHODS[:snapshotdelete], @pe_id, snap_id) end |
#snapshot_revert(snap_id) ⇒ nil, OpenNebula::Error
Reverts to a snapshot
668 669 670 |
# File 'lib/opennebula/virtual_machine.rb', line 668 def snapshot_revert(snap_id) return call(VM_METHODS[:snapshotrevert], @pe_id, snap_id) end |
#state ⇒ Object
Returns the VM state of the VirtualMachine (numeric value)
815 816 817 |
# File 'lib/opennebula/virtual_machine.rb', line 815 def state self['STATE'].to_i end |
#state_str ⇒ Object
Returns the VM state of the VirtualMachine (string value)
820 821 822 |
# File 'lib/opennebula/virtual_machine.rb', line 820 def state_str VM_STATE[state] end |
#status ⇒ Object
Returns the short status string for the VirtualMachine
835 836 837 838 839 840 841 842 843 |
# File 'lib/opennebula/virtual_machine.rb', line 835 def status short_state_str=SHORT_VM_STATES[state_str] if short_state_str=="actv" short_state_str=SHORT_LCM_STATES[lcm_state_str] end short_state_str end |
#stop ⇒ Object
Stops a running VM
418 419 420 |
# File 'lib/opennebula/virtual_machine.rb', line 418 def stop action('stop') end |
#suspend ⇒ Object
Saves a running VM
423 424 425 |
# File 'lib/opennebula/virtual_machine.rb', line 423 def suspend action('suspend') end |
#terminate(hard = false) ⇒ Object Also known as: shutdown
Shutdowns an already deployed VM
386 387 388 |
# File 'lib/opennebula/virtual_machine.rb', line 386 def terminate(hard=false) action(hard ? 'terminate-hard' : 'terminate') end |
#undeploy(hard = false) ⇒ Object
Shuts down an already deployed VM, saving its state in the system DS
393 394 395 |
# File 'lib/opennebula/virtual_machine.rb', line 393 def undeploy(hard=false) action(hard ? 'undeploy-hard' : 'undeploy') end |
#unresched ⇒ Object
Unsets the re-scheduling flag for the VM
509 510 511 |
# File 'lib/opennebula/virtual_machine.rb', line 509 def unresched action('unresched') end |
#update(new_template = nil, append = false) ⇒ nil, OpenNebula::Error
Replaces the template contents
330 331 332 |
# File 'lib/opennebula/virtual_machine.rb', line 330 def update(new_template=nil, append=false) super(VM_METHODS[:update], new_template, append ? 1 : 0) end |
#updateconf(new_conf, append = false) ⇒ nil, OpenNebula::Error
Changes the attributes of a VM in power off, failure and undeploy
states
768 769 770 |
# File 'lib/opennebula/virtual_machine.rb', line 768 def updateconf(new_conf, append = false) return call(VM_METHODS[:updateconf], @pe_id, new_conf, append ? 1 : 0) end |
#user_template_str(indent = true) ⇒ String
Returns the <USER_TEMPLATE> element in text form
339 340 341 |
# File 'lib/opennebula/virtual_machine.rb', line 339 def user_template_str(indent=true) template_like_str('USER_TEMPLATE', indent) end |
#user_template_xml ⇒ String
Returns the <USER_TEMPLATE> element in XML form
346 347 348 349 350 351 352 |
# File 'lib/opennebula/virtual_machine.rb', line 346 def user_template_xml if NOKOGIRI @xml.xpath('USER_TEMPLATE').to_s else @xml.elements['USER_TEMPLATE'].to_s end end |
#wait_state(state, timeout = 120) ⇒ Object
860 861 862 863 864 865 866 867 868 869 870 |
# File 'lib/opennebula/virtual_machine.rb', line 860 def wait_state(state, timeout=120) require 'opennebula/wait_ext' extend OpenNebula::WaitExt rc = wait2(state, 'LCM_INIT', timeout) return Error.new("Timeout expired for state #{state}.") unless rc true end |
#wait_state2(state, lcm_state, timeout = 120) ⇒ Object
872 873 874 875 876 877 878 879 880 |
# File 'lib/opennebula/virtual_machine.rb', line 872 def wait_state2(state, lcm_state, timeout=120) extend OpenNebula::WaitExt rc = wait2(state, lcm_state, timeout) return Error.new("Timeout expired for state #{state}.") unless rc true end |