|
| 1 | +# -*- mode: ruby -*- |
| 2 | +# vi: set ft=ruby : |
| 3 | + |
| 4 | +workers = (ENV['WORKERS'] || "2").to_i |
| 5 | +box_name = (ENV['VAGRANT_BOX'] || "sysnet4admin/Ubuntu-k8s") |
| 6 | +box_version = "0.7.1" |
| 7 | +Vagrant.configure("2") do |config| |
| 8 | + config.vm.box = "#{box_name}" |
| 9 | + config.vm.box_version = "#{box_version}" |
| 10 | + |
| 11 | + if Vagrant.has_plugin?("vagrant-vbguest") |
| 12 | + config.vbguest.auto_update = false |
| 13 | + end |
| 14 | + |
| 15 | + config.vm.define "host" do |host| |
| 16 | + host.vm.hostname = 'host1' |
| 17 | + host.vm.network :private_network, ip: "192.168.80.9", :netmask => "255.255.255.0" |
| 18 | + host.vm.network :private_network, ip: "192.168.90.9", :netmask => "255.255.255.0" |
| 19 | + host.vm.provision :shell, :path => "host.sh" |
| 20 | + host.vm.provider :virtualbox do |vbox| |
| 21 | + vbox.memory = "2048" |
| 22 | + vbox.cpus = "2" |
| 23 | + vbox.default_nic_type = "virtio" |
| 24 | + vbox.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"] |
| 25 | + vbox.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"] |
| 26 | + end |
| 27 | + end |
| 28 | + |
| 29 | + config.vm.define "master1" do |master| |
| 30 | + master.vm.hostname = 'master1' |
| 31 | + master.vm.network :private_network, ip: "192.168.90.10", :netmask => "255.255.255.0" |
| 32 | + master.vm.network :private_network, ip: "192.168.80.10", :netmask => "255.255.255.0" |
| 33 | + master.vm.provision :shell, :path => "master1.sh" |
| 34 | + master.vm.provider :virtualbox do |vbox| |
| 35 | + vbox.memory = "8192" |
| 36 | + vbox.cpus = "3" |
| 37 | + vbox.default_nic_type = "virtio" |
| 38 | + vbox.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"] |
| 39 | + vbox.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"] |
| 40 | + end |
| 41 | + end |
| 42 | + |
| 43 | + config.vm.define "master2" do |master| |
| 44 | + master.vm.hostname = 'master2' |
| 45 | + master.vm.network :private_network, ip: "192.168.90.11", :netmask => "255.255.255.0" |
| 46 | + master.vm.network :private_network, ip: "192.168.80.11", :netmask => "255.255.255.0" |
| 47 | + master.vm.provision :shell, :path => "master2.sh" |
| 48 | + master.vm.provider :virtualbox do |vbox| |
| 49 | + vbox.memory = "8192" |
| 50 | + vbox.cpus = "3" |
| 51 | + vbox.default_nic_type = "virtio" |
| 52 | + vbox.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"] |
| 53 | + vbox.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"] |
| 54 | + end |
| 55 | + end |
| 56 | + |
| 57 | + config.vm.define "master3" do |master| |
| 58 | + master.vm.hostname = 'master3' |
| 59 | + master.vm.network :private_network, ip: "192.168.90.12", :netmask => "255.255.255.0" |
| 60 | + master.vm.network :private_network, ip: "192.168.80.12", :netmask => "255.255.255.0" |
| 61 | + master.vm.provision :shell, :path => "master3.sh" |
| 62 | + master.vm.provider :virtualbox do |vbox| |
| 63 | + vbox.memory = "8192" |
| 64 | + vbox.cpus = "3" |
| 65 | + vbox.default_nic_type = "virtio" |
| 66 | + vbox.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"] |
| 67 | + vbox.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"] |
| 68 | + end |
| 69 | + end |
| 70 | + |
| 71 | + (1..workers).each do |node_number| |
| 72 | + config.vm.define "worker#{node_number}" do |worker| |
| 73 | + worker.vm.hostname = "worker#{node_number}" |
| 74 | + ip = node_number + 100 |
| 75 | + worker.vm.network :private_network, ip: "192.168.80.#{ip}", :netmask => "255.255.255.0" |
| 76 | + worker.vm.provision :shell, :path => "worker.sh" |
| 77 | + worker.vm.provider :virtualbox do |vbox| |
| 78 | + vbox.memory = "4096" |
| 79 | + vbox.cpus = "3" |
| 80 | + vbox.default_nic_type = "virtio" |
| 81 | + vbox.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"] |
| 82 | + end |
| 83 | + end |
| 84 | + end |
| 85 | +end |
0 commit comments