OS = (ENV['OS'] || "alpine310") BOX_REPO = (ENV['BOX_REPO'] || "generic") HOME = File.dirname(__FILE__) PROJECT = File.basename(HOME) NUM_NODES = (ENV['NUM_NODES'] || 0).to_i NODE_CPUS = (ENV['NODE_CPUS'] || 4).to_i NODE_MEMORY = (ENV['NODE_MEMORY'] || 4096).to_i NETWORK_PREFIX = ENV['NETWORK_PREFIX'] || "10.135.135" VAGRANT_PROVISION = ENV['VAGRANT_PROVISION'] || "./scripts/provision/vagrant" MOUNT_TYPE = ENV['MOUNT_TYPE'] || "nfs" # --- Rules for /etc/sudoers to avoid password entry configuring NFS: # %admin ALL = (root) NOPASSWD: /usr/bin/sed -E -e * -ibak /etc/exports # %admin ALL = (root) NOPASSWD: /usr/bin/tee -a /etc/exports # %admin ALL = (root) NOPASSWD: /sbin/nfsd restart # --- May need to add terminal to System Preferences -> Security & Privacy -> Privacy -> Full Disk Access def provision(vm, node_num) node_os = (ENV["OS_#{node_num}"] || OS) vm.box = (ENV["BOX_#{node_num}"] || ENV["BOX"] || "#{BOX_REPO}/#{node_os}") vm.hostname = "#{PROJECT}-#{node_num}-#{node_os}" vm.network "private_network", ip: "#{NETWORK_PREFIX}.#{100+node_num}" vm.provision "shell", path: VAGRANT_PROVISION, env: { 'HOME' => HOME, 'GOPATH' => ENV['GOPATH'], 'BOX' => vm.box } end Vagrant.configure("2") do |config| config.vm.provider "virtualbox" do |v| v.cpus = NODE_CPUS v.memory = NODE_MEMORY v.customize ["modifyvm", :id, "--audio", "none"] end if Vagrant.has_plugin?("vagrant-timezone") config.timezone.value = :host end config.vm.synced_folder ".", HOME, type: MOUNT_TYPE if NUM_NODES==0 provision(config.vm, 0) else (1..NUM_NODES).each do |i| config.vm.define ".#{i}" do |node| provision(node.vm, i) end end end end