Build and Deploy a Maven Project

Prerequisites

Workflow for a Maven Project

As is shown in the graph below, there is the workflow for a Maven project in KubeSphere DevOps, which uses a Jenkins pipeline to build and deploy the Maven project. All steps are defined in the pipeline.

maven-project-jenkins

At first, the Jenkins Master creates a Pod to run the pipeline. Kubernetes creates the Pod as the agent of Jenkins Master, and the Pod will be destroyed after the pipeline finished. The main process includes cloning code, building and pushing an image, and deploying the workload.

Default Configurations in Jenkins

Maven version

Execute the following command in the Maven builder container to get version information.

  1. mvn --version
  2. Apache Maven 3.5.3 (3383c37e1f9e9b3bc3df5050c29c8aff9f295297; 2018-02-24T19:49:05Z)
  3. Maven home: /opt/apache-maven-3.5.3
  4. Java version: 1.8.0_232, vendor: Oracle Corporation
  5. Java home: /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.232.b09-0.el7_7.i386/jre
  6. Default locale: en_US, platform encoding: UTF-8

Maven cache

The Jenkins Agent mounts the directories by Docker Volume on the node. The pipeline can cache some special directories such as /root/.m2, which are used for Maven building and the default cache directory for Maven tools in KubeSphere DevOps, so that dependency packages are downloaded and cached on the node.

Global Maven settings in the Jenkins Agent

The default file path of Maven settings is maven and the configuration file path is /opt/apache-maven-3.5.3/conf/settings.xml. Execute the following command to get the content of Maven settings.

  1. kubectl get cm -n kubesphere-devops-system ks-devops-agent -o yaml

Network of Maven Pod

The Pod labeled maven uses the docker-in-docker network to run the pipeline. Namely, /var/run/docker.sock in the node is mounted to the Maven container.

A Maven Pipeline Example

Prepare for the Maven project

Create credentials

Credential IDTypeUse
dockerhub-idAccount CredentialsRegistry, such as Docker Hub
demo-kubeconfigkubeconfigDeploy workloads

For details, refer to the Credential Management.

view-credential-list

Create a project for workloads

In this example, all workloads are deployed in kubesphere-sample-dev. You must create the project kubesphere-sample-dev in advance.

view-namespace

Create a pipeline for the Maven project

  1. Go to Pipelines of your DevOps project and click Create. For more information, see Create a Pipeline - using Graphical Editing Panel.

  2. Go to the detail page of the pipeline and click Edit Jenkinsfile.

    edit-jenkinsfile

  3. Copy and paste the following content into the pop-up window. You must replace the value of DOCKERHUB_NAMESPACE with yours. When you finish, save it.

    1. pipeline {
    2. agent {
    3. node {
    4. label 'maven'
    5. }
    6. }
    7. parameters {
    8. string(name:'TAG_NAME',defaultValue: '',description:'')
    9. }
    10. environment {
    11. DOCKER_CREDENTIAL_ID = 'dockerhub-id'
    12. KUBECONFIG_CREDENTIAL_ID = 'demo-kubeconfig'
    13. REGISTRY = 'docker.io'
    14. // need to replace by yourself dockerhub namespace
    15. DOCKERHUB_NAMESPACE = 'shaowenchen'
    16. APP_NAME = 'devops-java-sample'
    17. BRANCH_NAME = 'dev'
    18. }
    19. stages {
    20. stage ('checkout scm') {
    21. steps {
    22. git branch: 'master', url: "https://github.com/kubesphere/devops-java-sample.git"
    23. }
    24. }
    25. stage ('unit test') {
    26. steps {
    27. container ('maven') {
    28. sh 'mvn clean -o -gs `pwd`/configuration/settings.xml test'
    29. }
    30. }
    31. }
    32. stage ('build & push') {
    33. steps {
    34. container ('maven') {
    35. sh 'mvn -o -Dmaven.test.skip=true -gs `pwd`/configuration/settings.xml clean package'
    36. sh 'docker build -f Dockerfile-online -t $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:SNAPSHOT-$BRANCH_NAME-$BUILD_NUMBER .'
    37. withCredentials([usernamePassword(passwordVariable : 'DOCKER_PASSWORD' ,usernameVariable : 'DOCKER_USERNAME' ,credentialsId : "$DOCKER_CREDENTIAL_ID" ,)]) {
    38. sh 'echo "$DOCKER_PASSWORD" | docker login $REGISTRY -u "$DOCKER_USERNAME" --password-stdin'
    39. sh 'docker push $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:SNAPSHOT-$BRANCH_NAME-$BUILD_NUMBER'
    40. }
    41. }
    42. }
    43. }
    44. stage('deploy to dev') {
    45. steps {
    46. kubernetesDeploy(configs: 'deploy/dev-ol/**', enableConfigSubstitution: true, kubeconfigId: "$KUBECONFIG_CREDENTIAL_ID")
    47. }
    48. }
    49. }
    50. }
  4. Save the Jenkinsfile and you can see stages and steps are automatically created on graphical editing panels.

    view-edit-jenkinsfile

Run and test

  1. Click Run and type TAG_NAME to run the pipeline.

    run-maven-pipeline

  2. You can see the following figure when the pipeline finished.

    view-result-maven-pipeline

  3. In the project of kubesphere-sample-dev, there are new workloads created.

    view-result-maven-workload

  4. You can view the access address of the Service as below.

    view-result-maven-workload-svc