AWS
Setting Up Infrastructure with Terraform
To automate and streamline the deployment of infrastructure for CREDEBL, we use Terraform.
You can easily deploy the required infrastructure by following the steps below.
Prerequisites
- Terraform installed on your local machine. You can download it from the official Terraform website. 
- An AWS account with the appropriate permissions to create and manage resources. - The following AWS permissions are required for this deployment: - EC2 Full Access 
- S3 Full Access 
- CloudWatch Full Access 
- ECR (Elastic Container Registry) Full Access 
- ECS (Elastic Container Service) Full Access 
- EFS (Elastic File System) Full Access 
- VPC Full Access 
- IAM Full Access 
 
- Ensure the cloud provider’s CLI (e.g., AWS CLI) is installed and configured on your local machine with valid credentials. You can follow the AWS CLI configuration guide to set it up. 
Steps to Deploy
- Clone the Repository: First, get the code from the repository: - git clone https://github.com/credebl/install.git cd install/terraform-scripts
- Configure AWS: Ensure that your AWS credentials are set up. Run the following command to configure the AWS CLI if not done already: - aws configure- This will prompt you for your AWS Access Key, Secret Access Key, Region, and Output format. 
- Create and Configure - terraform.tfvarsFile: Before initiating the deployment, create a- terraform.tfvarsfile on path- terraform-script/aws/platform. Open the- terraform.tfvarsfile and add values to the variables. These values will be used to customize your deployment, such as the AWS region, instance type, and other required settings. Example:- aws_region = "us-west-2"
Ensure all required variables are set before proceeding.
- Initialise Terraform: Initialise the directory containing Terraform files to install the required AWS provider: - terraform init
- Preview the Infrastructure Changes: Run the following command to preview the changes that Terraform will make to your AWS infrastructure: - terraform plan
- Deploy the Infrastructure: When ready, deploy the resources using the following command: - terraform apply
- Confirm the Deployment: Type - yeswhen prompted to confirm and proceed with creating the AWS resources.
Post-Deployment Steps
- Create and Configure the - .envFile: After the deployment, a- .envfile will be created with Environment name. Open the file and add the necessary values to configure your environment. For example:- DATABASE_URL=<your-database-url> API_KEY=<your-api-key> SECRET_KEY=<your-secret-key>- Ensure all required variables are added and saved before proceeding. 
- Upload the - .envFile to S3: Once you've configured the- .envfile, you’ll need to upload it to the S3 bucket that was created during the deployment.
- Update ECS Service: Navigate to the ECS (Elastic Container Service) in the AWS Console. Go to the Cluster that was created. Inside the cluster, locate the Services and set the Desired Task Count to - 1(or your desired number of tasks) to launch the container.- This step will start your application as defined in the ECS service. 
Tearing Down AWS Resources
To delete the AWS resources created by Terraform, run the following command:
terraform destroyNotes
- For setting up NATS keys for authorization, please refer to the documentation on NATS authorization for more details. 
- Ensure that the required AWS IAM roles and permissions are in place before deploying. 
- For additional details or troubleshooting, refer to the Terraform AWS Provider documentation and the Terraform documentation. 
Last updated

