2020-04-07 02:43:16 +00:00
|
|
|
import pulumi
|
|
|
|
import json
|
|
|
|
import pulumi_aws as aws
|
|
|
|
|
2024-02-11 17:02:12 +00:00
|
|
|
# Read the default VPC and public subnets, which we will use.
|
2020-04-21 20:52:24 +00:00
|
|
|
vpc = aws.ec2.get_vpc(default=True)
|
|
|
|
subnets = aws.ec2.get_subnet_ids(vpc_id=vpc.id)
|
2020-04-07 02:43:16 +00:00
|
|
|
# Create a security group that permits HTTP ingress and unrestricted egress.
|
2020-04-21 17:24:42 +00:00
|
|
|
web_security_group = aws.ec2.SecurityGroup("webSecurityGroup",
|
2020-04-07 02:43:16 +00:00
|
|
|
vpc_id=vpc.id,
|
2020-08-06 22:09:23 +00:00
|
|
|
egress=[aws.ec2.SecurityGroupEgressArgs(
|
|
|
|
protocol="-1",
|
|
|
|
from_port=0,
|
|
|
|
to_port=0,
|
|
|
|
cidr_blocks=["0.0.0.0/0"],
|
|
|
|
)],
|
|
|
|
ingress=[aws.ec2.SecurityGroupIngressArgs(
|
|
|
|
protocol="tcp",
|
|
|
|
from_port=80,
|
|
|
|
to_port=80,
|
|
|
|
cidr_blocks=["0.0.0.0/0"],
|
|
|
|
)])
|
2020-04-07 02:43:16 +00:00
|
|
|
# Create an ECS cluster to run a container-based service.
|
|
|
|
cluster = aws.ecs.Cluster("cluster")
|
|
|
|
# Create an IAM role that can be used by our service's task.
|
2020-05-19 08:18:38 +00:00
|
|
|
task_exec_role = aws.iam.Role("taskExecRole", assume_role_policy=json.dumps({
|
2020-04-07 02:43:16 +00:00
|
|
|
"Version": "2008-10-17",
|
|
|
|
"Statement": [{
|
|
|
|
"Sid": "",
|
|
|
|
"Effect": "Allow",
|
|
|
|
"Principal": {
|
|
|
|
"Service": "ecs-tasks.amazonaws.com",
|
|
|
|
},
|
|
|
|
"Action": "sts:AssumeRole",
|
|
|
|
}],
|
2020-05-19 08:18:38 +00:00
|
|
|
}))
|
2020-04-21 17:24:42 +00:00
|
|
|
task_exec_role_policy_attachment = aws.iam.RolePolicyAttachment("taskExecRolePolicyAttachment",
|
2020-04-07 02:43:16 +00:00
|
|
|
role=task_exec_role.name,
|
|
|
|
policy_arn="arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy")
|
|
|
|
# Create a load balancer to listen for HTTP traffic on port 80.
|
2020-04-21 17:24:42 +00:00
|
|
|
web_load_balancer = aws.elasticloadbalancingv2.LoadBalancer("webLoadBalancer",
|
2020-04-07 02:43:16 +00:00
|
|
|
subnets=subnets.ids,
|
|
|
|
security_groups=[web_security_group.id])
|
2020-04-21 17:24:42 +00:00
|
|
|
web_target_group = aws.elasticloadbalancingv2.TargetGroup("webTargetGroup",
|
2020-04-07 02:43:16 +00:00
|
|
|
port=80,
|
|
|
|
protocol="HTTP",
|
|
|
|
target_type="ip",
|
|
|
|
vpc_id=vpc.id)
|
2020-04-21 17:24:42 +00:00
|
|
|
web_listener = aws.elasticloadbalancingv2.Listener("webListener",
|
2020-04-07 02:43:16 +00:00
|
|
|
load_balancer_arn=web_load_balancer.arn,
|
|
|
|
port=80,
|
2020-08-06 22:09:23 +00:00
|
|
|
default_actions=[aws.elasticloadbalancingv2.ListenerDefaultActionArgs(
|
|
|
|
type="forward",
|
|
|
|
target_group_arn=web_target_group.arn,
|
|
|
|
)])
|
2020-04-07 02:43:16 +00:00
|
|
|
# Spin up a load balanced service running NGINX
|
2020-04-21 17:24:42 +00:00
|
|
|
app_task = aws.ecs.TaskDefinition("appTask",
|
2020-04-07 02:43:16 +00:00
|
|
|
family="fargate-task-definition",
|
|
|
|
cpu="256",
|
|
|
|
memory="512",
|
|
|
|
network_mode="awsvpc",
|
|
|
|
requires_compatibilities=["FARGATE"],
|
|
|
|
execution_role_arn=task_exec_role.arn,
|
|
|
|
container_definitions=json.dumps([{
|
|
|
|
"name": "my-app",
|
|
|
|
"image": "nginx",
|
|
|
|
"portMappings": [{
|
|
|
|
"containerPort": 80,
|
|
|
|
"hostPort": 80,
|
|
|
|
"protocol": "tcp",
|
|
|
|
}],
|
|
|
|
}]))
|
2020-04-21 17:24:42 +00:00
|
|
|
app_service = aws.ecs.Service("appService",
|
2020-04-07 02:43:16 +00:00
|
|
|
cluster=cluster.arn,
|
|
|
|
desired_count=5,
|
|
|
|
launch_type="FARGATE",
|
|
|
|
task_definition=app_task.arn,
|
2020-08-06 22:09:23 +00:00
|
|
|
network_configuration=aws.ecs.ServiceNetworkConfigurationArgs(
|
|
|
|
assign_public_ip=True,
|
|
|
|
subnets=subnets.ids,
|
|
|
|
security_groups=[web_security_group.id],
|
|
|
|
),
|
|
|
|
load_balancers=[aws.ecs.ServiceLoadBalancerArgs(
|
|
|
|
target_group_arn=web_target_group.arn,
|
|
|
|
container_name="my-app",
|
|
|
|
container_port=80,
|
|
|
|
)],
|
2024-06-11 14:56:08 +00:00
|
|
|
opts = pulumi.ResourceOptions(depends_on=[web_listener]))
|
2020-04-21 16:18:09 +00:00
|
|
|
pulumi.export("url", web_load_balancer.dns_name)
|