-
Notifications
You must be signed in to change notification settings - Fork 312
/
Vagrantfile
155 lines (150 loc) · 6.2 KB
/
Vagrantfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
# -*- mode: ruby -*-
# vi: set ft=ruby :
#
# `Vagrantfile` for bootstrapping a development Consul cluster with
# VirtualBox provider and Ansible provisioner
#
# This inline script is called with a script provisioner on each box
# to do utility work for handling corner cases in different boxes and
# operating systems, such as installing Python on official FreeBSD boxes, etc.
#
$script = <<SCRIPT
check_os () {
PLATFORM="unknown"
UNAMESTR="$(uname)"
if test "$UNAMESTR" = "Linux"; then
PLATFORM="linux"
elif test "$UNAMESTR" = "FreeBSD"; then
PLATFORM="freebsd"
fi
}
## Install Python on FreeBSD
check_os
if test "$PLATFORM" = "freebsd"; then
echo "FreeBSD guest detected: installing Python ..."
if pkg install -y python > /dev/null 2>&1; then
echo "Done!"
else
echo >2 "Problem installing Python!"
fi
echo "Linking Python ..."
if ln -s /usr/local/bin/python /usr/bin/python; then
echo "Done!"
else
echo 2> "Problem linking Python!"
fi
fi
SCRIPT
ANSIBLE_PLAYBOOK = ENV['ANSIBLE_PLAYBOOK'] || "site.yml"
BOX_MEM = ENV['BOX_MEM'] || "1024"
BOX_NAME = ENV['BOX_NAME'] || "debian/stretch64"
CLUSTER_HOSTS = ENV['CLUSTER_HOSTS'] || "vagrant_hosts"
CONSUL_ACL_ENABLE = ENV['CONSUL_ACL_ENABLE'] || "false"
CONSUL_ATLAS_ENABLE = ENV['CONSUL_ATLAS_ENABLE'] || "false"
CONSUL_DNSMASQ_ENABLE = ENV['CONSUL_DNSMASQ_ENABLE'] || "false"
CONSUL_LOGLEVEL = ENV['CONSUL_LOGLEVEL'] || "INFO"
CONSUL_LOG_PATH = ENV['CONSUL_LOG_PATH'] || "/var/log/consul"
CONSUL_LOG_FILE = ENV['CONSUL_LOG_FILE'] || "consul.log"
CONSUL_SYSLOG_FACILITY = ENV['CONSUL_SYSLOG_FACILITY'] || "local0"
SYSLOG_USER = ENV['SYSLOG_USER'] || "syslog"
SYSLOG_GROUP = ENV['SYSLOG_GROUP'] || "adm"
CONSUL_NODE_OS = ENV['CONSUL_NODE_OS'] || "Linux"
VAGRANTFILE_API_VERSION = "2"
Vagrant.require_version ">= 1.9.0"
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
if BOX_NAME.include? "freebsd"
CONSUL_IFACE = "em1"
end
# Configure 3 Consul nodes
config.vm.define :consul1 do |consul1_config|
consul1_config.vm.box = BOX_NAME
# FreeBSD needs a MAC, disabled synced folder, and explicit shell
consul1_config.vm.base_mac = "080027D17374"
consul1_config.vm.synced_folder ".", "/vagrant", disabled: true
consul1_config.ssh.shell = "/bin/sh"
consul1_config.vm.network :private_network, ip: "10.1.42.210"
consul1_config.vm.hostname = "consul1.consul"
consul1_config.ssh.forward_agent = true
consul1_config.vm.provider "virtualbox" do |v|
v.name = "consul-node1"
v.customize ["modifyvm", :id, "--memory", BOX_MEM]
v.customize ["modifyvm", :id, "--ioapic", "on"]
v.customize ["modifyvm", :id, "--cpus", "2"]
v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
v.customize ["modifyvm", :id, "--natdnsproxy1", "on"]
consul1_config.vm.post_up_message = "Consul server 1 spun up!"
end
consul1_config.vm.provision :hosts do |provisioner|
provisioner.sync_hosts = false
provisioner.add_host '10.1.42.210', ['consul1.consul']
provisioner.add_host '10.1.42.220', ['consul2.consul']
provisioner.add_host '10.1.42.230', ['consul3.consul']
end
consul1_config.vm.provision "shell", inline: $script
end
config.vm.define :consul2 do |consul2_config|
consul2_config.vm.box = BOX_NAME
# FreeBSD needs a MAC, disabled synced folder, and explicit shell
consul2_config.vm.base_mac = "080027D27374"
consul2_config.vm.synced_folder ".", "/vagrant", disabled: true
consul2_config.ssh.shell = "/bin/sh"
consul2_config.vm.network :private_network, ip: "10.1.42.220"
consul2_config.vm.hostname = "consul2.consul"
consul2_config.ssh.forward_agent = true
consul2_config.vm.provider "virtualbox" do |v|
v.name = "consul-node2"
v.customize ["modifyvm", :id, "--memory", BOX_MEM]
v.customize ["modifyvm", :id, "--ioapic", "on"]
v.customize ["modifyvm", :id, "--cpus", "2"]
v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
v.customize ["modifyvm", :id, "--natdnsproxy1", "on"]
consul2_config.vm.post_up_message = "Consul server 2 spun up!"
end
consul2_config.vm.provision :hosts do |provisioner|
provisioner.sync_hosts = false
provisioner.add_host '10.1.42.210', ['consul1.consul']
provisioner.add_host '10.1.42.220', ['consul2.consul']
provisioner.add_host '10.1.42.230', ['consul3.consul']
end
consul2_config.vm.provision "shell", inline: $script
end
config.vm.define :consul3 do |consul3_config|
consul3_config.vm.box = BOX_NAME
# FreeBSD needs a MAC, disabled synced folder, and explicit shell
consul3_config.vm.base_mac = "080027D37374"
consul3_config.vm.synced_folder ".", "/vagrant", disabled: true
consul3_config.ssh.shell = "/bin/sh"
consul3_config.vm.network :private_network, ip: "10.1.42.230"
consul3_config.vm.hostname = "consul3.consul"
consul3_config.ssh.forward_agent = true
consul3_config.vm.provider "virtualbox" do |v|
v.name = "consul-node3"
v.customize ["modifyvm", :id, "--memory", BOX_MEM]
v.customize ["modifyvm", :id, "--ioapic", "on"]
v.customize ["modifyvm", :id, "--cpus", "2"]
v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
v.customize ["modifyvm", :id, "--natdnsproxy1", "on"]
consul3_config.vm.post_up_message = "Consul server 3 spun up!\n\nAccess http://consul1.consul:8500/ui/ in a browser for Consul UI."
end
consul3_config.vm.provision :hosts do |provisioner|
provisioner.sync_hosts = false
provisioner.add_host '10.1.42.210', ['consul1.consul']
provisioner.add_host '10.1.42.220', ['consul2.consul']
provisioner.add_host '10.1.42.230', ['consul3.consul']
end
consul3_config.vm.provision "shell", inline: $script
consul3_config.vm.provision :ansible do |ansible|
ansible.inventory_path = CLUSTER_HOSTS
# As if variable related things in Ansible couldn't be more exciting,
# extra Ansible variables can be defined here as well. Wheeee!
#
ansible.extra_vars = {
consul_log_level: "DEBUG",
consul_iface: "eth1"
}
ansible.playbook = ANSIBLE_PLAYBOOK
ansible.limit = "all"
compatibility_mode = "2.0"
end
end
end