-
Notifications
You must be signed in to change notification settings - Fork 3
/
private-agent_group_3.tf
131 lines (110 loc) · 4.43 KB
/
private-agent_group_3.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
variable "num_of_private_agent_group_3" {
description = "DC/OS Private Agents Count"
default = 3
}
variable "aws_group_3_private_agent_az" {
description = "AWS Default Zone"
default = "c"
}
# Create a subnet to launch slave private node into
resource "aws_subnet" "default_group_3_private" {
vpc_id = "${aws_vpc.default.id}"
cidr_block = "${cidrsubnet(aws_vpc.default.cidr_block, 6, 10)}"
map_public_ip_on_launch = true
availability_zone = "${var.aws_region}${var.aws_group_3_private_agent_az}"
}
# Private agent instance deploy
resource "aws_instance" "agent_group_3" {
# The connection block tells our provisioner how to
# communicate with the resource (instance)
connection {
# The default username for our AMI
user = "${module.aws-tested-oses.user}"
# The connection will use the local SSH agent for authentication.
}
root_block_device {
volume_size = "${var.aws_agent_instance_disk_size}"
}
count = "${var.num_of_private_agent_group_3}"
instance_type = "${var.aws_agent_instance_type}"
# ebs_optimized = "true" # Not supported for all configurations
tags {
owner = "${coalesce(var.owner, data.external.whoami.result["owner"])}"
expiration = "${var.expiration}"
Name = "${data.template_file.cluster-name.rendered}-pvtagt-${count.index + 1}"
cluster = "${data.template_file.cluster-name.rendered}"
}
# Lookup the correct AMI based on the region
# we specified
ami = "${module.aws-tested-oses.aws_ami}"
# The name of our SSH keypair we created above.
key_name = "${var.ssh_key_name}"
# Our Security group to allow http and SSH access
vpc_security_group_ids = ["${aws_security_group.public_slave.id}", "${aws_security_group.http-https.id}", "${aws_security_group.any_access_internal.id}", "${aws_security_group.ssh.id}", "${aws_security_group.internet-outbound.id}"]
# We're going to launch into the same subnet as our ELB. In a production
# environment it's more common to have a separate private subnet for
# backend instances.
subnet_id = "${aws_subnet.default_group_3_private.id}"
# OS init script
provisioner "file" {
content = "${module.aws-tested-oses.os-setup}"
destination = "/tmp/os-setup.sh"
}
# We run a remote provisioner on the instance after creating it.
# In this case, we just install nginx and start it. By default,
# this should be on port 80
provisioner "remote-exec" {
inline = [
"sudo chmod +x /tmp/os-setup.sh",
"sudo bash /tmp/os-setup.sh",
]
}
lifecycle {
ignore_changes = ["tags.Name"]
}
availability_zone = "${var.aws_region}${var.aws_group_3_private_agent_az}"
}
# Execute generated script on agent
resource "null_resource" "agent_group_3" {
# Changes to any instance of the cluster requires re-provisioning
triggers {
cluster_instance_ids = "${null_resource.bootstrap.id}"
current_ec2_instance_id = "${aws_instance.agent_group_3.*.id[count.index]}"
}
# Bootstrap script can run on any instance of the cluster
# So we just choose the first in this case
connection {
host = "${element(aws_instance.agent_group_3.*.public_ip, count.index)}"
user = "${module.aws-tested-oses.user}"
}
count = "${var.num_of_private_agent_group_3}"
# Generate and upload Agent script to node
provisioner "file" {
content = "${module.dcos-mesos-agent.script}"
destination = "run.sh"
}
# Wait for bootstrapnode to be ready
provisioner "remote-exec" {
inline = [
"until $(curl --output /dev/null --silent --head --fail http://${aws_instance.bootstrap.private_ip}/dcos_install.sh); do printf 'waiting for bootstrap node to serve...'; sleep 20; done"
]
}
# Install Slave Node
provisioner "remote-exec" {
inline = [
"sudo chmod +x run.sh",
"sudo ./run.sh",
]
}
# Mesos poststart check workaround. Engineering JIRA filed to Mesosphere team to fix.
provisioner "remote-exec" {
inline = [
"sudo sed -i.bak '131 s/1s/10s/' /opt/mesosphere/packages/dcos-config--setup*/etc/dcos-diagnostics-runner-config.json &> /dev/null || true",
"sudo sed -i.bak '140 s/1s/10s/' /opt/mesosphere/packages/dcos-config--setup*/etc/dcos-check-config.json &> /dev/null || true",
"sudo sed -i.bak '162 s/1s/10s/' /opt/mesosphere/packages/dcos-config--setup*/etc/dcos-diagnostics-runner-config.json &> /dev/null || true"
]
}
}
#output "Private Agent Public IP Address" {
# value = ["${aws_instance.agent_group_3.*.public_ip}"]
#}