-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathVagrantfile
123 lines (108 loc) · 5.01 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
require "yaml"
vagrant_root = File.dirname(File.expand_path(__FILE__))
settings = YAML.load_file "#{vagrant_root}/settings.yaml"
IP_SECTIONS = settings["network"]["control_ip"].match(/^([0-9.]+\.)([^.]+)$/)
# First 3 octets including the trailing dot:
IP_NW = IP_SECTIONS.captures[0]
# Last octet excluding all dots:
IP_START = Integer(IP_SECTIONS.captures[1])
NUM_WORKER_NODES = settings["nodes"]["workers"]["count"]
Vagrant.configure("2") do |config|
config.vm.boot_timeout = 600
config.vm.provision "shell", env: { "IP_NW" => IP_NW, "IP_START" => IP_START, "NUM_WORKER_NODES" => NUM_WORKER_NODES }, inline: <<-SHELL
apt-get update -y
echo "$IP_NW$((IP_START)) devnodemaster01" >> /etc/hosts
for i in `seq 1 ${NUM_WORKER_NODES}`; do
echo "$IP_NW$((IP_START+i)) node0${i}" >> /etc/hosts
done
SHELL
if `uname -m`.strip == "aarch64"
config.vm.box = settings["software"]["box"] + "-arm64"
else
config.vm.box = settings["software"]["box"]
end
config.vm.box_check_update = false
config.vm.define "devnodemaster01" do |controlplane|
controlplane.vm.hostname = "devnodemaster01"
## Assign IP From Settings YAML
controlplane.vm.network "private_network", ip: settings["network"]["control_ip"]
## Asign IP From Static Hardcode
# controlplane.vm.network "private_network", ip: "192.168.56.10"
## Openforwarded port toward host machine so host can accesss it
## Port 30001 : Kubernetes Dashboard UI
## Port 30002 : Kubernetes ArgoCD UI
## Port 32000 : Sample NGINX Deployment
controlplane.vm.network "forwarded_port", guest: 30001, host: 30001
controlplane.vm.network "forwarded_port", guest: 30002, host: 30002
controlplane.vm.network "forwarded_port", guest: 32000, host: 32000
## Openforwarded port toward host machine so host can accesss it
## Kubernetes control plane allocates a port from a range specified by --service-node-port-range flag (default: 30000-32767).
# for i in 30000..32767
# config.vm.network :forwarded_port, guest: i, host: i
# end
if settings["shared_folders"]
settings["shared_folders"].each do |shared_folder|
controlplane.vm.synced_folder shared_folder["host_path"], shared_folder["vm_path"]
end
end
controlplane.vm.provider "virtualbox" do |vb|
vb.name = "DEVNODEMASTER01-CALICO-CNI"
vb.cpus = settings["nodes"]["control"]["cpu"]
vb.memory = settings["nodes"]["control"]["memory"]
if settings["cluster_name"] and settings["cluster_name"] != ""
vb.customize ["modifyvm", :id, "--groups", ("/" + settings["cluster_name"])]
end
end
controlplane.vm.provision "shell",
env: {
"DNS_SERVERS" => settings["network"]["dns_servers"].join(" "),
"ENVIRONMENT" => settings["environment"],
"KUBERNETES_VERSION" => settings["software"]["kubernetes"],
"KUBERNETES_VERSION_SHORT" => settings["software"]["kubernetes"][0..3],
"OS" => settings["software"]["os"]
},
path: "scripts-setup/setup-node-all.sh"
controlplane.vm.provision "shell",
env: {
"CALICO_VERSION" => settings["software"]["calico"],
"CONTROL_IP" => settings["network"]["control_ip"],
"POD_CIDR" => settings["network"]["pod_cidr"],
"SERVICE_CIDR" => settings["network"]["service_cidr"]
},
path: "scripts-setup/setup-node-control-plane.sh"
end
(1..NUM_WORKER_NODES).each do |i|
config.vm.boot_timeout = 600
config.vm.define "devnodeworker0#{i}" do |node|
node.vm.hostname = "devnodeworker0#{i}"
node.vm.network "private_network", ip: IP_NW + "#{IP_START + i}"
if settings["shared_folders"]
settings["shared_folders"].each do |shared_folder|
node.vm.synced_folder shared_folder["host_path"], shared_folder["vm_path"]
end
end
node.vm.provider "virtualbox" do |vb|
vb.name = "DEVNODEWORKER0#{i}-CALICO-CNI"
vb.cpus = settings["nodes"]["workers"]["cpu"]
vb.memory = settings["nodes"]["workers"]["memory"]
if settings["cluster_name"] and settings["cluster_name"] != ""
vb.customize ["modifyvm", :id, "--groups", ("/" + settings["cluster_name"])]
end
end
node.vm.provision "shell",
env: {
"DNS_SERVERS" => settings["network"]["dns_servers"].join(" "),
"ENVIRONMENT" => settings["environment"],
"KUBERNETES_VERSION" => settings["software"]["kubernetes"],
"KUBERNETES_VERSION_SHORT" => settings["software"]["kubernetes"][0..3],
"OS" => settings["software"]["os"]
},
path: "scripts-setup/setup-node-all.sh"
node.vm.provision "shell", path: "scripts-setup/setup-node-worker.sh"
## Trigger the dashboard shell script after provisioning the last worker (and when enabled).
if i == NUM_WORKER_NODES and settings["software"]["dashboard"] and settings["software"]["dashboard"] != ""
node.vm.provision "shell", path: "scripts-setup/setup-dashboard.sh"
end
end
end
end