This project is demo used to present the talk "Building labs using component-based architecture with terraform and ansible".
This demo can be used as inspiration to create a similar project and enable developers to automatically spin up environments with all the required OS distributions with all needed configuration.
You can use one of configuration sample as inspiration for to create your own configuration file. The file must be named as input.tfvars
and placed in this project's root path.
You can copy one of the samples in order to deploy a demo environment:
cp examples/<name>.tfvars input.tfvars
Run docker compose to setup a docker instance with all needed tools:
docker-compose -f docker/docker-compose.yml build
docker-compose -f docker/docker-compose.yml up -d
-
All steps must be executed in the container
lab_builder
. Use a bash session for that:-
Start a bash session:
docker exec -it lab_builder bash
-
-
AWS short-term credentials:
- Check the official documentation
-
Deploy the lab:
make lab-deploy
-
Destroy the lab:
make lab-destroy
-
Retrieve information about the lab(IPs, IDs, configs, etc):
make lab-info
The lab builder has a feature to stop and start ec2 instances to avoid wastage in the cloud.
⚠️ This will make the terraform state to be of sync with AWS: Runmake lab-deploy
after starting the lab instances, in order to update the lab configuration.
Steps:
-
Stop all lab instances:
make instances-stop
-
Start all lab instances:
make instances-start
-
Retrieve instances status for all lab instances:
make instances-status
-
Deploy the lab to update the changes (Run after all instances change the status to
running
):make lab-deploy
Depending on the type, the lab builder allows managing the instances manually through SSH, and RDP. Use make instances-credentials
to retrieve the credentials for each instance.
-
Retrieve credentials for all lab instances.
make instances-credentials