data:image/s3,"s3://crabby-images/1d14c/1d14c52cc69cd38c4936af93ab88bbc1a39fefcc" alt=""
Scope of the blog:
- Build the Docker image
- Scan with Trivy and generate the report in the Azure DevOps
- Publish the report to the Pipeline Status page
Required Pre-requisites:
- Source Code Containing the Dockerfile in the Azure DevOps.
STEPS:
- Source Code with the Dockerfile
data:image/s3,"s3://crabby-images/d3c5c/d3c5cab87334b98eb755471ffcd7a107cc12e995" alt=""
- Create a new pipeline for this docker image build, to do go to Azure DevOps Project -> Pipeline -> New Pipeline
data:image/s3,"s3://crabby-images/f28ff/f28ff9e80abdcaec6726410acd327f6e62cd0181" alt=""
- Chose the Azure Repos Git
data:image/s3,"s3://crabby-images/ed764/ed76418e51a5abb2e863a52f5e9bf3490eaf1f54" alt=""
- Select the repository which we have created for the docker image build
data:image/s3,"s3://crabby-images/9f9ea/9f9ea75531acdaf76ab42a1d6c14b4d2d3b7897e" alt=""
- Now click on the starter pipeline
data:image/s3,"s3://crabby-images/38431/3843175dd8b76d5b87092d6259a3e5d12caef236" alt=""
- Now, add a Bash script task or Docker task to build the image.
Note: I’m using a Bash task for a quick setup.
data:image/s3,"s3://crabby-images/0ae1c/0ae1cc3a02aeaebc3bc1b407302cbfd9aa0d8014" alt=""
- Now, create another task to scan the Docker image using Trivy. To do this, search for the task named ‘Trivy: Take control of your application security’ on the right side.
data:image/s3,"s3://crabby-images/37328/373288564754339e9299670cc7e2c58a7682daef" alt=""
- Click on that task and paste the image name and click add
data:image/s3,"s3://crabby-images/9dd19/9dd19188df9ecec937c15338b4a3a7c000bc48a8" alt=""
- Once the task is added, it looks like this below
data:image/s3,"s3://crabby-images/aebb0/aebb0f022f873ed7bedfe038242ff4ee20a75213" alt=""
- Don’t forget to set the exit code to ‘0’; otherwise, if any vulnerabilities are found, it will cause the pipeline to fail.
- Validate and save the pipeline, it will trigger the pipeline.
data:image/s3,"s3://crabby-images/e4f84/e4f84f84112eecf0862f70189528680eb9add7d5" alt=""
- Once the pipeline run is completed, click on the run history. At the top, you’ll see ‘Trivy’ next to ‘Summary.’ Click on ‘Trivy’ to view the scan results.
data:image/s3,"s3://crabby-images/76287/76287c9db0b10499f6633bf836331c37cfacd783" alt=""
Scan Result:
data:image/s3,"s3://crabby-images/4282b/4282b1a9f6679d3154f58ab491835a94fe7481bd" alt=""
Pipeline Code:
trigger:
- main
pool:
vmImage: ubuntu-latest
steps:
- task: Bash@3
inputs:
targetType: 'inline'
script: |
# Write your commands here
echo 'Building Docker Image'
docker build -t hellow-world:latest .
echo 'Building Docker Image Completed'
displayName: Build Docker Image
- task: trivy@1
inputs:
version: 'latest'
image: 'hellow-world:latest'
exitCode: '0'
displayName: Scan Docker Image