Skip to content

Latest commit

 

History

History
105 lines (68 loc) · 3.72 KB

README.md

File metadata and controls

105 lines (68 loc) · 3.72 KB

terraform-aws-fun-land

Basic scheme to have fun with multiple and isolated Hashicorp Terraform versions in one machine. This can help you to have several build environments each one with own aws credentials to perform tasks without re-work and not dirtying your operating system overwriting with different packages versions.

This scheme uses modified version of official Hashicorp Terraform dockerfile plus following tools installed:

Also docker is available inside container by docker-cli installation and docker socket shared from docker host to container

install-steps

1- Install docker on your enviroment, making your operational system as docker host

https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-on-ubuntu-20-04

2- Install docker-compose on your environment

https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-compose-on-ubuntu-20-04

3- Create basic directory to persist files

mkdir /storage-docker/

mkdir /storage-docker/ferramentas

4- Clone this repository

git clone https://github.com/etaques/tf_environment.git
cd tf_environment

Stand up the environment according your need

Set on terraform.dockerfile variables if you want:

ENV TERRAFORM_VERSION=1.0.8
ENV TF_LOG=TRACE
ENV TF_DEV=true
ENV TF_RELEASE=true
ENV AWS_ACCESS_KEY_ID=
ENV AWS_SECRET_ACCESS_KEY=

5.1- Standing up (portainer-ui + terraform_builder) without aws credentials

environment=dev docker-compose --project-name AWS_FUN_PLACE_1_V108 up -d --build

5.2- Standing up (portainer-ui + terraform_builder) injecting aws credentials

aws_access_key_id=XXXXXXX aws_secret_access_key=XXXXXXXX environment=dev docker-compose --project-name AWS_FUN_PLACE_2_V108 up -d --build

5.3- Standing up just terraform container (terraform_builder only) without aws credentials

build:

docker build -f terraform.dockerfile -t terraform_builder_108 .

Pay attention on this line to complete with correct path to not share with any existent container, in this case mine is dev

-v /storage-docker/ferramentas/terraform_data_dev:/data \

run:

docker run -d --name AWS_FUN_PLACE_3_V108 \
-v /var/run/docker.sock:/var/run/docker.sock \
-v /usr/local/bin/docker-compose:/usr/local/bin/docker-compose \
-v /storage-docker/ferramentas/terraform_data_dev:/data \
terraform_builder108

6- Access portainer UI and work on your containers at http://localhost:9000 easier

The folder /data inside terraform container is the persistent place to put your terraform project. If you did step 3, this is mapped on your docker host at directory:

/storage-docker/ferramentas/terraform_data_dev

Now you can work with terraform in various versions just changing terraform.dockerfile environment variables, also portainer UI can give your easy way to check whats running or access shell from a beauty interface

Have fun!

Basic Terraform commands:

Planning enviroment

~$ terraform plan

Creating enviroment

~$ terraform apply

Destroying enviroment

~$ terraform destroy