6 VAGRANTFILE_API_VERSION = '2'
11 if File.symlink?(__FILE__)
12 global_config = File.expand_path(
14 File.dirname(File.readlink(__FILE__)),
15 'global_vagrant_variables.yml')
17 if File.exist?(global_config)
18 global_settings = YAML.load_file(global_config)
22 LIBVIRT_URI = global_settings.fetch('libvirt_uri', '')
23 LIBVIRT_STORAGE_POOL = global_settings.fetch('libvirt_storage_pool', '')
25 config_file=File.expand_path(File.join(File.dirname(__FILE__), 'vagrant_variables.yml'))
26 settings=YAML.load_file(config_file)
28 LABEL_PREFIX = settings['label_prefix'] ? settings['label_prefix'] + "-" : ""
29 NMONS = settings['mon_vms']
30 NOSDS = settings['osd_vms']
31 NMDSS = settings['mds_vms']
32 NRGWS = settings['rgw_vms']
33 NNFSS = settings['nfs_vms']
34 RESTAPI = settings['restapi']
35 NRBD_MIRRORS = settings['rbd_mirror_vms']
36 CLIENTS = settings['client_vms']
37 NISCSI_GWS = settings['iscsi_gw_vms']
38 PUBLIC_SUBNET = settings['public_subnet']
39 CLUSTER_SUBNET = settings['cluster_subnet']
40 BOX = settings['vagrant_box']
41 CLIENT_BOX = settings['client_vagrant_box']
42 BOX_URL = settings['vagrant_box_url']
43 SYNC_DIR = settings.fetch('vagrant_sync_dir', '/vagrant')
44 MEMORY = settings['memory']
46 USER = settings['ssh_username']
48 ASSIGN_STATIC_IP = settings.fetch('assign_static_ip', true)
49 DISABLE_SYNCED_FOLDER = settings.fetch('vagrant_disable_synced_folder', false)
50 DISK_UUID = Time.now.utc.to_i
52 def create_vmdk(name, size)
53 dir = Pathname.new(__FILE__).expand_path.dirname
54 path = File.join(dir, '.vagrant', name + '.vmdk')
55 `vmware-vdiskmanager -c -s #{size} -t 0 -a scsi #{path} \
56 2>&1 > /dev/null` unless File.exist?(path)
59 Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
60 config.ssh.insert_key = false # workaround for https://github.com/mitchellh/vagrant/issues/5048
61 config.ssh.private_key_path = settings['ssh_private_key_path']
62 config.ssh.username = USER
64 config.vm.provider :libvirt do |lv|
65 # When using libvirt, avoid errors like:
66 # "CPU feature cmt not found"
67 lv.cpu_mode = 'host-passthrough'
68 # set libvirt uri if present
69 if not LIBVIRT_URI.empty?
72 # set libvirt storage pool if present
73 if not LIBVIRT_STORAGE_POOL.empty?
74 lv.storage_pool_name = LIBVIRT_STORAGE_POOL
78 (0..CLIENTS - 1).each do |i|
79 config.vm.define "#{LABEL_PREFIX}client#{i}" do |client|
80 client.vm.box = CLIENT_BOX
81 client.vm.hostname = "#{LABEL_PREFIX}client#{i}"
83 client.vm.network :private_network,
84 ip: "#{PUBLIC_SUBNET}.4#{i}"
87 client.vm.provider :virtualbox do |vb|
88 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
92 client.vm.provider :vmware_fusion do |v|
93 v.vmx['memsize'] = "#{MEMORY}"
97 client.vm.provider :libvirt do |lv|
99 lv.random_hostname = true
100 lv.nic_model_type = "e1000"
104 client.vm.provider "parallels" do |prl|
105 prl.name = "client#{i}"
106 prl.memory = "#{MEMORY}"
109 client.vm.provider :linode do |provider|
110 provider.label = client.vm.hostname
115 (0..NRGWS - 1).each do |i|
116 config.vm.define "#{LABEL_PREFIX}rgw#{i}" do |rgw|
118 rgw.vm.box_url = BOX_URL
119 rgw.vm.hostname = "#{LABEL_PREFIX}rgw#{i}"
121 rgw.vm.network :private_network,
122 ip: "#{PUBLIC_SUBNET}.5#{i}"
126 rgw.vm.provider :virtualbox do |vb|
127 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
131 rgw.vm.provider :vmware_fusion do |v|
132 v.vmx['memsize'] = "#{MEMORY}"
136 rgw.vm.provider :libvirt do |lv|
138 lv.random_hostname = true
139 lv.nic_model_type = "e1000"
143 rgw.vm.provider "parallels" do |prl|
145 prl.memory = "#{MEMORY}"
148 rgw.vm.provider :linode do |provider|
149 provider.label = rgw.vm.hostname
154 (0..NNFSS - 1).each do |i|
155 config.vm.define "nfs#{i}" do |nfs|
157 nfs.vm.box_url = BOX_URL
158 nfs.vm.hostname = "nfs#{i}"
160 nfs.vm.network :private_network,
161 ip: "#{PUBLIC_SUBNET}.6#{i}"
165 nfs.vm.provider :virtualbox do |vb|
166 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
170 nfs.vm.provider :vmware_fusion do |v|
171 v.vmx['memsize'] = "#{MEMORY}"
175 nfs.vm.provider :libvirt do |lv|
177 lv.random_hostname = true
178 lv.nic_model_type = "e1000"
182 nfs.vm.provider "parallels" do |prl|
184 prl.memory = "#{MEMORY}"
187 nfs.vm.provider :linode do |provider|
188 provider.label = nfs.vm.hostname
193 (0..NMDSS - 1).each do |i|
194 config.vm.define "#{LABEL_PREFIX}mds#{i}" do |mds|
196 mds.vm.box_url = BOX_URL
197 mds.vm.hostname = "#{LABEL_PREFIX}mds#{i}"
199 mds.vm.network :private_network,
200 ip: "#{PUBLIC_SUBNET}.7#{i}"
203 mds.vm.provider :virtualbox do |vb|
204 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
208 mds.vm.provider :vmware_fusion do |v|
209 v.vmx['memsize'] = "#{MEMORY}"
213 mds.vm.provider :libvirt do |lv|
215 lv.random_hostname = true
216 lv.nic_model_type = "e1000"
219 mds.vm.provider "parallels" do |prl|
221 prl.memory = "#{MEMORY}"
224 mds.vm.provider :linode do |provider|
225 provider.label = mds.vm.hostname
230 (0..NRBD_MIRRORS - 1).each do |i|
231 config.vm.define "#{LABEL_PREFIX}rbd_mirror#{i}" do |rbd_mirror|
232 rbd_mirror.vm.box = BOX
233 rbd_mirror.vm.box_url = BOX_URL
234 rbd_mirror.vm.hostname = "#{LABEL_PREFIX}rbd-mirror#{i}"
236 rbd_mirror.vm.network :private_network,
237 ip: "#{PUBLIC_SUBNET}.8#{i}"
240 rbd_mirror.vm.provider :virtualbox do |vb|
241 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
245 rbd_mirror.vm.provider :vmware_fusion do |v|
246 v.vmx['memsize'] = "#{MEMORY}"
250 rbd_mirror.vm.provider :libvirt do |lv|
252 lv.random_hostname = true
253 lv.nic_model_type = "e1000"
256 rbd_mirror.vm.provider "parallels" do |prl|
257 prl.name = "rbd-mirror#{i}"
258 prl.memory = "#{MEMORY}"
261 rbd_mirror.vm.provider :linode do |provider|
262 provider.label = rbd_mirror.vm.hostname
267 (0..NISCSI_GWS - 1).each do |i|
268 config.vm.define "#{LABEL_PREFIX}iscsi_gw#{i}" do |iscsi_gw|
269 iscsi_gw.vm.box = BOX
270 iscsi_gw.vm.box_url = BOX_URL
271 iscsi_gw.vm.hostname = "#{LABEL_PREFIX}iscsi-gw#{i}"
273 iscsi_gw.vm.network :private_network,
274 ip: "#{PUBLIC_SUBNET}.9#{i}"
277 iscsi_gw.vm.provider :virtualbox do |vb|
278 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
282 iscsi_gw.vm.provider :vmware_fusion do |v|
283 v.vmx['memsize'] = "#{MEMORY}"
287 iscsi_gw.vm.provider :libvirt do |lv|
289 lv.random_hostname = true
290 lv.nic_model_type = "e1000"
293 iscsi_gw.vm.provider "parallels" do |prl|
294 prl.name = "iscsi-gw#{i}"
295 prl.memory = "#{MEMORY}"
298 iscsi_gw.vm.provider :linode do |provider|
299 provider.label = iscsi_gw.vm.hostname
304 (0..NMONS - 1).each do |i|
305 config.vm.define "#{LABEL_PREFIX}mon#{i}" do |mon|
307 mon.vm.box_url = BOX_URL
308 mon.vm.hostname = "#{LABEL_PREFIX}mon#{i}"
310 mon.vm.network :private_network,
311 ip: "#{PUBLIC_SUBNET}.1#{i}"
314 mon.vm.provider :virtualbox do |vb|
315 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
319 mon.vm.provider :vmware_fusion do |v|
320 v.vmx['memsize'] = "#{MEMORY}"
324 mon.vm.provider :libvirt do |lv|
326 lv.random_hostname = true
327 lv.nic_model_type = "e1000"
331 mon.vm.provider "parallels" do |prl|
333 prl.memory = "#{MEMORY}"
336 mon.vm.provider :linode do |provider|
337 provider.label = mon.vm.hostname
342 (0..NOSDS - 1).each do |i|
343 config.vm.define "#{LABEL_PREFIX}osd#{i}" do |osd|
345 osd.vm.box_url = BOX_URL
346 osd.vm.hostname = "#{LABEL_PREFIX}osd#{i}"
348 osd.vm.network :private_network,
349 ip: "#{PUBLIC_SUBNET}.10#{i}"
350 osd.vm.network :private_network,
351 ip: "#{CLUSTER_SUBNET}.20#{i}"
354 osd.vm.provider :virtualbox do |vb|
355 # Create our own controller for consistency and to remove VM dependency
356 # but only do it once, otherwise it would fail when rebooting machines.
357 # We assume this has run if one disk was created before
358 unless File.exist?("disk-#{i}-0.vdi")
359 vb.customize ['storagectl', :id,
360 '--name', 'OSD Controller',
364 vb.customize ['createhd',
365 '--filename', "disk-#{i}-#{d}",
366 '--size', '12000'] unless File.exist?("disk-#{i}-#{d}.vdi")
367 vb.customize ['storageattach', :id,
368 '--storagectl', 'OSD Controller',
372 '--medium', "disk-#{i}-#{d}.vdi"]
374 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
378 osd.vm.provider :vmware_fusion do |v|
380 v.vmx["scsi0:#{d + 1}.present"] = 'TRUE'
381 v.vmx["scsi0:#{d + 1}.fileName"] =
382 create_vmdk("disk-#{i}-#{d}", '11000MB')
384 v.vmx['memsize'] = "#{MEMORY}"
388 driverletters = ('b'..'z').to_a
389 osd.vm.provider :libvirt do |lv|
390 # always make /dev/sd{a/b/c/d} so that CI can ensure that
391 # virtualbox and libvirt will have the same devices to use for OSDs
393 lv.storage :file, :device => "sd#{driverletters[d]}", :size => '100G'
396 lv.random_hostname = true
397 lv.nic_model_type = "e1000"
401 osd.vm.provider "parallels" do |prl|
403 prl.memory = "#{MEMORY}"
405 prl.customize ["set", :id,
413 osd.vm.provider :linode do |provider|
414 provider.label = osd.vm.hostname
420 # Faster bootup. Disables mounting the sync folder for libvirt and virtualbox
421 config.vm.synced_folder './', SYNC_DIR, disabled: DISABLE_SYNCED_FOLDER