File: cached_ovf_deploy.rb

package info (click to toggle)
ruby-rbvmomi 1.8.2-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 1,756 kB
  • sloc: ruby: 5,590; sh: 36; makefile: 7
file content (120 lines) | stat: -rw-r--r-- 3,248 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#!/usr/bin/env ruby
require 'trollop'
require 'rbvmomi'
require 'rbvmomi/trollop'
require 'rbvmomi/utils/deploy'
require 'rbvmomi/utils/admission_control'
require 'yaml'

VIM = RbVmomi::VIM

opts = Trollop.options do
  banner <<-EOS
Deploy an OVF to a cluster, using a cached template if available.

Usage:
    cached_ovf_deploy.rb [options] <vmname> <ovfurl>

VIM connection options:
    EOS

    rbvmomi_connection_opts

    text <<-EOS

VM location options:
    EOS

    rbvmomi_datacenter_opt
    rbvmomi_datastore_opt

    text <<-EOS

Other options:
  EOS

  opt :template_name, "Name to give to the (cached) template", :type => :string
  opt :template_path, "Path where templates are stored", :default => 'templates', :type => :string
  opt :computer_path, "Path to the cluster to deploy into", :type => :string
  opt :network, "Name of the network to attach template to", :type => :string
  opt :vm_folder_path, "Path to VM folder to deploy VM into", :type => :string
  opt :lease, "Lease in days", :type => :int, :default => 3
end

Trollop.die("must specify host") unless opts[:host]
Trollop.die("no cluster path given") unless opts[:computer_path]
template_folder_path = opts[:template_path]
template_name = opts[:template_name] or Trollop.die("no template name given")
vm_name = ARGV[0] or Trollop.die("no VM name given")
ovf_url = ARGV[1] or Trollop.die("No OVF URL given")

vim = VIM.connect opts
dc = vim.serviceInstance.find_datacenter(opts[:datacenter]) or abort "datacenter not found"

root_vm_folder = dc.vmFolder
vm_folder = root_vm_folder
if opts[:vm_folder_path]
  vm_folder = root_vm_folder.traverse(opts[:vm_folder_path], VIM::Folder)
end
template_folder = root_vm_folder.traverse!(template_folder_path, VIM::Folder)

scheduler = AdmissionControlledResourceScheduler.new(
  vim,
  :datacenter => dc,
  :computer_names => [opts[:computer_path]],
  :vm_folder => vm_folder,
  :rp_path => '/',
  :datastore_paths => [opts[:datastore]],
  :max_vms_per_pod => nil, # No limits
  :min_ds_free => nil, # No limits
)
scheduler.make_placement_decision

datastore = scheduler.datastore
computer = scheduler.pick_computer
# XXX: Do this properly
if opts[:network]
  network = computer.network.find{|x| x.name == opts[:network]}
else
  network = computer.network[0]
end

lease_tool = LeaseTool.new
lease = opts[:lease] * 24 * 60 * 60
deployer = CachedOvfDeployer.new(
  vim, network, computer, template_folder, vm_folder, datastore
)
template = deployer.lookup_template template_name

if !template
  puts "#{Time.now}: Uploading/Preparing OVF template ..."
  
  template = deployer.upload_ovf_as_template(
    ovf_url, template_name,
    :run_without_interruptions => true,
    :config => lease_tool.set_lease_in_vm_config({}, lease)
  )
end

puts "#{Time.now}: Cloning template ..."
config = {
  :numCPUs => opts[:cpus],
  :memoryMB => opts[:memory],
}
config = lease_tool.set_lease_in_vm_config(config, lease)
vm = deployer.linked_clone template, vm_name, config

puts "#{Time.now}: Powering On VM ..."
# XXX: Add a retrying version?
vm.PowerOnVM_Task.wait_for_completion

puts "#{Time.now}: Waiting for VM to be up ..."
ip = nil
while !(ip = vm.guest_ip)
  sleep 5
end

puts "#{Time.now}: VM got IP: #{ip}"

puts "#{Time.now}: Done"