bosh_vsphere_cpi 2.2.0 → 2.2.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,154 +1,5 @@
1
- require 'cloud/vsphere/resources/datacenter'
2
-
3
1
  module VSphereCloud
4
- class Resources
5
- include ObjectStringifier
6
- stringify_with :datacenter
7
- MEMORY_HEADROOM = 128
8
- DISK_HEADROOM = 1024
9
- STALE_TIMEOUT = 60
2
+ module Resources
10
3
  BYTES_IN_MB = 1024 * 1024
11
-
12
- attr_reader :drs_rules
13
-
14
- def initialize(datacenter, config)
15
- @datacenter = datacenter
16
- @config = config
17
- @logger = config.logger
18
- @last_update = 0
19
- @lock = Monitor.new
20
- @drs_rules = []
21
- end
22
-
23
- # Place the persistent datastore in the given datacenter and cluster with
24
- # the requested disk space.
25
- #
26
- # @param [String] cluster_name cluster name.
27
- # @param [Integer] disk_size_in_mb disk size in mb.
28
- # @return [Datastore?] datastore if it was placed succesfuly.
29
- def pick_persistent_datastore_in_cluster(cluster_name, disk_size_in_mb)
30
- @lock.synchronize do
31
- cluster = @datacenter.clusters[cluster_name]
32
- if cluster.nil?
33
- raise Bosh::Clouds::CloudError, "Couldn't find cluster '#{cluster_name}'. Found: #{@datacenter.clusters.values.map(&:name)}"
34
- end
35
-
36
- datastore = cluster.pick_persistent(disk_size_in_mb)
37
- datastore.allocate(disk_size_in_mb)
38
- datastore
39
- end
40
- end
41
-
42
- # Find a cluster for a vm with the requested memory and ephemeral storage, attempting
43
- # to allocate it near existing persistent disks.
44
- #
45
- # @param [Integer] requested_memory_in_mb requested memory.
46
- # @param [Integer] requested_ephemeral_disk_size_in_mb requested ephemeral storage.
47
- # @param [Array<Resources::Disk>] existing_persistent_disks existing persistent disks, if any.
48
- # @return [Cluster] selected cluster if the resources were placed successfully, otherwise raises.
49
- def pick_cluster_for_vm(requested_memory_in_mb, requested_ephemeral_disk_size_in_mb, existing_persistent_disks)
50
- @lock.synchronize do
51
- # calculate locality to prioritizing clusters that contain the most persistent data.
52
- clusters = @datacenter.clusters.values
53
- persistent_disk_index = PersistentDiskIndex.new(clusters, existing_persistent_disks)
54
-
55
- scored_clusters = clusters.map do |cluster|
56
- persistent_disk_not_in_this_cluster = existing_persistent_disks.reject do |disk|
57
- persistent_disk_index.clusters_connected_to_disk(disk).include?(cluster)
58
- end
59
-
60
- score = Scorer.score(
61
- @config.logger,
62
- cluster,
63
- requested_memory_in_mb,
64
- requested_ephemeral_disk_size_in_mb,
65
- persistent_disk_not_in_this_cluster.map(&:size_in_mb)
66
- )
67
-
68
- [cluster, score]
69
- end
70
-
71
- acceptable_clusters = scored_clusters.select { |_, score| score > 0 }
72
-
73
- @logger.debug("Acceptable clusters: #{acceptable_clusters.inspect}")
74
-
75
- if acceptable_clusters.empty?
76
- total_persistent_size = existing_persistent_disks.map(&:size_in_mb).inject(0, :+)
77
- cluster_infos = clusters.map { |cluster| describe_cluster(cluster) }
78
-
79
- raise "Unable to allocate vm with #{requested_memory_in_mb}mb RAM, " +
80
- "#{requested_ephemeral_disk_size_in_mb / 1024}gb ephemeral disk, " +
81
- "and #{total_persistent_size / 1024}gb persistent disk from any cluster.\n#{cluster_infos.join(", ")}."
82
- end
83
-
84
- acceptable_clusters = acceptable_clusters.sort_by do |cluster, _score|
85
- persistent_disk_index.disks_connected_to_cluster(cluster).map(&:size_in_mb).inject(0, :+)
86
- end.reverse
87
-
88
- if acceptable_clusters.any? { |cluster, _| persistent_disk_index.disks_connected_to_cluster(cluster).any? }
89
- @logger.debug('Choosing cluster with the greatest available disk')
90
- selected_cluster, _ = acceptable_clusters.first
91
- else
92
- @logger.debug('Choosing cluster by weighted random')
93
- selected_cluster = Util.weighted_random(acceptable_clusters)
94
- end
95
-
96
- @logger.debug("Selected cluster '#{selected_cluster.name}'")
97
-
98
- selected_cluster.allocate(requested_memory_in_mb)
99
- selected_cluster
100
- end
101
- end
102
-
103
- def describe_cluster(cluster)
104
- "#{cluster.name} has #{cluster.free_memory}mb/" +
105
- "#{cluster.total_free_ephemeral_disk_in_mb / 1024}gb/" +
106
- "#{cluster.total_free_persistent_disk_in_mb / 1024}gb"
107
- end
108
-
109
- def pick_ephemeral_datastore(cluster, disk_size_in_mb)
110
- @lock.synchronize do
111
- datastore = cluster.pick_ephemeral(disk_size_in_mb)
112
- datastore.allocate(disk_size_in_mb)
113
- datastore
114
- end
115
- end
116
-
117
- def pick_persistent_datastore(cluster, disk_size_in_mb)
118
- @lock.synchronize do
119
- datastore = cluster.pick_persistent(disk_size_in_mb)
120
- datastore.allocate(disk_size_in_mb)
121
- datastore
122
- end
123
- end
124
-
125
- private
126
-
127
- attr_reader :config, :datacenter
128
-
129
-
130
- class PersistentDiskIndex
131
- def initialize(clusters, existing_persistent_disks)
132
- @clusters_to_disks = Hash[*clusters.map do |cluster|
133
- [cluster, existing_persistent_disks.select { |disk| cluster_includes_datastore?(cluster, disk.datastore) }]
134
- end.flatten(1)]
135
-
136
- @disks_to_clusters = Hash[*existing_persistent_disks.map do |disk|
137
- [disk, clusters.select { |cluster| cluster_includes_datastore?(cluster, disk.datastore) }]
138
- end.flatten(1)]
139
- end
140
-
141
- def cluster_includes_datastore?(cluster, datastore)
142
- cluster.persistent(datastore.name) != nil
143
- end
144
-
145
- def disks_connected_to_cluster(cluster)
146
- @clusters_to_disks[cluster]
147
- end
148
-
149
- def clusters_connected_to_disk(disk)
150
- @disks_to_clusters[disk]
151
- end
152
- end
153
4
  end
