- Get spurce code from Github, CodeCommit, CodePipeline, S3 …
- Build instructions are in buildspec.yml file
- Build logs to S3 and CloudWatch logs
- CloudWatch metrics for build statistics
- CloudWatch events to detect failed builds
- CloudWatch alarms and SNS notifications
- Create a Build Project
- Define Source for the code build, choose CodeCommit
- Choose a reference type (Branch, Git tag and Commit ID)
- Choose a Service Role (automatic)
- Can define additional configuration(timeout, queue timeout..)
- Can setup env var
- buildspec file
- Artifacts
- Logs –> CloudWatch or S3
- Click Create build project
- Click Start Build –> docker container will start…
- Check status and build duration in Build History
buildspec.yml
data:image/s3,"s3://crabby-images/cfa69/cfa6945968d56fac0c3a31fc1751f6dab95e30dc" alt=""
Check Build projects / Build project, you can see the phases and their durations
Artifacts
Environment variables and Parameter Store
–> printenv
Check AWS_REGION for eg
You can define env. Even secrets with SSM Paameter Store (SecureString with KMS key)
You must have IAM a read policy for codebuild to access SSM –> add AmazonSSMReadOnlyAccess policy to the user
data:image/s3,"s3://crabby-images/76345/76345e374c581d6e71dab9772672d06b9ef61eb2" alt=""
Artifacts and S3
Generate output files
data:image/s3,"s3://crabby-images/8c31b/8c31b92078c9fb3a71c84d6dae40fec26d557ebb" alt=""
CodeBuild / Buid Project / Edit Artifacts