Skip to content

Latest commit

 

History

History
 
 

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 

05. Container Build

Now that we are able to build our application, we would want to be able to build a container image that contains our JAR file. Once we build our container image we would need to store it into a container repository.

For that purpose we can use Docker Hub or any other free or paid container registry. Create an account in your registry of choice if you don't have one. Once you do that, as a best practice create a Personal Access Token that will be used by Jenkins to push images inside your registry account.

Create Jenkins secrets

In order for the Jenkins pipeline to be able to push images to the container registry (in this case, Docker Hub) we would need to authenticate with it in some way.

Go to Docker Hub -> Account Settings -> Security.

Click New Access Token and populate the form fields. For Access permission select Read, Write, Delete. Click Generate. Docker Hub will generate a token for you. Copy the token.

NOTE: Once you close the pop-up you will never see this token again, so make sure you have copied it before you close the pop-up.

In Jenkins, go to Manage Jenkins -> Manage Credentials -> System -> Global credentials -> Add credentials. In the form, select Secret text for Kind. In the Secret field paste the token from Docker Hub. In the ID field write something like DOCKER_REGISTRY_PASSWORD.

Finish the process by clicking Create.

Voila, we have created a Jenkins secret that holds our container registry access token.

Create another Pipeline Stage

Once we have our registry account in place, and have provided Jenkins with the credentials for it, we can write the next stage that will build and push our container image.

Paste the following stage snippet after the two stages from the previous section:

pipeline {
    agent none

    stages {
        // stages from the previous section

        stage('Docker Build and Push') {
            agent any

            environment {
                DOCKER_HUB_PASSWORD = credentials('DOCKER_HUB_PASSWORD')
            }

            steps {
                sh 'docker build -t <docker_hub_username>/webgoat .'
                sh 'docker login -u <docker_hub_username> -p ${DOCKER_HUB_PASSWORD}'
                sh 'docker push <docker_hub_username>/webgoat'
            }
        }
    }
}

This tell Jenkins to build the container image from the Dockerfile that is inside the WebGoat root directory. It tags the image with the right tag and pushes it to the container registry.

NOTE: If you are using registry different than Docker Hub, you would also need to prefix the tag with the registry domain name, e.g. if you are using quay.io your tag will be something like quay.io/<username>/webgoat.

In this stage we built our container image and pushed it to a container registry. We are almost ready to run our application container. But first, we are going to apply some security scanning in the next section.