Skip to content
This repository has been archived by the owner on Jul 11, 2023. It is now read-only.

Commit

Permalink
New function: single-node-asg module supports binding EIP by itself.
Browse files Browse the repository at this point in the history
Since it is single node, binding an EIP to the instance is possible. And
it eases other things since the public interface is constant.

Add assign_eip variable to single-node-asg. If turns it on, an EIP will
be allocated, and assocated with the instance.
  • Loading branch information
Magicloud committed Dec 10, 2019
1 parent 10779bd commit 269149c
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 22 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@


### Modules

* `single-node-asg`: New function: support associating EIP.

### Examples

Expand Down
68 changes: 49 additions & 19 deletions modules/single-node-asg/main.tf
Original file line number Diff line number Diff line change
Expand Up @@ -52,35 +52,59 @@ module "service-data" {
iam_instance_profile_role_name = module.instance_profile.iam_role_name
}

resource "aws_eip" "eip" {
count = var.assign_eip ? 1 : 0
}

resource "aws_iam_role_policy_attachment" "associate_eip" {
role = module.instance_profile.iam_role_name
policy_arn = aws_iam_policy.associate_eip_policy.arn
}

resource "aws_iam_policy" "associate_eip_policy" {
name = "associate_address"
policy = data.aws_iam_policy_document.associate_eip_policy_doc.json
}

data "aws_iam_policy_document" "associate_eip_policy_doc" {
statement {
sid = ""
effect = "Allow"
actions = [
"ec2:AssociateAddress"
]
resources = ["*"]
}
}

# Create an ASG with just 1 EC2 instance
module "server" {
source = "../asg"

ami = var.ami
azs = [local.az]
elb_names = var.load_balancers
key_name = var.key_name
# The IAM Instance Profile w/ attach_ebs role
iam_profile = module.instance_profile.iam_profile_id
instance_type = var.instance_type
# 1 EC2 instance <> 1 EBS volume
max_nodes = 1
min_nodes = 1
placement_group = var.placement_group
public_ip = var.public_ip
# the prefix and suffix names are combined in
# the `asg` module to create the full name
name_prefix = var.name_prefix
name_suffix = "${var.name_suffix}-${local.az}"

ami = var.ami
elb_names = var.load_balancers
key_name = var.key_name
iam_profile = module.instance_profile.iam_profile_id
instance_type = var.instance_type
max_nodes = 1
min_nodes = 1
placement_group = var.placement_group
public_ip = var.public_ip
name_prefix = var.name_prefix
name_suffix = "${var.name_suffix}-${local.az}"
root_volume_type = var.root_volume_type
root_volume_size = var.root_volume_size
security_group_ids = var.security_group_ids
subnet_ids = [var.subnet_id]

user_data = <<END_INIT
#!/bin/bash
apt update
${var.init_prefix}
${module.init-install-awscli.init_snippet}
while ! ${var.assign_eip ? "aws ec2 associate-address --instance-id \"$(ec2metadata --instance-id)\" --region \"${var.region}\" --allocation-id \"${element(aws_eip.eip.*.id, 0)}\"" : "true"}; do
sleep 1
done
${module.init-attach-ebs.init_snippet}
${var.init_suffix}
END_INIT
Expand All @@ -89,7 +113,13 @@ END_INIT

# Render init snippet - boxed module to attach the EBS volume to the node
module "init-attach-ebs" {
source = "../init-snippet-attach-ebs-volume"
region = var.region
source = "../init-snippet-attach-ebs-volume"
region = var.region
volume_id = module.service-data.volume_id
}

module "init-install-awscli" {
source = "../init-snippet-install-awscli"
}


4 changes: 4 additions & 0 deletions modules/single-node-asg/outputs.tf
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,7 @@ output "asg_iam_role_name" {
value = module.instance_profile.iam_role_name
description = "`name` exported from the Service Data `aws_iam_role`"
}

output "eip_address" {
value = aws_eip.eip.*[0].public_ip
}
9 changes: 7 additions & 2 deletions modules/single-node-asg/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ variable "data_volume_size" {
variable "data_volume_encrypted" {
default = true
description = "Boolean, whether or not to encrypt the EBS block device"
type = string
type = bool
}

variable "data_volume_kms_key_id" {
Expand Down Expand Up @@ -92,7 +92,7 @@ variable "init_suffix" {
variable "public_ip" {
default = true
description = "Boolean flag to enable/disable `map_public_ip_on_launch` in the launch configuration"
type = string
type = bool
}

variable "subnet_id" {
Expand All @@ -116,3 +116,8 @@ variable "load_balancers" {
type = list(string)
}

variable "assign_eip" {
default = false
description = "Whether or not associating an EIP with the node."
type = bool
}

0 comments on commit 269149c

Please sign in to comment.