154
5
  end
@@ -1,7 +1,7 @@
1
1
  module VSphereCloud
2
2
  class VmCreator
3
- def initialize(memory, disk_size_in_mb, cpu, nested_hardware_virtualization, placer, client, cloud_searcher, logger, cpi, agent_env, file_provider, disk_provider)
4
- @placer = placer
3
+ def initialize(memory, disk_size_in_mb, cpu, nested_hardware_virtualization, drs_rules, client, cloud_searcher, logger, cpi, agent_env, file_provider, datacenter, cluster=nil)
4
+ @drs_rules = drs_rules
5
5
  @client = client
6
6
  @cloud_searcher = cloud_searcher
7
7
  @logger = logger
@@ -12,9 +12,10 @@ module VSphereCloud
12
12
  @nested_hardware_virtualization = nested_hardware_virtualization
13
13
  @agent_env = agent_env
14
14
  @file_provider = file_provider
15
- @disk_provider = disk_provider
15
+ @datacenter = datacenter
16
+ @cluster = cluster
16
17
 
17
- @logger.debug("VM creator initialized with memory: #{@memory}, disk: #{@disk}, cpu: #{@cpu}, placer: #{@placer}")
18
+ @logger.debug("VM creator initialized with memory: #{@memory}, disk: #{@disk}, cpu: #{@cpu}")
18
19
  end
19
20
 
20
21
  def create(agent_id, stemcell_cid, networks, persistent_disk_cids, environment)
@@ -31,12 +32,15 @@ module VSphereCloud
31
32
  stemcell_size /= 1024 * 1024
32
33
 
33
34
  persistent_disk_cids ||= []
34
- persistent_disks = persistent_disk_cids.map { |cid| @disk_provider.find(cid) }
35
+ persistent_disks = persistent_disk_cids.map { |cid| @datacenter.find_disk(cid) }
35
36
 
36
37
  # need to include swap and linked clone log
37
38
  ephemeral_disk_size_in_mb = @disk_size_in_mb + @memory + stemcell_size
38
- cluster = @placer.pick_cluster_for_vm(@memory, ephemeral_disk_size_in_mb, persistent_disks)
39
- datastore = @placer.pick_ephemeral_datastore(cluster, ephemeral_disk_size_in_mb)
39
+ cluster = @cluster || @datacenter.pick_cluster_for_vm(@memory, ephemeral_disk_size_in_mb, persistent_disks)
40
+ if cluster.ephemeral_datastores.empty?
41
+ raise "Cluster '#{cluster.name}' has no ephemeral datastores"
42
+ end
43
+ datastore = @datacenter.pick_ephemeral_datastore(ephemeral_disk_size_in_mb, cluster.ephemeral_datastores.keys)
40
44
 
41
45
  vm_cid = "vm-#{SecureRandom.uuid}"
42
46
  @logger.info("Creating vm: #{vm_cid} on #{cluster.mob} stored in #{datastore.mob}")
@@ -54,20 +58,22 @@ module VSphereCloud
54
58
  config = VimSdk::Vim::Vm::ConfigSpec.new(config_hash)
55
59
  config.device_change = []
56
60
 
57
- ephemeral_disk = VSphereCloud::EphemeralDisk.new(@disk_size_in_mb, vm_cid, datastore)
58
- ephemeral_disk_config = ephemeral_disk.create_spec(replicated_stemcell_vm.system_disk.controller_key)
61
+ ephemeral_disk = Resources::EphemeralDisk.new(Resources::EphemeralDisk::DISK_NAME, @disk_size_in_mb, datastore, vm_cid)
62
+
63
+ ephemeral_disk_config = ephemeral_disk.create_disk_attachment_spec(replicated_stemcell_vm.system_disk.controller_key)
59
64
  config.device_change << ephemeral_disk_config
60
65
 
61
66
  dvs_index = {}
62
67
  networks.each_value do |network|
63
68
  v_network_name = network['cloud_properties']['name']
64
69
  network_mob = @client.find_by_inventory_path([cluster.datacenter.name, 'network', v_network_name])
65
- nic_config = @cpi.create_nic_config_spec(v_network_name, network_mob, replicated_stemcell_vm.pci_controller.key, dvs_index)
70
+ virtual_nic = Resources::Nic.create_virtual_nic(@cloud_searcher, v_network_name, network_mob, replicated_stemcell_vm.pci_controller.key, dvs_index)
71
+ nic_config = Resources::VM.create_add_device_spec(virtual_nic)
66
72
  config.device_change << nic_config
67
73
  end
68
74
 
69
75
  replicated_stemcell_vm.nics.each do |nic|
70
- nic_config = @cpi.create_delete_device_spec(nic)
76
+ nic_config = Resources::VM.create_delete_device_spec(nic)
71
77
  config.device_change << nic_config
72
78
  end
73
79
 
@@ -117,15 +123,16 @@ module VSphereCloud
117
123
  vm_cid
118
124
  end
119
125
 
126
+ private
127
+
120
128
  def create_drs_rules(vm, cluster)
121
- return unless @placer.drs_rules
122
- return if @placer.drs_rules.size == 0
129
+ return if @drs_rules.nil? || @drs_rules.size == 0
123
130
 
124
- if @placer.drs_rules.size > 1
131
+ if @drs_rules.size > 1
125
132
  raise 'vSphere CPI supports only one DRS rule per resource pool'
126
133
  end
127
134
 
128
- rule_config = @placer.drs_rules.first
135
+ rule_config = @drs_rules.first
129
136
 
130
137
  if rule_config['type'] != 'separate_vms'
131
138
  raise "vSphere CPI only supports DRS rule of 'separate_vms' type, not '#{rule_config['type']}'"
@@ -2,20 +2,21 @@ require 'cloud/vsphere/vm_creator'
2
2
 
3
3
  module VSphereCloud
4
4
  class VmCreatorBuilder
5
- def build(resources, cloud_properties, client, cloud_searcher, logger, cpi, agent_env, file_provider, disk_provider)
5
+ def build(cloud_properties, client, cloud_searcher, logger, cpi, agent_env, file_provider, datacenter, cluster=nil, drs_rules=[])
6
6
  VmCreator.new(
7
7
  cloud_properties.fetch('ram'),
8
8
  cloud_properties.fetch('disk'),
9
9
  cloud_properties.fetch('cpu'),
10
10
  cloud_properties.fetch('nested_hardware_virtualization', false),
11
- resources,
11
+ drs_rules,
12
12
  client,
13
13
  cloud_searcher,
14
14
  logger,
15
15
  cpi,
16
16
  agent_env,
17
17
  file_provider,
18
- disk_provider
18
+ datacenter,
19
+ cluster
19
20
  )
