2014-07-14 17:50:04 +00:00
|
|
|
# -*- mode: ruby -*-
|
|
|
|
# vi: set ft=ruby :
|
|
|
|
|
|
|
|
# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
|
|
|
|
VAGRANTFILE_API_VERSION = "2"
|
|
|
|
|
|
|
|
# Require a recent version of vagrant otherwise some have reported errors setting host names on boxes
|
|
|
|
Vagrant.require_version ">= 1.6.2"
|
|
|
|
|
2014-12-12 19:08:22 +00:00
|
|
|
if ARGV.first == "up" && ENV['USING_KUBE_SCRIPTS'] != 'true'
|
|
|
|
raise Vagrant::Errors::VagrantError.new, <<END
|
|
|
|
Calling 'vagrant up' directly is not supported. Instead, please run the following:
|
|
|
|
|
|
|
|
export KUBERNETES_PROVIDER=vagrant
|
|
|
|
./cluster/kube-up.sh
|
|
|
|
END
|
|
|
|
end
|
|
|
|
|
2014-09-29 20:37:04 +00:00
|
|
|
# The number of minions to provision
|
2015-01-09 18:00:48 +00:00
|
|
|
$num_minion = (ENV['NUM_MINIONS'] || 1).to_i
|
2014-07-14 17:50:04 +00:00
|
|
|
|
2014-09-29 20:37:04 +00:00
|
|
|
# ip configuration
|
2014-12-12 19:08:22 +00:00
|
|
|
$master_ip = ENV['MASTER_IP']
|
|
|
|
$minion_ip_base = ENV['MINION_IP_BASE'] || ""
|
|
|
|
$minion_ips = $num_minion.times.collect { |n| $minion_ip_base + "#{n+3}" }
|
2014-07-14 17:50:04 +00:00
|
|
|
|
2014-09-29 20:37:04 +00:00
|
|
|
# Determine the OS platform to use
|
|
|
|
$kube_os = ENV['KUBERNETES_OS'] || "fedora"
|
2014-07-14 17:50:04 +00:00
|
|
|
|
2014-12-15 06:23:48 +00:00
|
|
|
# Check if we already have kube box
|
|
|
|
$kube_box_url = ENV['KUBERNETES_BOX_URL'] || "http://opscode-vm-bento.s3.amazonaws.com/vagrant/virtualbox/opscode_fedora-20_chef-provisionerless.box"
|
|
|
|
|
2014-09-29 20:37:04 +00:00
|
|
|
# OS platform to box information
|
|
|
|
$kube_box = {
|
|
|
|
"fedora" => {
|
|
|
|
"name" => "fedora20",
|
2014-12-15 06:23:48 +00:00
|
|
|
"box_url" => $kube_box_url
|
2014-07-14 17:50:04 +00:00
|
|
|
}
|
2014-09-29 20:37:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# This stuff is cargo-culted from http://www.stefanwrobel.com/how-to-make-vagrant-performance-not-suck
|
2014-11-14 01:09:59 +00:00
|
|
|
# Give access to half of all cpu cores on the host. We divide by 2 as we assume
|
|
|
|
# that users are running with hyperthreads.
|
2014-09-29 20:37:04 +00:00
|
|
|
host = RbConfig::CONFIG['host_os']
|
|
|
|
if host =~ /darwin/
|
2014-11-14 01:09:59 +00:00
|
|
|
$vm_cpus = (`sysctl -n hw.ncpu`.to_i/2.0).ceil
|
2014-09-29 20:37:04 +00:00
|
|
|
elsif host =~ /linux/
|
2014-11-14 01:09:59 +00:00
|
|
|
$vm_cpus = (`nproc`.to_i/2.0).ceil
|
2014-09-29 20:37:04 +00:00
|
|
|
else # sorry Windows folks, I can't help you
|
|
|
|
$vm_cpus = 2
|
|
|
|
end
|
|
|
|
|
2015-02-08 23:53:35 +00:00
|
|
|
# Give VM 1024MB of RAM by default
|
2015-02-24 00:17:13 +00:00
|
|
|
# In Fedora VM, tmpfs device is mapped to /tmp. tmpfs is given 50% of RAM allocation.
|
|
|
|
# When doing Salt provisioning, we copy approximately 200MB of content in /tmp before anything else happens.
|
|
|
|
# This causes problems if anything else was in /tmp or the other directories that are bound to tmpfs device (i.e /run, etc.)
|
2015-02-08 23:53:35 +00:00
|
|
|
$vm_mem = (ENV['KUBERNETES_MEMORY'] || 1024).to_i
|
2014-09-29 20:37:04 +00:00
|
|
|
|
|
|
|
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
|
|
|
|
def customize_vm(config)
|
|
|
|
config.vm.box = $kube_box[$kube_os]["name"]
|
|
|
|
config.vm.box_url = $kube_box[$kube_os]["box_url"]
|
|
|
|
|
|
|
|
config.vm.provider :virtualbox do |v|
|
|
|
|
v.customize ["modifyvm", :id, "--memory", $vm_mem]
|
|
|
|
v.customize ["modifyvm", :id, "--cpus", $vm_cpus]
|
|
|
|
|
|
|
|
# Use faster paravirtualized networking
|
|
|
|
v.customize ["modifyvm", :id, "--nictype1", "virtio"]
|
|
|
|
v.customize ["modifyvm", :id, "--nictype2", "virtio"]
|
|
|
|
end
|
|
|
|
end
|
2014-07-14 17:50:04 +00:00
|
|
|
|
|
|
|
# Kubernetes master
|
2015-02-20 00:35:39 +00:00
|
|
|
config.vm.define "master" do |c|
|
|
|
|
customize_vm c
|
|
|
|
if ENV['KUBE_TEMP'] then
|
|
|
|
script = "#{ENV['KUBE_TEMP']}/master-start.sh"
|
|
|
|
c.vm.provision "shell", run: "always", path: script
|
|
|
|
end
|
|
|
|
c.vm.network "private_network", ip: "#{$master_ip}"
|
|
|
|
c.vm.hostname = ENV['MASTER_NAME']
|
2014-10-14 11:14:25 +00:00
|
|
|
end
|
2014-07-14 17:50:04 +00:00
|
|
|
|
|
|
|
# Kubernetes minion
|
2014-09-29 20:37:04 +00:00
|
|
|
$num_minion.times do |n|
|
2014-07-14 17:50:04 +00:00
|
|
|
config.vm.define "minion-#{n+1}" do |minion|
|
2014-09-29 20:37:04 +00:00
|
|
|
customize_vm minion
|
|
|
|
|
2014-07-14 17:50:04 +00:00
|
|
|
minion_index = n+1
|
2014-09-29 20:37:04 +00:00
|
|
|
minion_ip = $minion_ips[n]
|
2015-02-20 00:35:39 +00:00
|
|
|
if ENV['KUBE_TEMP'] then
|
|
|
|
script = "#{ENV['KUBE_TEMP']}/minion-start-#{n}.sh"
|
|
|
|
minion.vm.provision "shell", run: "always", path: script
|
|
|
|
end
|
2014-07-14 17:50:04 +00:00
|
|
|
minion.vm.network "private_network", ip: "#{minion_ip}"
|
2014-12-12 19:08:22 +00:00
|
|
|
minion.vm.hostname = "#{ENV['INSTANCE_PREFIX']}-minion-#{minion_index}"
|
2014-07-14 17:50:04 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|