Skip to content

nadnerb/terraform-ecs-clamav

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Setting up an AWS ECS service (ClamAV) using Terraform

The following project deploys an ECS service to AWS. This example uses installs a clamav container, however any docker container can be substituted.

This assumes that you have a running ECS cluster in AWS. If you are continuing on from the previous project we are in the third part of the series.

Overall series Architecture

alt text

Setting up

Helper script

Within the project I have written a helper script called run.sh, it is very simple but will ensure that you always use the correct workspace with the accompanying variables file. It can be use like this:

It also uses an AWS profile matching the workspace name.

./run.sh plan prod

The above example will run a terraform plan on the prod workspace. It looks in the workspace-variables directory for a variable file called prod.tfvars, the same name as we used for the workspace.

The run.sh is very basic and currently does not support extra parameters. Basic useage of terraform plan, apply and destroy work fine.

If you don't want to use the run script, you can see the command that we use to run terraform in the script itself.

Configuration

As mentioned above, we provide and override variables with a file matching the name of our workspace in the workspace-variables directory. An example would look like this:

zone_name = "oculo"
ecs_cluster_name = "services"
iam_role = "ecs-role"

ecs_cluster_id = "arn:aws:ecs:ap-southeast-2:ID:cluster/yourservices"
vpc_id = "vpc-example"
availability_zones = "ap-southeast-2a,ap-southeast-2b,ap-southeast-2c"
subnet_ids = "subnet-example1,subnet-example2,subnet-example3"
cidr_blocks = "172.31.0.0/16"

Deploying our infrastructure

./run.sh plan yourworkspacename

If this all works as expected with no errors you can then apply the changes.

./run.sh apply yourworkspacename

You should see something like the following:

Apply complete! Resources: x added, 0 changed, 0 destroyed.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published