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.
- checksums.yaml +4 -4
- data/lib/cloud/vsphere/agent_env.rb +2 -9
- data/lib/cloud/vsphere/client.rb +135 -33
- data/lib/cloud/vsphere/cloud.rb +131 -210
- data/lib/cloud/vsphere/config.rb +1 -4
- data/lib/cloud/vsphere/resources/cluster.rb +10 -35
- data/lib/cloud/vsphere/resources/cluster_provider.rb +1 -1
- data/lib/cloud/vsphere/resources/datacenter.rb +177 -14
- data/lib/cloud/vsphere/resources/datastore.rb +3 -1
- data/lib/cloud/vsphere/resources/disk.rb +33 -7
- data/lib/cloud/vsphere/resources/ephemeral_disk.rb +23 -0
- data/lib/cloud/vsphere/resources/folder.rb +1 -1
- data/lib/cloud/vsphere/resources/nic.rb +38 -0
- data/lib/cloud/vsphere/resources/persistent_disk.rb +22 -0
- data/lib/cloud/vsphere/resources/resource_pool.rb +1 -1
- data/lib/cloud/vsphere/resources/scorer.rb +3 -3
- data/lib/cloud/vsphere/resources/util.rb +1 -1
- data/lib/cloud/vsphere/resources/vm.rb +145 -5
- data/lib/cloud/vsphere/resources.rb +1 -150
- data/lib/cloud/vsphere/vm_creator.rb +22 -15
- data/lib/cloud/vsphere/vm_creator_builder.rb +4 -3
- data/lib/cloud/vsphere.rb +8 -4
- metadata +7 -8
- data/lib/cloud/vsphere/disk_provider.rb +0 -94
- data/lib/cloud/vsphere/fixed_cluster_placer.rb +0 -32
- data/lib/cloud/vsphere/resources/disk/disk_config.rb +0 -35
- data/lib/cloud/vsphere/resources/disk/ephemeral_disk.rb +0 -22
@@ -1,154 +1,5 @@
|
|
1
|
-
require 'cloud/vsphere/resources/datacenter'
|
2
|
-
|
3
1
|
module VSphereCloud
|
4
|
-
|
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,
|
4
|
-
@
|
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
|
-
@
|
15
|
+
@datacenter = datacenter
|
16
|
+
@cluster = cluster
|
16
17
|
|
17
|
-
@logger.debug("VM creator initialized with memory: #{@memory}, disk: #{@disk}, cpu: #{@cpu}
|
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| @
|
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 = @
|
39
|
-
|
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 =
|
58
|
-
|
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
|
-
|
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 =
|
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
|
122
|
-
return if @placer.drs_rules.size == 0
|
129
|
+
return if @drs_rules.nil? || @drs_rules.size == 0
|
123
130
|
|
124
|
-
if @
|
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 = @
|
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(
|
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
|
-
|
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
|
-
|
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
|
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
|
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.
|
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:
|
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.
|
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.
|
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/
|
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
|