20
21
  end
21
22
  end
data/lib/cloud/vsphere.rb CHANGED
@@ -12,9 +12,7 @@ require 'cloud/vsphere/cloud'
12
12
  require 'cloud/vsphere/cloud_searcher'
13
13
  require 'cloud/vsphere/config'
14
14
  require 'cloud/vsphere/cluster_config'
15
- require 'cloud/vsphere/disk_provider'
16
15
  require 'cloud/vsphere/file_provider'
17
- require 'cloud/vsphere/fixed_cluster_placer'
18
16
  require 'cloud/vsphere/lease_obtainer'
19
17
  require 'cloud/vsphere/lease_updater'
20
18
  require 'cloud/vsphere/path_finder'
@@ -22,12 +20,18 @@ require 'cloud/vsphere/resources/cluster_provider'
22
20
  require 'cloud/vsphere/resources/cluster'
23
21
  require 'cloud/vsphere/resources/datacenter'
24
22
  require 'cloud/vsphere/resources/datastore'
25
- require 'cloud/vsphere/resources/disk/ephemeral_disk'
23
+ require 'cloud/vsphere/resources/disk'
24
+ require 'cloud/vsphere/resources/ephemeral_disk'
25
+ require 'cloud/vsphere/resources/persistent_disk'
26
+ require 'cloud/vsphere/resources/nic'
26
27
  require 'cloud/vsphere/resources/folder'
27
28
  require 'cloud/vsphere/resources/vm'
28
29
  require 'cloud/vsphere/resources/resource_pool'
29
30
  require 'cloud/vsphere/resources/scorer'
30
31
  require 'cloud/vsphere/resources/util'
32
+ require 'cloud/vsphere/drs_rules/drs_lock'
33
+ require 'cloud/vsphere/drs_rules/drs_rule'
34
+ require 'cloud/vsphere/drs_rules/vm_attribute_manager'
31
35
  require 'cloud/vsphere/soap_stub'
32
36
  require 'cloud/vsphere/vm_creator_builder'
33
37
  require 'cloud/vsphere/vm_provider'
@@ -46,7 +50,7 @@ module Bosh
46
50
  :create_disk, :has_disk?, :delete_disk,
47
51
  :attach_disk, :detach_disk,
48
52
  :snapshot_disk, :delete_snapshot,
49
- :current_vm_id, :get_disks, :ping, :disk_provider
53
+ :current_vm_id, :get_disks, :ping
50
54
 
51
55
  def initialize(options)
52
56
  @delegate = VSphereCloud::Cloud.new(options)
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bosh_vsphere_cpi
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.2.0
4
+ version: 2.2.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - VMware
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2015-11-17 00:00:00.000000000 Z
11
+ date: 2016-01-26 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bosh_common
@@ -86,14 +86,14 @@ dependencies:
86
86
  requirements:
87
87
  - - '='
88
88
  - !ruby/object:Gem::Version
89
- version: 2.4.0
89
+ version: 2.7.1
90
90
  type: :runtime
91
91
  prerelease: false
92
92
  version_requirements: !ruby/object:Gem::Requirement
93
93
  requirements:
94
94
  - - '='
95
95
  - !ruby/object:Gem::Version
96
- version: 2.4.0
96
+ version: 2.7.1
97
97
  - !ruby/object:Gem::Dependency
98
98
  name: mono_logger
99
99
  requirement: !ruby/object:Gem::Requirement
@@ -125,12 +125,10 @@ files:
125
125
  - lib/cloud/vsphere/cloud_searcher.rb
126
126
  - lib/cloud/vsphere/cluster_config.rb
127
127
  - lib/cloud/vsphere/config.rb
128
- - lib/cloud/vsphere/disk_provider.rb
129
128
  - lib/cloud/vsphere/drs_rules/drs_lock.rb
130
129
  - lib/cloud/vsphere/drs_rules/drs_rule.rb
131
130
  - lib/cloud/vsphere/drs_rules/vm_attribute_manager.rb
132
131
  - lib/cloud/vsphere/file_provider.rb
133
- - lib/cloud/vsphere/fixed_cluster_placer.rb
134
132
  - lib/cloud/vsphere/ip_conflict_detector.rb
135
133
  - lib/cloud/vsphere/lease_obtainer.rb
136
134
  - lib/cloud/vsphere/lease_updater.rb
