Overview
This project demonstrates a complete Continuous Integration and Continuous Deployment (CI/CD) pipeline using AWS services. It automates the process of building, testing, scanning, and deploying a Docker image to an Amazon EC2 instance.
Architecture
Workflow:
- User Commit: The user commits code to AWS CodeCommit.
- CodePipeline: Triggers automatically on code changes in the repository.
- CodeBuild: Check out the code. Executes build and unit tests. Scans the code for vulnerabilities. Builds the Docker image. Scans the Docker image. Pushes the Docker image to a container registry (e.g., Amazon ECR).
- CodeDeploy: Deploys the Docker image to an Amazon EC2 instance.
Tools Used
👉 AWS CodeCommit: Stores the source code and version control. 👉 AWS CodePipeline: Orchestrates the CI/CD workflow. 👉 AWS CodeBuild: Executes build, unit tests, code scan, image build, and image scan. 👉 AWS CodeDeploy: Deploys the built image to the target EC2 instance. 👉 Amazon EC2: Hosts the application after deployment.
Detailed Pipeline Breakdown
- Checkout: Pulls the latest code from CodeCommit.
- Build & UT: Runs build steps and unit tests using CodeBuild.
- Code Scan: Performs static code analysis for security and code quality.
- Image Build: Constructs a Docker image of the application.
- Image Scan: Checks for vulnerabilities in the built Docker image.
- Image Push: Pushes the final image to Amazon Elastic Container Registry (ECR).
- Deployment: CodeDeploy picks the image and deploys it to the Amazon EC2 instance.
Conclusion
This AWS DevOps pipeline automates the entire process of building, testing, scanning, and deploying your application, ensuring quicker releases and improved software quality.