-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathec2.tf
49 lines (41 loc) · 2.11 KB
/
ec2.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
resource "aws_instance" "database" {
ami = data.aws_ssm_parameter.ubuntu_latest.value
instance_type = "t3.micro"
subnet_id = aws_subnet.private[0].id
vpc_security_group_ids = [aws_security_group.database.id]
private_ip = var.database_private_ip
key_name = var.ec2_key_pair
tags = { "Name" = "${var.default_tags.project}-database" }
user_data = base64encode(templatefile("${path.module}/scripts/database.sh", {
DATABASE_SERVICE_NAME = var.database_service_name # getting the variables from Terraform into the script
DATABASE_MESSAGE = var.database_service_message
}))
depends_on = [aws_nat_gateway.nat]
}
resource "aws_instance" "consul_server" {
count = var.consul_server_count
ami = data.aws_ssm_parameter.ubuntu_latest.value
instance_type = "t2.micro"
subnet_id = aws_subnet.private[count.index].id
associate_public_ip_address = false
key_name = var.ec2_key_pair
vpc_security_group_ids = [aws_security_group.consul_server.id]
private_ip = local.server_private_ips[count.index]
iam_instance_profile = aws_iam_instance_profile.consul_instance_profile.name
tags = {
"Name" = "${var.default_tags.project}-consul-server"
}
user_data = base64encode(templatefile("${path.module}/scripts/server.sh", {
CA_PUBLIC_KEY = tls_self_signed_cert.ca_cert.cert_pem
CONSUL_SERVER_PUBLIC_KEY = tls_locally_signed_cert.consul_server_signed_cert.cert_pem
CONSUL_SERVER_PRIVATE_KEY = tls_private_key.consul_server_key.private_key_pem
CONSUL_BOOTSTRAP_TOKEN = random_uuid.consul_bootstrap_token.result
CONSUL_GOSSIP_KEY = random_id.consul_gossip_key.b64_std
CONSUL_SERVER_COUNT = var.consul_server_count
CONSUL_SERVER_DATACENTER = var.consul_dc1_name
AUTO_JOIN_TAG = "Name"
AUTO_JOIN_TAG_VALUE = "${var.default_tags.project}-consul-server"
SERVICE_NAME_PREFIX = local.project_tag
}))
depends_on = [aws_nat_gateway.nat]
}