@@ -142,9 +140,10 @@ files:
142
140
  - lib/cloud/vsphere/resources/datacenter.rb
143
141
  - lib/cloud/vsphere/resources/datastore.rb
144
142
  - lib/cloud/vsphere/resources/disk.rb
145
- - lib/cloud/vsphere/resources/disk/disk_config.rb
146
- - lib/cloud/vsphere/resources/disk/ephemeral_disk.rb
143
+ - lib/cloud/vsphere/resources/ephemeral_disk.rb
147
144
  - lib/cloud/vsphere/resources/folder.rb
145
+ - lib/cloud/vsphere/resources/nic.rb
146
+ - lib/cloud/vsphere/resources/persistent_disk.rb
148
147
  - lib/cloud/vsphere/resources/resource_pool.rb
149
148
  - lib/cloud/vsphere/resources/scorer.rb
150
149
  - lib/cloud/vsphere/resources/util.rb
@@ -1,94 +0,0 @@
1
- require 'ostruct'
2
- require 'cloud/vsphere/resources/disk'
3
-
4
- module VSphereCloud
5
- class DiskProvider
6
- # https://pubs.vmware.com/vsphere-55/index.jsp?topic=%2Fcom.vmware.wssdk.apiref.doc%2Fvim.VirtualDiskManager.VirtualDiskType.html
7
- SUPPORTED_DISK_TYPES = %w{
8
- eagerZeroedThick
9
- preallocated
10
- thick
11
- thin
12
- }
13
-
14
- DEFAULT_DISK_TYPE = 'preallocated'
15
-
16
- def initialize(virtual_disk_manager, datacenter, resources, disk_path, client, logger)
17
- @virtual_disk_manager = virtual_disk_manager
18
- @datacenter = datacenter
19
- @resources = resources
20
- @disk_path = disk_path
21
- @client = client
22
- @logger = logger
23
- end
24
-
25
- def create(disk_size_in_mb, disk_type, cluster)
26
- type = disk_type
27
- if type.nil?
28
- type = DEFAULT_DISK_TYPE
29
- end
30
-
31
- unless SUPPORTED_DISK_TYPES.include?(type)
32
- raise "Disk type: '#{disk_type}' is not supported"
33
- end
34
-
35
- if cluster
36
- datastore = @resources.pick_persistent_datastore_in_cluster(cluster.name, disk_size_in_mb)
37
- else
38
- datastore = @datacenter.pick_persistent_datastore(disk_size_in_mb)
39
- end
40
- disk_cid = "disk-#{SecureRandom.uuid}"
41
- @logger.debug("Creating disk '#{disk_cid}' in datastore '#{datastore.name}'")
42
-
43
- @client.create_disk(@datacenter, datastore, disk_cid, @disk_path, disk_size_in_mb, type)
44
- end
45
-
46
- def find_and_move(disk_cid, cluster, datacenter, accessible_datastores)
47
- disk = find(disk_cid)
48
- disk_in_persistent_datastore = @datacenter.persistent_datastores.include?(disk.datastore.name)
49
- disk_in_accessible_datastore = accessible_datastores.include?(disk.datastore.name)
50
- if disk_in_persistent_datastore && disk_in_accessible_datastore
51
- @logger.info("Disk #{disk_cid} found in an accessible, persistent datastore '#{disk.datastore.name}'")
52
- return disk
53
- end
54
-
55
- destination_datastore = @resources.pick_persistent_datastore_in_cluster(cluster.name, disk.size_in_mb)
56
-
57
- unless accessible_datastores.include?(destination_datastore.name)
58
- raise "Datastore '#{destination_datastore.name}' is not accessible to cluster '#{cluster.name}'"
59
- end
60
-
61
- destination_path = path(destination_datastore, disk_cid)
62
- @logger.info("Moving #{disk.path} to #{destination_path}")
63
- @client.move_disk(datacenter, disk.path, datacenter, destination_path)
64
- @logger.info('Moved disk successfully')
65
- Resources::Disk.new(disk_cid, disk.size_in_mb, destination_datastore, destination_path)
66
- end
67
-
68
- def find(disk_cid)
69
- persistent_datastores = @datacenter.persistent_datastores
70
- @logger.debug("Looking for disk #{disk_cid} in datastores: #{persistent_datastores}")
71
- persistent_datastores.each do |_, datastore|
72
- disk = @client.find_disk(disk_cid, datastore, @disk_path)
73
- @logger.debug("disk #{disk_cid} found in: #{datastore}") unless disk.nil?
74
- return disk unless disk.nil?
75
- end
76
-
77
- other_datastores = @datacenter.all_datastores.reject{|datastore_name, _| persistent_datastores[datastore_name] }
78
- @logger.debug("disk #{disk_cid} not found in filtered persistent datastores, trying other datastores: #{other_datastores}")
79
- other_datastores.each do |_, datastore|
80
- disk = @client.find_disk(disk_cid, datastore, @disk_path)
81
- @logger.debug("disk #{disk_cid} found in: #{datastore}") unless disk.nil?
82
- return disk unless disk.nil?
83
- end
84
-
85
- raise Bosh::Clouds::DiskNotFound.new(false), "Could not find disk with id '#{disk_cid}'"
86
- end
87
-
88
- private
89
-
90
- def path(datastore, disk_cid)
91
- "[#{datastore.name}] #{@disk_path}/#{disk_cid}.vmdk"
92
- end
93
- end
94
- end
@@ -1,32 +0,0 @@
1
- module VSphereCloud
2
- class FixedClusterPlacer
3
- include ObjectStringifier
4
- stringify_with :cluster
5
-
6
- attr_reader :drs_rules
7
-
8
- def initialize(cluster, drs_rules)
9
- @cluster = cluster
10
- @drs_rules = drs_rules
11
- end
12
-
13
- def pick_cluster_for_vm(memory, ephemeral, persistent)
14
- @cluster.allocate(memory)
15
- @cluster
16
- end
17
-
18
- def pick_ephemeral_datastore(cluster, disk_size_in_mb)
19
- datastore = cluster.pick_ephemeral(disk_size_in_mb)
20
- datastore.allocate(disk_size_in_mb)
21
- datastore
22
- end
23
-
24
- def pick_persistent_datastore(_, _)
25
- raise NotImplementedError
26
- end
27
-
28
- private
29
-
30
- attr_reader :cluster
31
- end
32
- end
@@ -1,35 +0,0 @@
1
- module VSphereCloud
2
- class DiskConfig
3
- def initialize(datastore_name, filename, controller_key, size_in_mb)
4
- @datastore_name = datastore_name
5
- @filename = filename
6
- @controller_key = controller_key
7
- @size_in_mb = size_in_mb
8
- end
9
-
10
- def spec(options)
11
- backing_info = VimSdk::Vim::Vm::Device::VirtualDisk::FlatVer2BackingInfo.new
12
- backing_info.datastore = @datastore_name
13
- if options[:independent]
14
- backing_info.disk_mode = VimSdk::Vim::Vm::Device::VirtualDiskOption::DiskMode::INDEPENDENT_PERSISTENT
15
- else
16
- backing_info.disk_mode = VimSdk::Vim::Vm::Device::VirtualDiskOption::DiskMode::PERSISTENT
17
- end
18
- backing_info.file_name = @filename
19
-
20
- virtual_disk = VimSdk::Vim::Vm::Device::VirtualDisk.new
21
- virtual_disk.key = -1
22
- virtual_disk.controller_key = @controller_key
23
- virtual_disk.backing = backing_info
24
- virtual_disk.capacity_in_kb = @size_in_mb * 1024
25
-
26
- device_config_spec = VimSdk::Vim::Vm::Device::VirtualDeviceSpec.new
27
- device_config_spec.device = virtual_disk
28
- device_config_spec.operation = VimSdk::Vim::Vm::Device::VirtualDeviceSpec::Operation::ADD
29
- if options[:create]
30
- device_config_spec.file_operation = VimSdk::Vim::Vm::Device::VirtualDeviceSpec::FileOperation::CREATE
31
- end
32
- device_config_spec
33
- end
34
- end
35
- end
@@ -1,22 +0,0 @@
1
- require 'cloud/vsphere/resources/disk/disk_config'
2
-
3
- module VSphereCloud
4
- class EphemeralDisk
5
- DISK_NAME = 'ephemeral_disk'
6
- def initialize(size_in_mb, folder_name, datastore)
7
- @folder_name = folder_name
8
- @datastore = datastore
9
- @size_in_mb = size_in_mb
10
- end
11
-
12
- def create_spec(controller_key)
13
- DiskConfig.new(@datastore.mob, filename, controller_key, @size_in_mb).spec(create: true)
14
- end
15
-
16
- private
17
-
18
- def filename
19
- "[#{@datastore.name}] #{@folder_name}/#{DISK_NAME}.vmdk"
20
- end
21
- end
22
- end