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['vagrant_sync_dir']
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 # Faster bootup. Disables mounting the sync folder for libvirt and virtualbox
79 if DISABLE_SYNCED_FOLDER
80 config.vm.provider :virtualbox do |v,override|
81 override.vm.synced_folder '.', SYNC_DIR, disabled: true
83 config.vm.provider :libvirt do |v,override|
84 override.vm.synced_folder '.', SYNC_DIR, disabled: true
88 (0..CLIENTS - 1).each do |i|
89 config.vm.define "#{LABEL_PREFIX}client#{i}" do |client|
90 client.vm.box = CLIENT_BOX
91 client.vm.hostname = "#{LABEL_PREFIX}client#{i}"
93 client.vm.network :private_network,
94 ip: "#{PUBLIC_SUBNET}.4#{i}"
97 client.vm.provider :virtualbox do |vb|
98 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
102 client.vm.provider :vmware_fusion do |v|
103 v.vmx['memsize'] = "#{MEMORY}"
107 client.vm.provider :libvirt do |lv|
109 lv.random_hostname = true
110 lv.nic_model_type = "e1000"
114 client.vm.provider "parallels" do |prl|
115 prl.name = "client#{i}"
116 prl.memory = "#{MEMORY}"
119 client.vm.provider :linode do |provider|
120 provider.label = client.vm.hostname
125 (0..NRGWS - 1).each do |i|
126 config.vm.define "#{LABEL_PREFIX}rgw#{i}" do |rgw|
128 rgw.vm.box_url = BOX_URL
129 rgw.vm.hostname = "#{LABEL_PREFIX}rgw#{i}"
131 rgw.vm.network :private_network,
132 ip: "#{PUBLIC_SUBNET}.5#{i}"
136 rgw.vm.provider :virtualbox do |vb|
137 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
141 rgw.vm.provider :vmware_fusion do |v|
142 v.vmx['memsize'] = "#{MEMORY}"
146 rgw.vm.provider :libvirt do |lv|
148 lv.random_hostname = true
149 lv.nic_model_type = "e1000"
153 rgw.vm.provider "parallels" do |prl|
155 prl.memory = "#{MEMORY}"
158 rgw.vm.provider :linode do |provider|
159 provider.label = rgw.vm.hostname
164 (0..NNFSS - 1).each do |i|
165 config.vm.define "nfs#{i}" do |nfs|
167 nfs.vm.box_url = BOX_URL
168 nfs.vm.hostname = "nfs#{i}"
170 nfs.vm.network :private_network,
171 ip: "#{PUBLIC_SUBNET}.6#{i}"
175 nfs.vm.provider :virtualbox do |vb|
176 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
180 nfs.vm.provider :vmware_fusion do |v|
181 v.vmx['memsize'] = "#{MEMORY}"
185 nfs.vm.provider :libvirt do |lv|
187 lv.random_hostname = true
188 lv.nic_model_type = "e1000"
192 nfs.vm.provider "parallels" do |prl|
194 prl.memory = "#{MEMORY}"
197 nfs.vm.provider :linode do |provider|
198 provider.label = nfs.vm.hostname
203 (0..NMDSS - 1).each do |i|
204 config.vm.define "#{LABEL_PREFIX}mds#{i}" do |mds|
206 mds.vm.box_url = BOX_URL
207 mds.vm.hostname = "#{LABEL_PREFIX}mds#{i}"
209 mds.vm.network :private_network,
210 ip: "#{PUBLIC_SUBNET}.7#{i}"
213 mds.vm.provider :virtualbox do |vb|
214 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
218 mds.vm.provider :vmware_fusion do |v|
219 v.vmx['memsize'] = "#{MEMORY}"
223 mds.vm.provider :libvirt do |lv|
225 lv.random_hostname = true
226 lv.nic_model_type = "e1000"
229 mds.vm.provider "parallels" do |prl|
231 prl.memory = "#{MEMORY}"
234 mds.vm.provider :linode do |provider|
235 provider.label = mds.vm.hostname
240 (0..NRBD_MIRRORS - 1).each do |i|
241 config.vm.define "#{LABEL_PREFIX}rbd_mirror#{i}" do |rbd_mirror|
242 rbd_mirror.vm.box = BOX
243 rbd_mirror.vm.box_url = BOX_URL
244 rbd_mirror.vm.hostname = "#{LABEL_PREFIX}rbd-mirror#{i}"
246 rbd_mirror.vm.network :private_network,
247 ip: "#{PUBLIC_SUBNET}.8#{i}"
250 rbd_mirror.vm.provider :virtualbox do |vb|
251 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
255 rbd_mirror.vm.provider :vmware_fusion do |v|
256 v.vmx['memsize'] = "#{MEMORY}"
260 rbd_mirror.vm.provider :libvirt do |lv|
262 lv.random_hostname = true
263 lv.nic_model_type = "e1000"
266 rbd_mirror.vm.provider "parallels" do |prl|
267 prl.name = "rbd-mirror#{i}"
268 prl.memory = "#{MEMORY}"
271 rbd_mirror.vm.provider :linode do |provider|
272 provider.label = rbd_mirror.vm.hostname
277 (0..NISCSI_GWS - 1).each do |i|
278 config.vm.define "#{LABEL_PREFIX}iscsi_gw#{i}" do |iscsi_gw|
279 iscsi_gw.vm.box = BOX
280 iscsi_gw.vm.box_url = BOX_URL
281 iscsi_gw.vm.hostname = "#{LABEL_PREFIX}iscsi-gw#{i}"
283 iscsi_gw.vm.network :private_network,
284 ip: "#{PUBLIC_SUBNET}.9#{i}"
287 iscsi_gw.vm.provider :virtualbox do |vb|
288 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
292 iscsi_gw.vm.provider :vmware_fusion do |v|
293 v.vmx['memsize'] = "#{MEMORY}"
297 iscsi_gw.vm.provider :libvirt do |lv|
299 lv.random_hostname = true
300 lv.nic_model_type = "e1000"
303 iscsi_gw.vm.provider "parallels" do |prl|
304 prl.name = "iscsi-gw#{i}"
305 prl.memory = "#{MEMORY}"
308 iscsi_gw.vm.provider :linode do |provider|
309 provider.label = iscsi_gw.vm.hostname
314 (0..NMONS - 1).each do |i|
315 config.vm.define "#{LABEL_PREFIX}mon#{i}" do |mon|
317 mon.vm.box_url = BOX_URL
318 mon.vm.hostname = "#{LABEL_PREFIX}mon#{i}"
320 mon.vm.network :private_network,
321 ip: "#{PUBLIC_SUBNET}.1#{i}"
324 mon.vm.provider :virtualbox do |vb|
325 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
329 mon.vm.provider :vmware_fusion do |v|
330 v.vmx['memsize'] = "#{MEMORY}"
334 mon.vm.provider :libvirt do |lv|
336 lv.random_hostname = true
337 lv.nic_model_type = "e1000"
341 mon.vm.provider "parallels" do |prl|
343 prl.memory = "#{MEMORY}"
346 mon.vm.provider :linode do |provider|
347 provider.label = mon.vm.hostname
352 (0..NOSDS - 1).each do |i|
353 config.vm.define "#{LABEL_PREFIX}osd#{i}" do |osd|
355 osd.vm.box_url = BOX_URL
356 osd.vm.hostname = "#{LABEL_PREFIX}osd#{i}"
358 osd.vm.network :private_network,
359 ip: "#{PUBLIC_SUBNET}.10#{i}"
360 osd.vm.network :private_network,
361 ip: "#{CLUSTER_SUBNET}.20#{i}"
364 osd.vm.provider :virtualbox do |vb|
365 # Create our own controller for consistency and to remove VM dependency
366 # but only do it once, otherwise it would fail when rebooting machines.
367 # We assume this has run if one disk was created before
368 unless File.exist?("disk-#{i}-0.vdi")
369 vb.customize ['storagectl', :id,
370 '--name', 'OSD Controller',
374 vb.customize ['createhd',
375 '--filename', "disk-#{i}-#{d}",
376 '--size', '12000'] unless File.exist?("disk-#{i}-#{d}.vdi")
377 vb.customize ['storageattach', :id,
378 '--storagectl', 'OSD Controller',
382 '--medium', "disk-#{i}-#{d}.vdi"]
384 vb.customize ['modifyvm', :id, '--memory', "#{MEMORY}"]
388 osd.vm.provider :vmware_fusion do |v|
390 v.vmx["scsi0:#{d + 1}.present"] = 'TRUE'
391 v.vmx["scsi0:#{d + 1}.fileName"] =
392 create_vmdk("disk-#{i}-#{d}", '11000MB')
394 v.vmx['memsize'] = "#{MEMORY}"
398 driverletters = ('a'..'z').to_a
399 osd.vm.provider :libvirt do |lv|
400 # always make /dev/sd{a/b/c/d} so that CI can ensure that
401 # virtualbox and libvirt will have the same devices to use for OSDs
403 lv.storage :file, :device => "hd#{driverletters[d]}", :path => "disk-#{i}-#{d}-#{DISK_UUID}.disk", :size => '12G', :bus => "ide"
406 lv.random_hostname = true
407 lv.nic_model_type = "e1000"
411 osd.vm.provider "parallels" do |prl|
413 prl.memory = "#{MEMORY}"
415 prl.customize ["set", :id,
423 osd.vm.provider :linode do |provider|
424 provider.label = osd.vm.hostname