132 lines
4.1 KiB
Ruby
132 lines
4.1 KiB
Ruby
# -*- mode: ruby -*-
|
|
# vi: set ft=ruby :
|
|
|
|
# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
|
|
VAGRANTFILE_API_VERSION = "2"
|
|
|
|
DEFAULT_CPU_COUNT = 2
|
|
$script = <<SCRIPT
|
|
GO_VERSION="1.7.1"
|
|
|
|
# Install Prereq Packages
|
|
sudo apt-get update
|
|
sudo apt-get install -y build-essential curl git-core mercurial bzr libpcre3-dev pkg-config zip default-jre qemu libc6-dev-i386 silversearcher-ag jq htop vim unzip
|
|
|
|
# Setup go, for development of Nomad
|
|
SRCROOT="/opt/go"
|
|
SRCPATH="/opt/gopath"
|
|
|
|
# Get the ARCH
|
|
ARCH=`uname -m | sed 's|i686|386|' | sed 's|x86_64|amd64|'`
|
|
|
|
# Install Go
|
|
cd /tmp
|
|
wget -q https://storage.googleapis.com/golang/go${GO_VERSION}.linux-${ARCH}.tar.gz
|
|
tar -xf go${GO_VERSION}.linux-${ARCH}.tar.gz
|
|
sudo mv go $SRCROOT
|
|
sudo chmod 775 $SRCROOT
|
|
sudo chown vagrant:vagrant $SRCROOT
|
|
|
|
# Setup the GOPATH; even though the shared folder spec gives the working
|
|
# directory the right user/group, we need to set it properly on the
|
|
# parent path to allow subsequent "go get" commands to work.
|
|
sudo mkdir -p $SRCPATH
|
|
sudo chown -R vagrant:vagrant $SRCPATH 2>/dev/null || true
|
|
# ^^ silencing errors here because we expect this to fail for the shared folder
|
|
|
|
cat <<EOF >/tmp/gopath.sh
|
|
export GOPATH="$SRCPATH"
|
|
export GOROOT="$SRCROOT"
|
|
export PATH="$SRCROOT/bin:$SRCPATH/bin:\$PATH"
|
|
EOF
|
|
sudo mv /tmp/gopath.sh /etc/profile.d/gopath.sh
|
|
sudo chmod 0755 /etc/profile.d/gopath.sh
|
|
source /etc/profile.d/gopath.sh
|
|
|
|
# Install Docker
|
|
echo deb https://apt.dockerproject.org/repo ubuntu-`lsb_release -c | awk '{print $2}'` main | sudo tee /etc/apt/sources.list.d/docker.list
|
|
sudo apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
|
|
sudo apt-get update
|
|
sudo apt-get install -y docker-engine
|
|
|
|
# Restart docker to make sure we get the latest version of the daemon if there is an upgrade
|
|
sudo service docker restart
|
|
|
|
# Make sure we can actually use docker as the vagrant user
|
|
sudo usermod -aG docker vagrant
|
|
|
|
# Setup Nomad for development
|
|
cd /opt/gopath/src/github.com/hashicorp/nomad && make bootstrap
|
|
|
|
# Install rkt, consul and vault
|
|
bash scripts/install_rkt.sh
|
|
bash scripts/install_rkt_vagrant.sh
|
|
bash scripts/install_consul.sh
|
|
bash scripts/install_vault.sh
|
|
|
|
# CD into the nomad working directory when we login to the VM
|
|
grep "cd /opt/gopath/src/github.com/hashicorp/nomad" ~/.profile || echo "cd /opt/gopath/src/github.com/hashicorp/nomad" >> ~/.profile
|
|
SCRIPT
|
|
|
|
def configureVM(vmCfg, vmParams={
|
|
numCPUs: DEFAULT_CPU_COUNT,
|
|
}
|
|
)
|
|
vmCfg.vm.box = "cbednarski/ubuntu-1404"
|
|
|
|
vmCfg.vm.provision "shell", inline: $script, privileged: false
|
|
vmCfg.vm.synced_folder '.', '/opt/gopath/src/github.com/hashicorp/nomad'
|
|
|
|
# We're going to compile go and run a concurrent system, so give ourselves
|
|
# some extra resources. Nomad will have trouble working correctly with <2
|
|
# CPUs so we should use at least that many.
|
|
cpus = vmParams.fetch(:numCPUs, DEFAULT_CPU_COUNT)
|
|
memory = 2048
|
|
|
|
vmCfg.vm.provider "parallels" do |p, o|
|
|
o.vm.box = "parallels/ubuntu-14.04"
|
|
p.memory = memory
|
|
p.cpus = cpus
|
|
end
|
|
|
|
vmCfg.vm.provider "virtualbox" do |v|
|
|
v.memory = memory
|
|
v.cpus = cpus
|
|
end
|
|
|
|
["vmware_fusion", "vmware_workstation"].each do |p|
|
|
vmCfg.vm.provider p do |v|
|
|
v.gui = false
|
|
v.memory = memory
|
|
v.cpus = cpus
|
|
end
|
|
end
|
|
return vmCfg
|
|
end
|
|
|
|
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
|
|
1.upto(3) do |n|
|
|
vmName = "nomad-server%02d" % [n]
|
|
isFirstBox = (n == 1)
|
|
|
|
numCPUs = DEFAULT_CPU_COUNT
|
|
if isFirstBox and Object::RUBY_PLATFORM =~ /darwin/i
|
|
# Override the max CPUs for the first VM
|
|
numCPUs = [numCPUs, (`/usr/sbin/sysctl -n hw.ncpu`.to_i - 1)].max
|
|
end
|
|
|
|
config.vm.define vmName, autostart: isFirstBox, primary: isFirstBox do |vmCfg|
|
|
vmCfg.vm.hostname = vmName
|
|
vmCfg = configureVM(vmCfg, {:numCPUs => numCPUs})
|
|
end
|
|
end
|
|
|
|
1.upto(3) do |n|
|
|
vmName = "nomad-client%02d" % [n]
|
|
config.vm.define vmName, autostart: false, primary: false do |vmCfg|
|
|
vmCfg.vm.hostname = vmName
|
|
vmCfg = configureVM(vmCfg)
|
|
end
|
|
end
|
|
end
|