This repository has been archived by the owner on Sep 17, 2020. It is now read-only.
forked from mesosphere-backup/packet-terraform
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdcos.tf
140 lines (131 loc) · 4.59 KB
/
dcos.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
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
provider "packet" {
auth_token = "${var.packet_api_key}"
}
resource "packet_device" "dcos_bootstrap" {
hostname = "${format("${var.dcos_cluster_name}-bootstrap-%02d", count.index)}"
operating_system = "coreos_stable"
plan = "${var.packet_boot_type}"
connection {
user = "core"
private_key = "${var.dcos_ssh_key_path}"
}
user_data = "#cloud-config\n\nmanage_etc_hosts: \"localhost\"\nssh_authorized_keys:\n - \"${file("${var.dcos_ssh_public_key_path}")}\"\n"
facility = "${var.packet_facility}"
project_id = "${var.packet_project_id}"
billing_cycle = "hourly"
provisioner "local-exec" {
command = "rm -rf ./do-install.sh"
}
provisioner "local-exec" {
command = "echo BOOTSTRAP=\"${packet_device.dcos_bootstrap.network.0.address}\" >> ips.txt"
}
provisioner "local-exec" {
command = "echo CLUSTER_NAME=\"${var.dcos_cluster_name}\" >> ips.txt"
}
provisioner "remote-exec" {
inline = [
"wget -q -O dcos_generate_config.sh -P $HOME ${var.dcos_installer_url}",
"mkdir $HOME/genconf"
]
}
provisioner "local-exec" {
command = "./make-files.sh"
}
provisioner "local-exec" {
command = "sed -i -e '/^- *$/d' ./config.yaml"
}
provisioner "file" {
source = "./ip-detect"
destination = "$HOME/genconf/ip-detect"
}
provisioner "file" {
source = "./config.yaml"
destination = "$HOME/genconf/config.yaml"
}
provisioner "remote-exec" {
inline = ["sudo bash $HOME/dcos_generate_config.sh",
"docker run -d -p 4040:80 -v $HOME/genconf/serve:/usr/share/nginx/html:ro nginx 2>/dev/null",
"docker run -d -p 2181:2181 -p 2888:2888 -p 3888:3888 --name=dcos_int_zk jplock/zookeeper 2>/dev/null"
]
}
}
resource "packet_device" "dcos_master" {
hostname = "${format("${var.dcos_cluster_name}-master-%02d", count.index)}"
operating_system = "coreos_stable"
plan = "${var.packet_master_type}"
count = "${var.dcos_master_count}"
user_data = "#cloud-config\n\nmanage_etc_hosts: \"localhost\"\nssh_authorized_keys:\n - \"${file("${var.dcos_ssh_public_key_path}")}\"\n"
facility = "${var.packet_facility}"
project_id = "${var.packet_project_id}"
billing_cycle = "hourly"
connection {
user = "core"
private_key = "${var.dcos_ssh_key_path}"
}
provisioner "local-exec" {
command = "rm -rf ./do-install.sh"
}
provisioner "local-exec" {
command = "echo ${format("MASTER_%02d", count.index)}=\"${self.network.0.address}\" >> ips.txt"
}
provisioner "local-exec" {
command = "while [ ! -f ./do-install.sh ]; do sleep 1; done"
}
provisioner "file" {
source = "./do-install.sh"
destination = "/tmp/do-install.sh"
}
provisioner "remote-exec" {
inline = "bash /tmp/do-install.sh master"
}
}
resource "packet_device" "dcos_agent" {
hostname = "${format("${var.dcos_cluster_name}-agent-%02d", count.index)}"
depends_on = ["packet_device.dcos_bootstrap"]
operating_system = "coreos_stable"
plan = "${var.packet_agent_type}"
count = "${var.dcos_agent_count}"
user_data = "#cloud-config\n\nmanage_etc_hosts: \"localhost\"\nssh_authorized_keys:\n - \"${file("${var.dcos_ssh_public_key_path}")}\"\n"
facility = "${var.packet_facility}"
project_id = "${var.packet_project_id}"
billing_cycle = "hourly"
connection {
user = "core"
private_key = "${var.dcos_ssh_key_path}"
}
provisioner "local-exec" {
command = "while [ ! -f ./do-install.sh ]; do sleep 1; done"
}
provisioner "file" {
source = "do-install.sh"
destination = "/tmp/do-install.sh"
}
provisioner "remote-exec" {
inline = "bash /tmp/do-install.sh slave"
}
}
resource "packet_device" "dcos_public_agent" {
hostname = "${format("${var.dcos_cluster_name}-public-agent-%02d", count.index)}"
depends_on = ["packet_device.dcos_bootstrap"]
operating_system = "coreos_stable"
plan = "${var.packet_agent_type}"
count = "${var.dcos_public_agent_count}"
user_data = "#cloud-config\n\nmanage_etc_hosts: \"localhost\"\nssh_authorized_keys:\n - \"${file("${var.dcos_ssh_public_key_path}")}\"\n"
facility = "${var.packet_facility}"
project_id = "${var.packet_project_id}"
billing_cycle = "hourly"
connection {
user = "core"
private_key = "${var.dcos_ssh_key_path}"
}
provisioner "local-exec" {
command = "while [ ! -f ./do-install.sh ]; do sleep 1; done"
}
provisioner "file" {
source = "do-install.sh"
destination = "/tmp/do-install.sh"
}
provisioner "remote-exec" {
inline = "bash /tmp/do-install.sh slave_public"
}
}