Create Backend CodeBuild
Create Backend CodeBuild
- Access AWS Console and search for CodeBuild in the menu
- Select Build project
- Click Create project
- Enter Project name:
aws-fcj-container-be
data:image/s3,"s3://crabby-images/527b0/527b083faa639aff76a8147375fd0bf9e4b4282a" alt="create-project"
Configure Source:
- Select GitHub as Source provider
- Choose Personal access
- Select Personal access token
- For Connection, choose the secret created earlier
- Select Repository in my GitHub account
- Paste the HTTPS URL into GitHub repository field (URL copied from step 6.2)
- Source version:
refs/tags/*
data:image/s3,"s3://crabby-images/083ea/083eab40708aff68ea41bcb0f7dc903330dd8363" alt="source-config"
In the Primary source webhook events section:
- Webhook: Select Rebuild every time a code change is pushed to the repository
- Choose Single build
- Event type: PUSH
- Enter HEAD_REF:
HEAD_REF
- Enter Pattern:
^refs/tags/
data:image/s3,"s3://crabby-images/74545/7454591244e21f47504ad4c626ae176ce355ef86" alt="webhook-config"
Configure environment:
- Provisioning model:
On-demand
- Environment image:
Managed image
- Compute: EC2
- Operating system: Ubuntu
- Runtime: Standard
- Image: aws/codebuild/standard:7.0
- Image version: Always use latest image for version
- Service role: New service role
- Role name:
codebuild-aws-fcj-container-be-service-role
data:image/s3,"s3://crabby-images/be322/be3225e619fc2e42ab3211162cca923ebab18851" alt="environment"
Expand Additional configuration
data:image/s3,"s3://crabby-images/a81c5/a81c5d9afa1dc2464b5de75ce09888aa3bd80f47" alt="additional-config"
- Click Add environment variable
- Add environment variables according to the table:
data:image/s3,"s3://crabby-images/ae21f/ae21fb7743d49a1531fd9ad567dc7150eaf5e912" alt="env-variables"
- Click Create build project to complete
data:image/s3,"s3://crabby-images/4293c/4293c48d14584c2f7b471581bca82dd226583e72" alt="create-complete"
Add role for BE CodeBuild
After creating the build project:
- Access the newly created build project
data:image/s3,"s3://crabby-images/bee41/bee414cd35e99e01038663ec2642663114e6fe8a" alt="access-project"
- In the Service role section, click on the role to navigate to IAM management
data:image/s3,"s3://crabby-images/532f5/532f5f49f4bf74a9f96e853189083e3246d296b6" alt="service-role"
Add permissions to the role:
- Select Add permissions
- Choose Attach policy
- Search and select these policies:
AmazonECS_FullAccess
CloudWatchLogsFullAccess
WriteECRRepositoryContent
- Click Attach policies
data:image/s3,"s3://crabby-images/2ef00/2ef000ab840181cb1c6dff9bb24655513732e3ca" alt="attach-policies"