class OpenNebula::VirtualMachine
Constants
- EXTERNAL_IP_ATTRS
- HISTORY_ACTION
- LCM_STATE
- MIGRATE_REASON
- SHORT_LCM_STATES
- SHORT_MIGRATE_REASON
- SHORT_VM_STATES
- VM_METHODS
Constants and Class Methods
- VM_STATE
Public Class Methods
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:
vnet = VirtualMachine.new(VirtualMachine.build_xml(3),rpc_client)
# File lib/opennebula/virtual_machine.rb, line 221 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
# File lib/opennebula/virtual_machine.rb, line 238 def VirtualMachine.get_history_action(action) return HISTORY_ACTION[action.to_i] end
# File lib/opennebula/virtual_machine.rb, line 231 def VirtualMachine.get_reason(reason) reason=MIGRATE_REASON[reason.to_i] reason_str=SHORT_MIGRATE_REASON[reason] reason_str end
Class constructor
# File lib/opennebula/virtual_machine.rb, line 243 def initialize(xml, client) super(xml,client) end
Public Instance Methods
Allocates a new VirtualMachine in OpenNebula
@param description [String] A string containing the template of
the VirtualMachine.
@param hold [true,false] false to create the VM in pending state,
true to create it on hold
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 267 def allocate(description, hold=false) super(VM_METHODS[:allocate], description, hold) end
@deprecated use {#shutdown}
# File lib/opennebula/virtual_machine.rb, line 352 def cancel shutdown(true) end
Changes the permissions. Each [Integer] argument must be 1 to allow, 0 deny, -1 do not change
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 536 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
Changes the permissions.
@param octet [String] Permissions octed , e.g. 640 @return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 527 def chmod_octet(octet) super(VM_METHODS[:chmod], octet) end
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
# File lib/opennebula/virtual_machine.rb, line 518 def chown(uid, gid) super(VM_METHODS[:chown], uid, gid) end
Deletes a VM from the pool
# File lib/opennebula/virtual_machine.rb, line 422 def delete(recreate=false) if recreate action('delete-recreate') else action('delete') end end
Initiates the instance of the VM on the target host.
@param host_id [Interger] The host id (hid) of the target host where
the VM will be instantiated.
@param enforce [true|false] If it is set to true, the host capacity
will be checked, and the deployment will fail if the host is overcommited. Defaults to false
@param ds_id [Integer] The System Datastore where to deploy the VM. To
use the default, set it to -1
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 316 def deploy(host_id, enforce=false, ds_id=-1) enforce ||= false ds_id ||= -1 return call(VM_METHODS[:deploy], @pe_id, host_id.to_i, enforce, ds_id.to_i) end
Returns the #deploy_id of the VirtualMachine (numeric value)
# File lib/opennebula/virtual_machine.rb, line 701 def deploy_id self['DEPLOY_ID'] end
Attaches a disk to a running VM
@param disk_template [String] Template containing a DISK element @return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 386 def disk_attach(disk_template) return call(VM_METHODS[:attach], @pe_id, disk_template) end
Detaches a disk from a running VM
@param disk_id [Integer] Id of the disk to be detached @return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 397 def disk_detach(disk_id) return call(VM_METHODS[:detach], @pe_id, disk_id) end
Set the specified vm's disk to be saved as a new image
@param disk_id [Integer] ID of the disk to be saved @param image_name [String] Name for the new image where the
disk will be saved
@param image_type [String] Type of the new image. Set to empty string
to use the default type
@param snap_id [Integer] ID of the snapshot to save, -1 to use the current disk image state
@return [Integer, OpenNebula::Error] the new Image ID in case of
success, error otherwise
# File lib/opennebula/virtual_machine.rb, line 487 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
Takes a new snapshot of a disk
@param disk_id [Integer] Id of the disk @param name [String] description for the snapshot
@return [Integer, OpenNebula::Error] The new snapshot ID or error
# File lib/opennebula/virtual_machine.rb, line 622 def disk_snapshot_create(disk_id, name) return call(VM_METHODS[:disksnapshotcreate], @pe_id, disk_id, name) end
Deletes a disk snapshot
@param disk_id [Integer] Id of the disk @param snap_id [Integer] Id of the snapshot
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 644 def disk_snapshot_delete(disk_id, snap_id) return call(VM_METHODS[:disksnapshotdelete], @pe_id, disk_id, snap_id) end
Reverts disk state to a previously taken snapshot
@param disk_id [Integer] Id of the disk @param snap_id [Integer] Id of the snapshot
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 633 def disk_snapshot_revert(disk_id, snap_id) return call(VM_METHODS[:disksnapshotrevert], @pe_id, disk_id, snap_id) end
@deprecated use {#delete} instead
# File lib/opennebula/virtual_machine.rb, line 431 def finalize(recreate=false) delete(recreate) end
Returns the group identifier
- return
-
Integer the element's group ID
# File lib/opennebula/virtual_machine.rb, line 696 def gid self['GID'].to_i end
Sets a VM to hold state, scheduler will not deploy it
# File lib/opennebula/virtual_machine.rb, line 357 def hold action('hold') end
Retrieves the information of the given VirtualMachine.
# File lib/opennebula/virtual_machine.rb, line 252 def info() super(VM_METHODS[:info], 'VM') end
Returns the #deploy_id of the VirtualMachine (numeric value)
# File lib/opennebula/virtual_machine.rb, line 706 def keep_disks? !self['USER_TEMPLATE/KEEP_DISKS_ON_DONE'].nil? && self['USER_TEMPLATE/KEEP_DISKS_ON_DONE'].downcase=="yes" end
Returns the LCM state of the VirtualMachine (numeric value)
# File lib/opennebula/virtual_machine.rb, line 674 def lcm_state self['LCM_STATE'].to_i end
Returns the LCM state of the VirtualMachine (string value)
# File lib/opennebula/virtual_machine.rb, line 679 def lcm_state_str LCM_STATE[lcm_state] end
@deprecated use {#migrate} instead
# File lib/opennebula/virtual_machine.rb, line 471 def live_migrate(host_id, enforce=false) migrate(host_id, true, enforce) end
Moves a running VM to the specified host. With live=true the migration is done withdout downtime.
@param host_id [Interger] The host id (hid) of the target host where
the VM will be migrated.
@param live [true|false] If true the migration is done without
downtime. Defaults to false
@param enforce [true|false] If it is set to true, the host capacity
will be checked, and the deployment will fail if the host is overcommited. Defaults to false
@param ds_id [Integer] The System Datastore where to migrate the VM.
To use the current one, set it to -1
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 465 def migrate(host_id, live=false, enforce=false, ds_id=-1) call(VM_METHODS[:migrate], @pe_id, host_id.to_i, live==true, enforce, ds_id.to_i) end
Retrieves this VM's monitoring data from OpenNebula
@param [Array<String>] xpath_expressions Elements to retrieve.
@return [Hash<String, Array<Array<int>>>, OpenNebula::Error] Hash with
the requested xpath expressions, and an Array of 'timestamp, value'.
@example
vm.monitoring( ['MONITORING/CPU', 'MONITORING/NETTX'] ) { "MONITORING/CPU"=>[["1435085098", "47"], ["1435085253", "5"], ["1435085410", "48"], ["1435085566", "3"], ["1435088136", "2"]], "MONITORING/NETTX"=>[["1435085098", "0"], ["1435085253", "50"], ["1435085410", "50"], ["1435085566", "50"], ["1435085723", "50"]] }
# File lib/opennebula/virtual_machine.rb, line 559 def monitoring(xpath_expressions) return super(VM_METHODS[:monitoring], 'VM', 'LAST_POLL', xpath_expressions) end
Retrieves this VM's monitoring data from OpenNebula, in XML
@return [String] VM monitoring data, in XML
# File lib/opennebula/virtual_machine.rb, line 567 def monitoring_xml() return Error.new('ID not defined') if !@pe_id return @client.call(VM_METHODS[:monitoring], @pe_id) end
Attaches a NIC to a running VM
@param nic_template [String] Template containing a NIC element @return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 408 def nic_attach(nic_template) return call(VM_METHODS[:attachnic], @pe_id, nic_template) end
Detaches a NIC from a running VM
@param nic_id [Integer] Id of the NIC to be detached @return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 417 def nic_detach(nic_id) return call(VM_METHODS[:detachnic], @pe_id, nic_id) end
Powers off a running VM
# File lib/opennebula/virtual_machine.rb, line 337 def poweroff(hard=false) action(hard ? 'poweroff-hard' : 'poweroff') end
Reboots an already deployed VM
# File lib/opennebula/virtual_machine.rb, line 342 def reboot(hard=false) action(hard ? 'reboot-hard' : 'reboot') end
Recovers an ACTIVE VM
@param result [Integer] Recover with failure (0), success (1) or retry (2) @param result [info] Additional information needed to recover the VM @return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 655 def recover(result) return call(VM_METHODS[:recover], @pe_id, result) end
Releases a VM from hold state
# File lib/opennebula/virtual_machine.rb, line 362 def release action('release') end
Renames this VM
@param name [String] New name for the VM.
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 579 def rename(name) return call(VM_METHODS[:rename], @pe_id, name) end
Sets the re-scheduling flag for the VM
# File lib/opennebula/virtual_machine.rb, line 441 def resched action('resched') end
@deprecated use {#reboot}
# File lib/opennebula/virtual_machine.rb, line 347 def reset reboot(true) end
Resize the VM
@param capacity_template [String] Template containing the new capacity
elements CPU, VCPU, MEMORY. If one of them is not present, or its value is 0, it will not be resized
@param enforce [true|false] If it is set to true, the host capacity
will be checked. This will only affect oneadmin requests, regular users resize requests will always be enforced
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 510 def resize(capacity_template, enforce) return call(VM_METHODS[:resize], @pe_id, capacity_template, enforce) end
@deprecated use {#delete} instead
# File lib/opennebula/virtual_machine.rb, line 436 def resubmit action('delete-recreate') end
Resumes the execution of a saved VM
# File lib/opennebula/virtual_machine.rb, line 377 def resume action('resume') end
Clones the VM's source Template, replacing the disks with live snapshots of the current disks. The VM capacity and NICs are also preserved
@param name [String] Name for the new Template @param name [true,false,nil] Optional, true to make the saved images persistent, false make them non-persistent
@return [Integer, OpenNebula::Error] the new Template ID in case of
success, error otherwise
# File lib/opennebula/virtual_machine.rb, line 720 def save_as_template(name, persistent=nil) img_ids = [] new_tid = nil begin rc = info() raise if OpenNebula.is_error?(rc) tid = self['TEMPLATE/TEMPLATE_ID'] if tid.nil? || tid.empty? rc = Error.new('VM has no template to be saved') raise end if state_str() != "POWEROFF" rc = Error.new("VM state must be POWEROFF, "<< "current state is #{state_str()}, #{lcm_state_str()}") raise end # Clone the source template rc = OpenNebula::Template.new_with_id(tid, @client).clone(name) raise if OpenNebula.is_error?(rc) new_tid = rc # Replace the original template's capacity with the actual VM values replace = "" cpu = self['TEMPLATE/CPU'] if !cpu.nil? && !cpu.empty? replace << "CPU = #{cpu}\n" end vcpu = self['TEMPLATE/VCPU'] if !vcpu.nil? && !vcpu.empty? replace << "VCPU = #{vcpu}\n" end mem = self['TEMPLATE/MEMORY'] if !mem.nil? && !mem.empty? replace << "MEMORY = #{mem}\n" end self.each('TEMPLATE/DISK') do |disk| # While the previous snapshot is still in progress, we wait # indefinitely rc = info() raise if OpenNebula.is_error?(rc) steps = 0 while lcm_state_str() == "HOTPLUG_SAVEAS_POWEROFF" if steps < 30 sleep 1 else sleep 15 end rc = info() raise if OpenNebula.is_error?(rc) steps += 1 end # If the VM is not busy with a previous disk snapshot, we wait # but this time with a timeout rc = wait_state("POWEROFF") raise if OpenNebula.is_error?(rc) disk_id = disk["DISK_ID"] if disk_id.nil? || disk_id.empty? rc = Error.new('The DISK_ID is missing from the VM template') raise end image_id = disk["IMAGE_ID"] if !image_id.nil? && !image_id.empty? rc = disk_saveas(disk_id.to_i,"#{name}-disk-#{disk_id}","",-1) raise if OpenNebula.is_error?(rc) if persistent == true OpenNebula::Image.new_with_id(rc.to_i, @client).persistent() end img_ids << rc.to_i replace << "DISK = [ IMAGE_ID = #{rc} ]\n" else # Volatile disks cannot be saved, so the definition is copied replace << self.template_like_str( "TEMPLATE", true, "DISK[DISK_ID=#{disk_id}]") << "\n" end end self.each('TEMPLATE/NIC') do |nic| nic_id = nic["NIC_ID"] if nic_id.nil? || nic_id.empty? rc = Error.new('The NIC_ID is missing from the VM template') raise end net_id = nic["NETWORK_ID"] if !net_id.nil? && !net_id.empty? replace << "NIC = [ NETWORK_ID = #{net_id} ]\n" else # This NIC does not use a Virtual Network replace << self.template_like_str( "TEMPLATE", true, "NIC[NIC_ID=#{nic_id}]") << "\n" end end # Required by the Sunstone Cloud View replace << "SAVED_TEMPLATE_ID = #{tid}\n" new_tmpl = OpenNebula::Template.new_with_id(new_tid, @client) rc = new_tmpl.update(replace, true) raise if OpenNebula.is_error?(rc) return new_tid rescue # Rollback. Delete the template and the images created if !new_tid.nil? new_tmpl = OpenNebula::Template.new_with_id(new_tid, @client) new_tmpl.delete() end img_ids.each do |id| img = OpenNebula::Image.new_with_id(id, @client) img.delete() end return rc end end
Shutdowns an already deployed VM
# File lib/opennebula/virtual_machine.rb, line 327 def shutdown(hard=false) action(hard ? 'shutdown-hard' : 'shutdown') end
Creates a new VM snapshot
@param name [String] Name for the snapshot.
@return [Integer, OpenNebula::Error] The new snaphost ID in case
of success, Error otherwise
# File lib/opennebula/virtual_machine.rb, line 589 def snapshot_create(name="") return Error.new('ID not defined') if !@pe_id name ||= "" return @client.call(VM_METHODS[:snapshotcreate], @pe_id, name) end
Deletes a VM snapshot
@param snap_id [Integer] Id of the snapshot
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 612 def snapshot_delete(snap_id) return call(VM_METHODS[:snapshotdelete], @pe_id, snap_id) end
Reverts to a snapshot
@param snap_id [Integer] Id of the snapshot
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 602 def snapshot_revert(snap_id) return call(VM_METHODS[:snapshotrevert], @pe_id, snap_id) end
Returns the VM state of the VirtualMachine (numeric value)
# File lib/opennebula/virtual_machine.rb, line 664 def state self['STATE'].to_i end
Returns the VM state of the VirtualMachine (string value)
# File lib/opennebula/virtual_machine.rb, line 669 def state_str VM_STATE[state] end
Returns the short status string for the VirtualMachine
# File lib/opennebula/virtual_machine.rb, line 684 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
Stops a running VM
# File lib/opennebula/virtual_machine.rb, line 367 def stop action('stop') end
Saves a running VM
# File lib/opennebula/virtual_machine.rb, line 372 def suspend action('suspend') end
Shuts down an already deployed VM, saving its state in the system DS
# File lib/opennebula/virtual_machine.rb, line 332 def undeploy(hard=false) action(hard ? 'undeploy-hard' : 'undeploy') end
Unsets the re-scheduling flag for the VM
# File lib/opennebula/virtual_machine.rb, line 446 def unresched action('unresched') end
Replaces the template contents
@param new_template [String] New template contents @param append [true, false] True to append new attributes instead of
replace the whole template
@return [nil, OpenNebula::Error] nil in case of success, Error
otherwise
# File lib/opennebula/virtual_machine.rb, line 279 def update(new_template=nil, append=false) super(VM_METHODS[:update], new_template, append ? 1 : 0) end
Returns the <USER_TEMPLATE> element in text form
@param indent [true,false] indents the resulting string, defaults to true
@return [String] The USER_TEMPLATE
# File lib/opennebula/virtual_machine.rb, line 288 def user_template_str(indent=true) template_like_str('USER_TEMPLATE', indent) end
Returns the <USER_TEMPLATE> element in XML form
@return [String] The USER_TEMPLATE
# File lib/opennebula/virtual_machine.rb, line 295 def user_template_xml if NOKOGIRI @xml.xpath('USER_TEMPLATE').to_s else @xml.elements['USER_TEMPLATE'].to_s end end
Private Instance Methods
# File lib/opennebula/virtual_machine.rb, line 861 def action(name) return Error.new('ID not defined') if !@pe_id rc = @client.call(VM_METHODS[:action], name, @pe_id) rc = nil if !OpenNebula.is_error?(rc) return rc end
# File lib/opennebula/virtual_machine.rb, line 892 def wait_lcm_state(state, timeout=10) vm_state = "" lcm_state = "" timeout.times do rc = info() return rc if OpenNebula.is_error?(rc) vm_state = state_str() lcm_state = lcm_state_str() if lcm_state == state return true end sleep 1 end return Error.new("Timeout expired for state #{state}. "<< "VM is in state #{vm_state}, #{lcm_state}") end
# File lib/opennebula/virtual_machine.rb, line 870 def wait_state(state, timeout=10) vm_state = "" lcm_state = "" timeout.times do rc = info() return rc if OpenNebula.is_error?(rc) vm_state = state_str() lcm_state = lcm_state_str() if vm_state == state return true end sleep 1 end return Error.new("Timeout expired for state #{state}. "<< "VM is in state #{vm_state}, #{lcm_state}") end