Created
September 10, 2014 20:47
-
-
Save micahhausler/539755721c1cbf2b657b to your computer and use it in GitHub Desktop.
Vagrant CoreOS setup (w/ rudder)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# coreos-vagrant is configured through a series of configuration | |
# options (global ruby variables) which are detailed below. To modify | |
# these options, first copy this file to "config.rb". Then simply | |
# uncomment the necessary lines, leaving the $, and replace everything | |
# after the equals sign.. | |
# Size of the CoreOS cluster created by Vagrant | |
#$num_instances=1 | |
# Log the serial consoles of CoreOS VMs to log/ | |
# Enable by setting value to true, disable with false | |
# WARNING: Serial logging is known to result in extremely high CPU usage with | |
# VirtualBox, so should only be used in debugging situations | |
#$enable_serial_logging=false | |
# Enable port forwarding of Docker TCP socket | |
# Set to the TCP port you want exposed on the *host* machine, default is 4243 | |
# If 4243 is used, Vagrant will auto-increment (e.g. in the case of $num_instances > 1) | |
# You can then use the docker tool locally by setting the folloing env var: | |
# export DOCKER_HOST='tcp://127.0.0.1:4243' | |
$expose_docker_tcp=4243 | |
# Setting for VirtualBox VMs | |
#$vb_gui = false | |
#$vb_memory = 1024 | |
#$vb_cpus = 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#cloud-config | |
write_files: | |
- path: /home/core/.dockercfg | |
owner: core:core | |
permissions: 0644 | |
content: | | |
{"hub.docker.com":{"auth":"xXxXxXxXxX=","email":""}} | |
coreos: | |
etcd: | |
# generate a new token for each unique cluster from https://discovery.etcd.io/new | |
# WARNING: replace each time you 'vagrant destroy' | |
discovery: https://discovery.etcd.io/<token> | |
addr: $public_ipv4:4001 | |
peer-addr: $public_ipv4:7001 | |
fleet: | |
public-ip: $public_ipv4 | |
units: | |
- name: etcd.service | |
command: start | |
- name: fleet.service | |
command: start | |
- name: rudder.service | |
command: start | |
content: | | |
[Unit] | |
Requires=etcd.service | |
After=etcd.service | |
[Service] | |
ExecStartPre=/usr/bin/mkdir -p /opt/bin | |
ExecStartPre=/usr/bin/wget -O /opt/bin/rudder https://s3.amazonaws.com/ambition_public/docker/rudder | |
ExecStartPre=/usr/bin/chmod 755 /opt/bin/rudder | |
ExecStartPre=-/usr/bin/etcdctl mk /coreos.com/network/config '{"Network":"10.0.0.0/16"}' | |
ExecStart=/opt/bin/rudder -iface $private_ipv4 | |
ExecStartPost=/usr/bin/sleep 2 | |
- name: docker-tcp.socket | |
command: start | |
enable: true | |
content: | | |
[Unit] | |
Description=Docker Socket for the API | |
[Socket] | |
ListenStream=2375 | |
Service=docker.service | |
BindIPv6Only=both | |
[Install] | |
WantedBy=sockets.target | |
- name: docker.service | |
command: start | |
runtime: yes | |
content: | | |
[Unit] | |
Description=docker | |
After=docker-tcp.socket | |
Requires=rudder.service | |
After=rudder.service | |
[Service] | |
EnvironmentFile=/run/rudder/subnet.env | |
ExecStart=/usr/bin/docker -d --bip=${RUDDER_SUBNET} --mtu=${RUDDER_MTU} -s=btrfs -r=false -H fd:// |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# -*- mode: ruby -*- | |
# # vi: set ft=ruby : | |
require 'fileutils' | |
Vagrant.require_version ">= 1.6.0" | |
CLOUD_CONFIG_PATH = File.join(File.dirname(__FILE__), "user-data") | |
CONFIG = File.join(File.dirname(__FILE__), "config.rb") | |
# Defaults for config options defined in CONFIG | |
$num_instances = 3 | |
$update_channel = "alpha" | |
$enable_serial_logging = false | |
$vb_gui = false | |
$vb_memory = 1024 | |
$vb_cpus = 1 | |
# Attempt to apply the deprecated environment variable NUM_INSTANCES to | |
# $num_instances while allowing config.rb to override it | |
if ENV["NUM_INSTANCES"].to_i > 0 && ENV["NUM_INSTANCES"] | |
$num_instances = ENV["NUM_INSTANCES"].to_i | |
end | |
if File.exist?(CONFIG) | |
require CONFIG | |
end | |
Vagrant.configure("2") do |config| | |
config.vm.box = "coreos-%s" % $update_channel | |
config.vm.box_version = ">= 308.0.1" | |
config.vm.box_url = "http://%s.release.core-os.net/amd64-usr/current/coreos_production_vagrant.json" % $update_channel | |
config.vm.provider :vmware_fusion do |vb, override| | |
override.vm.box_url = "http://%s.release.core-os.net/amd64-usr/current/coreos_production_vagrant_vmware_fusion.json" % $update_channel | |
end | |
config.vm.provider :virtualbox do |v| | |
# On VirtualBox, we don't have guest additions or a functional vboxsf | |
# in CoreOS, so tell Vagrant that so it can be smarter. | |
v.check_guest_additions = false | |
v.functional_vboxsf = false | |
end | |
# plugin conflict | |
if Vagrant.has_plugin?("vagrant-vbguest") then | |
config.vbguest.auto_update = false | |
end | |
(1..$num_instances).each do |i| | |
config.vm.define vm_name = "core-%02d" % i do |config| | |
config.vm.hostname = vm_name | |
if $enable_serial_logging | |
logdir = File.join(File.dirname(__FILE__), "log") | |
FileUtils.mkdir_p(logdir) | |
serialFile = File.join(logdir, "%s-serial.txt" % vm_name) | |
FileUtils.touch(serialFile) | |
config.vm.provider :vmware_fusion do |v, override| | |
v.vmx["serial0.present"] = "TRUE" | |
v.vmx["serial0.fileType"] = "file" | |
v.vmx["serial0.fileName"] = serialFile | |
v.vmx["serial0.tryNoRxLoss"] = "FALSE" | |
end | |
config.vm.provider :virtualbox do |vb, override| | |
vb.customize ["modifyvm", :id, "--uart1", "0x3F8", "4"] | |
vb.customize ["modifyvm", :id, "--uartmode1", serialFile] | |
vb.customize ["modifyvm", :id, "--natdnshostresolver1", "on"] | |
vb.customize ["modifyvm", :id, "--natdnsproxy1", "on"] | |
end | |
end | |
if $expose_docker_tcp | |
config.vm.network "forwarded_port", guest: 2375, host: ($expose_docker_tcp + i - 1), auto_correct: true | |
end | |
config.vm.provider :vmware_fusion do |vb| | |
vb.gui = $vb_gui | |
end | |
config.vm.network "forwarded_port", guest: 4001, host: 4001, auto_correct: true | |
config.vm.network "forwarded_port", guest: 7001, host: 7001, auto_correct: true | |
config.vm.provider :virtualbox do |vb| | |
vb.gui = $vb_gui | |
vb.memory = $vb_memory | |
vb.cpus = $vb_cpus | |
end | |
ip = "172.17.8.#{i+100}" | |
config.vm.network :private_network, ip: ip | |
# Uncomment below to enable NFS for sharing the host machine into the coreos-vagrant VM. | |
#config.vm.synced_folder ".", "/home/core/share", id: "core", :nfs => true, :mount_options => ['nolock,vers=3,udp'] | |
if File.exist?(CLOUD_CONFIG_PATH) | |
config.vm.provision :file, :source => "#{CLOUD_CONFIG_PATH}", :destination => "/tmp/vagrantfile-user-data" | |
config.vm.provision :shell, :inline => "mv /tmp/vagrantfile-user-data /var/lib/coreos-vagrant/", :privileged => true | |
end | |
end | |
end | |
end |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment