This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Este contenido no está disponible en el idioma seleccionado.
Chapter 4. Creating CI/CD solutions for applications using OpenShift Pipelines
With Red Hat OpenShift Pipelines, you can create a customized CI/CD solution to build, test, and deploy your application.
To create a full-fledged, self-serving CI/CD Pipeline for an application, you must perform the following tasks:
- Create custom Tasks, or install existing reusable Tasks.
- Create and define the delivery Pipeline for your application.
- Create a PersistentVolumeClaim attached to the Workspace to provide the volume or filesystem for Pipeline execution.
- Create a PipelineRun to instantiate and invoke the Pipeline.
- Add Triggers to capture any events in the source repository.
			This section uses the pipelines-tutorial example to demonstrate the preceding tasks. The example uses a simple application which consists of:
		
- 
					A front-end interface, vote-ui, with the source code in theui-repoGit repository.
- 
					A back-end interface, vote-api, with the source code in theapi-repoGit repository.
- 
					The apply_manifestandupdate-deploymentTasks in thepipelines-tutorialGit repository.
4.1. Prerequisites
- You have access to an OpenShift Container Platform cluster.
- You have installed OpenShift Pipelines using the Red Hat OpenShift Pipelines Operator listed in the OpenShift OperatorHub. Once installed, it is applicable to the entire cluster.
- You have installed OpenShift Pipelines CLI.
- 
						You have forked the front-end ui-repoand back-endapi-repoGit repositories using your GitHub ID, and have Administrator access to these repositories.
- 
						Optional: You have cloned the pipelines-tutorialGit repository.
4.2. Creating a project and checking your Pipeline ServiceAccount
Procedure
- Log in to your OpenShift Container Platform cluster: - oc login -u <login> -p <password> https://openshift.example.com:6443 - $ oc login -u <login> -p <password> https://openshift.example.com:6443- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a project for the sample application. For this example workflow, create the - pipelines-tutorialproject:- oc new-project pipelines-tutorial - $ oc new-project pipelines-tutorial- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- If you create a project with a different name, be sure to update the resource URLs used in the example with your project name. 
- View the - pipelineServiceAccount:- Red Hat OpenShift Pipelines Operator adds and configures a ServiceAccount named - pipelinethat has sufficient permissions to build and push an image. This ServiceAccount is used by PipelineRun.- oc get serviceaccount pipeline - $ oc get serviceaccount pipeline- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.3. Creating Pipeline Tasks
Procedure
- Install the - apply-manifestsand- update-deploymentTasks from the- pipelines-tutorialrepository, which contains a list of reusable Tasks for Pipelines:- oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/01_apply_manifest_task.yaml oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/02_update_deployment_task.yaml - $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/01_apply_manifest_task.yaml $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/02_update_deployment_task.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the - tkn task listcommand to list the Tasks you created:- tkn task list - $ tkn task list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output verifies that the - apply-manifestsand- update-deploymentTasks were created:- NAME DESCRIPTION AGE apply-manifests 1 minute ago update-deployment 48 seconds ago - NAME DESCRIPTION AGE apply-manifests 1 minute ago update-deployment 48 seconds ago- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the - tkn clustertasks listcommand to list the Operator-installed additional ClusterTasks, for example --- buildahand- s2i-python-3:Note- You must use a privileged Pod container to run the - buildahClusterTask because it requires a privileged security context. To learn more about security context constraints (SCC) for pods, see the Additional resources section.- tkn clustertasks list - $ tkn clustertasks list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output lists the Operator-installed ClusterTasks: - NAME DESCRIPTION AGE buildah 1 day ago git-clone 1 day ago s2i-php 1 day ago tkn 1 day ago - NAME DESCRIPTION AGE buildah 1 day ago git-clone 1 day ago s2i-php 1 day ago tkn 1 day ago- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4. Assembling a Pipeline
A Pipeline represents a CI/CD flow and is defined by the Tasks to be executed. It is designed to be generic and reusable in multiple applications and environments.
				A Pipeline specifies how the Tasks interact with each other and their order of execution using the from and runAfter parameters. It uses the workspaces field to specify one or more volumes that each Task in the Pipeline requires during execution.
			
In this section, you will create a Pipeline that takes the source code of the application from GitHub and then builds and deploys it on OpenShift Container Platform.
				The Pipeline performs the following tasks for the back-end application vote-api and front-end application vote-ui:
			
- 
						Clones the source code of the application from the Git repository by referring to the git-urlandgit-revisionparameters.
- 
						Builds the container image using the buildahClusterTask.
- 
						Pushes the image to the internal image registry by referring to the imageparameter.
- 
						Deploys the new image on OpenShift Container Platform by using the apply-manifestsandupdate-deploymentTasks.
Procedure
- Copy the contents of the following sample Pipeline YAML file and save it: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The Pipeline definition abstracts away the specifics of the Git source repository and image registries. These details are added as - paramswhen a Pipeline is triggered and executed.
- Create the Pipeline: - oc create -f <pipeline-yaml-file-name.yaml> - $ oc create -f <pipeline-yaml-file-name.yaml>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can also execute the YAML file directly from the Git repository: - oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/04_pipeline.yaml - $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/04_pipeline.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the - tkn pipeline listcommand to verify that the Pipeline is added to the application:- tkn pipeline list - $ tkn pipeline list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output verifies that the - build-and-deployPipeline was created:- NAME AGE LAST RUN STARTED DURATION STATUS build-and-deploy 1 minute ago --- --- --- --- - NAME AGE LAST RUN STARTED DURATION STATUS build-and-deploy 1 minute ago --- --- --- ---- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.5. Specifying PersistentVolumeClaims as VolumeSource in Workspaces
Workspaces help Tasks share data, and allow you to specify one or more volumes that each Task in the Pipeline requires during execution.
In this section, you will create a PersistentVolumeClaim to provide data storage and bind it to the Workspace. This PersistentVolumeClaim provides the volumes or filesystem required for the Pipeline execution.
Procedure
- Copy and save the contents of the following sample PersistentVolumeClaim YAML file: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the PersistentVolumeClaim, specifying the file you just created: - oc create -f <PersistentVolumeClaim-yaml-file-name.yaml> - $ oc create -f <PersistentVolumeClaim-yaml-file-name.yaml>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can execute the YAML file directly from the Git repository: - oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/03_persistent_volume_claim.yaml - $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/01_pipeline/03_persistent_volume_claim.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.6. Running a Pipeline
A PipelineRun starts a Pipeline and ties it to the Git and image resources that should be used for the specific invocation. It automatically creates and starts the TaskRuns for each Task in the Pipeline.
Procedure
- Start the Pipeline for the back-end application: - tkn pipeline start build-and-deploy -w name=shared-workspace,claimName=source-pvc -p deployment-name=vote-api -p git-url=http://github.com/openshift-pipelines/vote-api.git -p IMAGE=image-registry.openshift-image-registry.svc:5000/pipelines-tutorial/vote-api - $ tkn pipeline start build-and-deploy -w name=shared-workspace,claimName=source-pvc -p deployment-name=vote-api -p git-url=http://github.com/openshift-pipelines/vote-api.git -p IMAGE=image-registry.openshift-image-registry.svc:5000/pipelines-tutorial/vote-api- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note the PipelineRun ID returned in the command output. 
- Track the PipelineRun progress: - tkn pipelinerun logs <pipelinerun ID> -f - $ tkn pipelinerun logs <pipelinerun ID> -f- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Start the Pipeline for the front-end application: - tkn pipeline start build-and-deploy -w name=shared-workspace,claimName=source-pvc -p deployment-name=vote-api -p git-url=http://github.com/openshift-pipelines/vote-ui.git -p IMAGE=image-registry.openshift-image-registry.svc:5000/pipelines-tutorial/vote-ui - $ tkn pipeline start build-and-deploy -w name=shared-workspace,claimName=source-pvc -p deployment-name=vote-api -p git-url=http://github.com/openshift-pipelines/vote-ui.git -p IMAGE=image-registry.openshift-image-registry.svc:5000/pipelines-tutorial/vote-ui- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note the PipelineRun ID returned in the command output. 
- Track the PipelineRun progress: - tkn pipelinerun logs <pipelinerun ID> -f - $ tkn pipelinerun logs <pipelinerun ID> -f- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- After a few minutes, use - tkn pipelinerun listcommand to verify that the Pipeline ran successfully by listing all the PipelineRuns:- tkn pipelinerun list - $ tkn pipelinerun list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output lists the PipelineRuns: - NAME STARTED DURATION STATUS build-and-deploy-run-xy7rw 1 hour ago 2 minutes Succeeded build-and-deploy-run-z2rz8 1 hour ago 19 minutes Succeeded - NAME STARTED DURATION STATUS build-and-deploy-run-xy7rw 1 hour ago 2 minutes Succeeded build-and-deploy-run-z2rz8 1 hour ago 19 minutes Succeeded- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Get the application route: - oc get route vote-ui --template='http://{{.spec.host}}'- $ oc get route vote-ui --template='http://{{.spec.host}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note the output of the previous command. You can access the application using this route. 
- To rerun the last PipelineRun, using the PipelineResources and ServiceAccount of the previous Pipeline, run: - tkn pipeline start build-and-deploy --last - $ tkn pipeline start build-and-deploy --last- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.7. Adding Triggers to a Pipeline
Triggers enable Pipelines to respond to external GitHub events, such as push events and pull requests. After you have assembled and started the Pipeline for the application, add TriggerBindings, TriggerTemplates, and an EventListener to capture the GitHub events.
Procedure
- Copy the content of the following sample - TriggerBindingYAML file and save it:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - TriggerBinding:- oc create -f <triggerbinding-yaml-file-name.yaml> - $ oc create -f <triggerbinding-yaml-file-name.yaml>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can create the - TriggerBindingdirectly from the- pipelines-tutorialGit repository:- oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/03_triggers/01_binding.yaml - $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/03_triggers/01_binding.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Copy the content of the following sample - TriggerTemplateYAML file and save it:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - TriggerTemplate:- oc create -f <triggertemplate-yaml-file-name.yaml> - $ oc create -f <triggertemplate-yaml-file-name.yaml>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can create the - TriggerTemplatedirectly from the- pipelines-tutorialGit repository:- oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/03_triggers/02_template.yaml - $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/03_triggers/02_template.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Copy the contents of the following sample - EventListenerYAML file and save it:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - EventListener:- oc create -f <eventlistener-yaml-file-name.yaml> - $ oc create -f <eventlistener-yaml-file-name.yaml>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can create the - EvenListenerdirectly from the- pipelines-tutorialGit repository:- oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/03_triggers/03_event_listener.yaml - $ oc create -f https://raw.githubusercontent.com/openshift/pipelines-tutorial/release-tech-preview-2/03_triggers/03_event_listener.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Expose the EventListener service as an OpenShift Container Platform route to make it publicly accessible: - oc expose svc el-vote-app - $ oc expose svc el-vote-app- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.8. Creating Webhooks
Webhooks are HTTP POST messages that are received by the EventListeners whenever a configured event occurs in your repository. The event payload is then mapped to TriggerBindings, and processed by TriggerTemplates. The TriggerTemplates eventually start one or more PipelineRuns, leading to the creation and deployment of Kubernetes resources.
				In this section, you will configure a Webhook URL on your forked Git repositories vote-ui and vote-api. This URL points to the publicly accessible EventListener service route.
			
Adding Webhooks requires administrative privileges to the repository. If you do not have administrative access to your repository, contact your system administrator for adding Webhooks.
Procedure
- Get the Webhook URL: - echo "URL: $(oc get route el-vote-app --template='http://{{.spec.host}}')"- $ echo "URL: $(oc get route el-vote-app --template='http://{{.spec.host}}')"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note the URL obtained in the output. 
- Configure Webhooks manually on the front-end repository: - 
								Open the front-end Git repository vote-uiin your browser.
- 
								Click Settings Webhooks Add Webhook 
- On the Webhooks/Add Webhook page: - Enter the Webhook URL from step 1 in Payload URL field
- Select application/json for the Content type
- Specify the secret in the Secret field
- Ensure that the Just the push event is selected
- Select Active
- Click Add Webhook
 
 
- 
								Open the front-end Git repository 
- 
						Repeat step 2 for the back-end repository vote-api.
4.9. Triggering a PipelineRun
				Whenever a push event occurs in the Git repository, the configured Webhook sends an event payload to the publicly exposed EventListener service route. The EventListener service of the application processes the payload, and passes it to the relevant TriggerBindings and TriggerTemplates pair. The TriggerBinding extracts the parameters and the TriggerTemplate uses these parameters to create resources. This may rebuild and redeploy the application.
			
				In this section, you push an empty commit to the front-end vote-ui repository, which then triggers the PipelineRun.
			
Procedure
- From the terminal, clone your forked Git repository - vote-ui:- git clone git@github.com:<your GitHub ID>/vote-ui.git -b release-tech-preview-2 - $ git clone git@github.com:<your GitHub ID>/vote-ui.git -b release-tech-preview-2- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Push an empty commit: - git commit -m "empty-commit" --allow-empty && git push origin release-tech-preview-2 - $ git commit -m "empty-commit" --allow-empty && git push origin release-tech-preview-2- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check if the PipelineRun was triggered: - tkn pipelinerun list - $ tkn pipelinerun list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Notice that a new PipelineRun was initiated. 
4.10. Additional resources
- For more details on pipelines in the Developer perspective, see the working with Pipelines in the Developer perspective section.
- To learn more about Security Context Constraints (SCCs), see Managing Security Context Constraints section.
- For more examples of reusable Tasks, see the OpenShift Catalog repository. Additionally, you can also see the Tekton Catalog in the Tekton project.