🏢 This directory contains the Terraform configuration for our core cloud infrastructure. It provides a ready-to-use Terraform module with essential services and security features.
- ✨ Comprehensive Root Terraform module for quick deployment.
- 🗄️ Configured to use an external S3 bucket for Terraform state management with a DynamoDB table for state locking.
- 🐘 RDS Postgres setup for reliable database services.
- 🔒 Utilization of AWS Secrets Manager for secure storage of database credentials.
- 🔧 Use of SSM Parameter Store for managing network and service parameters.
- Direnv for loading environment variables.
- Terraform for infrastructure provisioning.
- TFswitch to switch between Terraform versions easily.
-
Change Directory:
Navigate to the directory containing the Terraform configuration:
cd live/common-infra
-
Create .envrc file:
Create a new
.envrc
file in this directory by copying the.envrc.example
file:cp .envrc.example .envrc
Then, update the
.envrc
file with the values for your environment! -
Load Environment Variables:
Load the environment variables using
direnv
:direnv allow
-
Set Terraform Version:
Ensure you are using the correct Terraform version:
tfswitch
-
Initialize Terraform:
Initialize the working directory with the required providers and modules:
terraform init -backend-config="./configs/${ENVIRONMENT}-backend.tfvars"
-
Workspace Management:
Select or create a new workspace tailored to your deployment environment:
# Select an existing workspace terraform workspace select "${TF_WORKSPACE}" # Create a new workspace if it doesn't exist and select it terraform workspace new "${TF_WORKSPACE}"
🚀 Deployment Instructions:
-
Plan Your Deployment:
Review and verify the deployment plan:
terraform plan -var-file "./configs/${ENVIRONMENT}.tfvars" -out "${ENVIRONMENT}.tfplan"
-
Execute the Plan:
Apply the planned configuration to provision the infrastructure:
terraform apply "${ENVIRONMENT}.tfplan"
After successfully deploying the infrastructure, follow these steps to test the deployment and ensure everything is working as expected:
AWS Session Manager provides secure and auditable instance management without needing to open inbound ports, manage SSH keys, or use bastion hosts. To connect to the bastion host using Session Manager, follow these steps:
You can check the Bastion Host Module documentation for detailed steps on connecting to the bastion host using Session Manager: Connect to Bastion Host Using Session Manager.
To connect to the database from the bastion host, retrieve the connection information from AWS Secrets Manager. Follow these steps:
- Outside the bastion host:
db_host=$(terraform output -json | jq -r '.example_db_instance_address.value')
db_port=$(terraform output -json | jq -r '.example_db_instance_port.value')
db_name=$(terraform output -json | jq -r '.example_db_instance_name.value')
# Retrieve the parameter value from the AWS Parameter Store
SECRET_ID=$(terraform output -json | jq -r '.example_db_instance_master_user_secret_arn.value')
# Print the values
echo "DB Host: $db_host"
echo "DB Port: $db_port"
echo "DB Name: $db_name"
echo "Secret ID: $SECRET_ID"
- Inside the bastion host:
# Retrieve the connection information from AWS Secrets Manager
db_secret=$(aws secretsmanager get-secret-value --secret-id "$SECRET_ID" \
--query 'SecretString' --output json)
# Parse the connection information to obtain the username, password, host, port, and database name
db_username=$(echo $db_secret | jq -r '.username')
db_password=$(echo $db_secret | jq -r '.password')
# Connect to the database using Psql with Docker
docker run -it --rm postgres:14.0-alpine psql -h $db_host -p $db_port -U $db_username -d $db_name
You can now execute SQL commands to test the database setup. For example:
- Retrieve the current date and time:
> SELECT NOW();
- Check the database version:
> SELECT version();
- List the tables in the database:
> SELECT table_name FROM information_schema.tables WHERE table_schema = 'public';
These steps will help you verify the successful setup of the database and ensure that the necessary connections and configurations are in place.
To destroy the infrastructure, run the following command:
terraform destroy -var-file "./configs/${ENVIRONMENT}.tfvars"
The module documentation is generated with terraform-docs by running the following command from the module directory:
terraform-docs md . > ./docs/MODULE.md
You can also view the latest version of the module documentation here.