-
Notifications
You must be signed in to change notification settings - Fork 9
/
main.tf
75 lines (58 loc) · 1.76 KB
/
main.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
provider "aws" {
region = "eu-west-1"
}
##################################################################
# Data sources to get VPC, subnet, security group and AMI details
##################################################################
data "aws_vpc" "default" {
default = true
}
data "aws_subnet_ids" "all" {
vpc_id = "${data.aws_vpc.default.id}"
}
data "aws_ami" "centos" {
most_recent = true
owners = ["679593333241"]
filter {
name = "architecture"
values = ["x86_64"]
}
filter {
name = "root-device-type"
values = ["ebs"]
}
filter {
name = "virtualization-type"
values = ["hvm"]
}
filter {
name = "name"
values = ["CentOS Linux 7*"]
}
}
module "security_group" {
source = "terraform-aws-modules/security-group/aws"
name = "minishift-aws"
description = "Security group for Minishift on AWS"
vpc_id = "${data.aws_vpc.default.id}"
ingress_cidr_blocks = ["${var.access_ip}"]
ingress_rules = ["all-all"]
egress_rules = ["all-all"]
}
module "ec2" {
source = "terraform-aws-modules/ec2-instance/aws"
instance_count = 1
name = "minishift-aws"
key_name = "minishift-aws"
ami = "${data.aws_ami.centos.id}"
instance_type = "${var.instance_type}"
cpu_credits = "unlimited"
subnet_id = "${element(data.aws_subnet_ids.all.ids, 0)}"
vpc_security_group_ids = ["${module.security_group.this_security_group_id}"]
associate_public_ip_address = true
root_block_device = [{ "volume_size" = "${var.instance_rootfs_size}" }]
}
resource "aws_key_pair" "ec2_pubkey" {
key_name = "minishift-aws"
public_key = "${file("${var.ssh_pubkey_path}")}"
}