forked from linode/terraform-linode-k8s
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmaster.tf
78 lines (65 loc) · 2.09 KB
/
master.tf
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
resource "linode_instance" "k8s_master" {
count = 1
region = "${var.region}"
label = "${terraform.workspace}-master-${count.index + 1}"
group = "${var.linode_group}"
type = "${var.server_type_master}"
private_ip = true
disk {
label = "boot"
size = 81920
authorized_keys = ["${chomp(file(var.ssh_public_key))}"]
root_pass = "${random_string.password.result}"
image = "linode/ubuntu16.04lts"
}
config {
label = "master"
kernel = "linode/grub2"
devices {
sda = {
disk_label = "boot"
}
}
}
provisioner file {
source = "config/sshd_config"
destination = "/etc/ssh/sshd_config"
}
provisioner remote-exec {
inline = [
"systemctl restart sshd",
]
}
provisioner "file" {
source = "scripts/"
destination = "/tmp"
}
provisioner "file" {
source = "addons/"
destination = "/tmp"
}
provisioner "remote-exec" {
# TODO advertise on public adress
inline = [
"set -e",
"hostnamectl set-hostname ${self.label} && hostname -F /etc/hostname",
"chmod +x /tmp/docker-install.sh && /tmp/docker-install.sh ${var.docker_version}",
"chmod +x /tmp/kubeadm-install.sh && /tmp/kubeadm-install.sh ${var.kubeadm_version}",
"kubeadm init --pod-network-cidr=10.244.0.0/16 --apiserver-advertise-address=${self.private_ip_address} --apiserver-cert-extra-sans=${self.ip_address}",
"mkdir -p $HOME/.kube && cp -i /etc/kubernetes/admin.conf $HOME/.kube/config",
"kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/v0.10.0/Documentation/kube-flannel.yml",
"chmod +x /tmp/monitoring-install.sh && /tmp/monitoring-install.sh",
]
}
provisioner "local-exec" {
command = "./scripts/kubectl-conf.sh ${terraform.workspace} ${self.ip_address} ${self.private_ip_address}"
on_failure = "continue"
}
}
data "external" "kubeadm_join" {
program = ["./scripts/kubeadm-token.sh"]
query = {
host = "${linode_instance.k8s_master.0.ip_address}"
}
depends_on = ["linode_instance.k8s_master"]
}