Get started with Jenkins CI/CD in RedHat Openshift 4
MIT
Get started with Jenkins CI/CD in RedHat Openshift 4
oc version
Client Version: 4.4.10
Server Version: 4.3.3
Kubernetes Version: v1.16.2
Create project pipelineproject
oc new-project pipelineproject
Search for Jenkins template
oc get templates -n openshift | grep jenkins
jenkins-ephemeral Jenkins service, without persistent storage.... 8 (all set) 6
jenkins-ephemeral-monitored Jenkins service, without persistent storage.... 9 (all set) 7
jenkins-persistent Jenkins service, with persistent storage.... 10 (all set) 7
jenkins-persistent-monitored Jenkins service, with persistent storage.... 11 (all set) 8
View template
oc get template/jenkins-ephemeral -o json -n openshift
Process all parameters for a given openshift template
oc process --parameters -n openshift jenkins-ephemeral # jenkins-persistent
NAME DESCRIPTION GENERATOR VALUE
JENKINS_SERVICE_NAME The name of the OpenShift Service exposed for the Jenkins container. jenkins
JNLP_SERVICE_NAME The name of the service used for master/slave communication. jenkins-jnlp
ENABLE_OAUTH Whether to enable OAuth OpenShift integration. If false, the static account 'admin' will be initialized with the password 'password'. true
MEMORY_LIMIT Maximum amount of memory the container can use. 1Gi
NAMESPACE The OpenShift Namespace where the Jenkins ImageStream resides. openshift
DISABLE_ADMINISTRATIVE_MONITORS Whether to perform memory intensive, possibly slow, synchronization with the Jenkins Update Center on start. If true, the Jenkins core update monitor and site warnings monitor are disabled. false
JENKINS_IMAGE_STREAM_TAG Name of the ImageStreamTag to be used for the Jenkins image. jenkins:2
JENKINS_UC_INSECURE Whether to allow use of a Jenkins Update Center that uses invalid certificate (self-signed, unknown CA). If any value other than 'false', certificate check is bypassed. By default, certificate check is enforced. false
Deploy Jenkins using jenkins-ephemeral template
oc new-app jenkins-ephemeral
--> Deploying template "openshift/jenkins-ephemeral" to project bookinfo
Jenkins (Ephemeral)
---------
Jenkins service, without persistent storage.
WARNING: Any data stored will be lost upon pod destruction. Only use this template for testing.
A Jenkins service has been created in your project. Log into Jenkins with your OpenShift account. The tutorial at https://github.com/openshift/origin/blob/master/examples/jenkins/README.md contains more information about using this template.
* With parameters:
* Jenkins Service Name=jenkins
* Jenkins JNLP Service Name=jenkins-jnlp
* Enable OAuth in Jenkins=true
* Memory Limit=1Gi
* Jenkins ImageStream Namespace=openshift
* Disable memory intensive administrative monitors=false
* Jenkins ImageStreamTag=jenkins:2
* Allows use of Jenkins Update Center repository with invalid SSL certificate=false
--> Creating resources ...
route.route.openshift.io "jenkins" created
deploymentconfig.apps.openshift.io "jenkins" created
serviceaccount "jenkins" created
rolebinding.authorization.openshift.io "jenkins_edit" created
service "jenkins-jnlp" created
service "jenkins" created
--> Success
Access your application via route 'jenkins-bookinfo.apps.cluster-8faf.8faf.sandbox1706.opentlc.com'
Run 'oc status' to view your app.
Verify the depliyment is completed.
oc get all
NAME READY STATUS RESTARTS AGE
pod/jenkins-1-deploy 0/1 Completed 0 96s
pod/jenkins-1-xbpcm 1/1 Running 0 87s
NAME DESIRED CURRENT READY AGE
replicationcontroller/jenkins-1 1 1 1 96s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/jenkins ClusterIP 172.30.157.171 <none> 80/TCP 97s
service/jenkins-jnlp ClusterIP 172.30.134.17 <none> 50000/TCP 97s
NAME REVISION DESIRED CURRENT TRIGGERED BY
deploymentconfig.apps.openshift.io/jenkins 1 1 1 config,image(jenkins:2)
NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD
route.route.openshift.io/jenkins jenkins-jenkins.apps.cluster-8faf.8faf.sandbox1706.opentlc.com jenkins <all> edge/Redirect None
Setup Jenkins job
We need to set up a pipeline to build our software, but we want to use the build that is built into OpenShift. The following command will create a build configuration (or “build config,” which is an object of type “BuildConfig”), which has the instructions we give to OpenShift to tell it how to build our application. In this particular case, we’re creating a pipeline that, in turn, has the build instructions: