Class: Chef::Knife::VsphereVmMigrate
- Inherits:
-
BaseVsphereCommand
- Object
- Chef::Knife
- BaseVsphereCommand
- Chef::Knife::VsphereVmMigrate
- Defined in:
- lib/chef/knife/vsphere_vm_migrate.rb
Overview
migrate vm to specified resource pool , datastore and host
Instance Method Summary collapse
Methods inherited from BaseVsphereCommand
#choose_datastore, common_options, #conn_opts, #datacenter, #fatal_exit, #find_all_in_folder, #find_datastore, #find_datastorecluster, #find_datastores_regex, #find_device, #find_folder, #find_in_folder, #find_network, #find_pool, #find_pool_folder, #find_pools_and_clusters, #get_config, #get_password_from_stdin, #get_path_to_object, #get_vm, #get_vms, #linux?, #number_to_human_size, #password, #tcp_test_port, #tcp_test_port_vm, #traverse_folders_for_computeresources, #traverse_folders_for_dc, #traverse_folders_for_pools, #traverse_folders_for_vm, #traverse_folders_for_vms, #vim_connection, #windows?
Methods inherited from Chef::Knife
Instance Method Details
#find_host_folder(folder, name) ⇒ Object
31 32 33 34 35 36 37 38 |
# File 'lib/chef/knife/vsphere_vm_migrate.rb', line 31 def find_host_folder(folder, name) folder.childEntity.each do |cluster| cluster.host.each do |host| return host if host.name == name end end nil end |
#run ⇒ Object
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/chef/knife/vsphere_vm_migrate.rb', line 40 def run $stdout.sync = true vmname = @name_args[0] if vmname.nil? show_usage fatal_exit('You must specify a virtual machine name') end vim_connection dc = datacenter folder = find_folder(get_config(:folder)) || dc.vmFolder vm = find_in_folder(folder, RbVmomi::VIM::VirtualMachine, vmname) || abort("VM #{vmname} not found") priority = config[:priority] dest_host = config[:dest_host] ndc = find_datastore(config[:dest_datastore]) || abort('dest-datastore not found') pool = find_pool(config[:resource_pool]) if config[:resource_pool] dest_host = find_host_folder(dc.hostFolder, dest_host) migrate_spec = RbVmomi::VIM.VirtualMachineRelocateSpec(datastore: ndc, pool: pool, host: dest_host) vm.RelocateVM_Task(spec: migrate_spec, priority: priority).wait_for_completion end |