Getting Started with Triggers
This tutorial shows you how to
- Install Tekton Triggers.
- Create a Trigger Template.
- Create a Trigger Bind.
- Create an Event Listener.
This guide uses a local cluster with minikube.
Before you begin
-
Complete the two previous Getting Started tutorials: Tasks and Pipelines. Do not clean up your resources, skip the last section.
-
Install curl if it’s not already available on your system.
Overview
You can use Tekton Triggers to modify the behavior of your CI/CD Pipelines depending on external events. The basic implementation you are going to create in this guide comprises three main components:
-
An
EventListener
object that listens to the world waiting for “something” to happen. -
When an event happens, the Event Listener passes the information associated with that event on to a
TriggerBinding
object, which in turn encodes the information into variables that are then passed on to aTriggerTemplate
object. -
The
TriggerTemplate
object uses the variables to instantiate and run a Pipeline.
An optional ClusterInterceptor
object can be added to validate and process
data.
You are going to create a Tekton Trigger to run the hello-goodbye
Pipeline
when the Event Listener detects an event.
Install Tekton Triggers
-
Use
kubectl
to install Tekton Triggers:kubectl apply --filename \ https://storage.googleapis.com/tekton-releases/triggers/latest/release.yaml kubectl apply --filename \ https://storage.googleapis.com/tekton-releases/triggers/latest/interceptors.yaml
-
Monitor the installation:
kubectl get pods --namespace tekton-pipelines --watch
When
tekton-triggers-controller
,tekton-triggers-webhook
, andtekton-triggers-core-controller
show1/1
under theREADY
column, you are ready to continue. For example:NAME READY STATUS RESTARTS AGE tekton-pipelines-controller-68b8d87687-8mzvt 1/1 Running 2 (4d13h ago) 4d19h tekton-pipelines-webhook-6fb6dd6d75-7jfz6 1/1 Running 2 (104s ago) 4d19h tekton-triggers-controller-74b654c6bc-24ds7 1/1 Running 2 (104s ago) 4d19h tekton-triggers-core-interceptors-79f4dbb969-sk2dk 1/1 Running 3 (104s ago) 4d19h tekton-triggers-webhook-56885c9875-nx499 1/1 Running 2 (104s ago) 4d19h
Hit Ctrl + C to stop monitoring.
Create a Trigger Template
A Trigger Template defines what happens when an event is detected.
-
Create a new file named
trigger-template.yaml
and add the following:apiVersion: triggers.tekton.dev/v1beta1 kind: TriggerTemplate metadata: name: hello-template spec: params: - name: username default: "Kubernetes" resourcetemplates: - apiVersion: tekton.dev/v1beta1 kind: PipelineRun metadata: generateName: hello-goodbye-run- spec: pipelineRef: name: hello-goodbye params: - name: username value: $(tt.params.username)
The
PipelineRun
object that you created in the previous tutorial is now included in the template declaration. This trigger expects theusername
parameter to be available; if it’s not, it assigns a default value: “Kubernetes”. -
Apply the Trigger Template to your cluster:
kubectl apply -f trigger-template.yaml
Create a Trigger Binding
A Trigger Binding instantiates the Trigger Template, the same way you had to create a Pipeline Run to instantiate the Pipeline.
-
Create a file named
trigger-binding.yaml
with the following content:apiVersion: triggers.tekton.dev/v1beta1 kind: TriggerBinding metadata: name: hello-binding spec: params: - name: username value: $(body.username)
This Trigger Binding gets some information and saves it in the
username
variable. -
Apply the Trigger Binding:
kubectl apply -f trigger-binding.yaml
Create an Event Listener
The EventListener
object encompasses both the Trigger Template and the
Trigger Binding.
-
Create a file named
event-listener.yaml
and add the following:apiVersion: triggers.tekton.dev/v1beta1 kind: EventListener metadata: name: hello-listener spec: serviceAccountName: tekton-robot triggers: - name: hello-trigger bindings: - ref: hello-binding template: ref: hello-template
This declares that when an event is detected, it will run the Trigger Binding and the Trigger Template.
-
Event Listeners require a service account to run. To create the service account for this example create a file named
rbac.yaml
and add the following:apiVersion: v1 kind: ServiceAccount metadata: name: tekton-robot --- apiVersion: rbac.authorization.k8s.io/v1 kind: RoleBinding metadata: name: triggers-example-eventlistener-binding subjects: - kind: ServiceAccount name: tekton-robot roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: tekton-triggers-eventlistener-roles --- apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: triggers-example-eventlistener-clusterbinding subjects: - kind: ServiceAccount name: tekton-robot namespace: default roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: tekton-triggers-eventlistener-clusterroles
For now think about this part as an implementation detail for this tutorial. You don’t have to understand what’s going on in this file.
-
Apply the file to your cluster:
kubectl apply -f rbac.yaml
Running the Trigger
You have everything you need to run this Trigger and start listening for events.
-
Create the Event Listener:
kubectl apply -f event-listener.yaml
-
To be able to communicate outside the cluster, enable port-forwarding:
kubectl port-forward service/el-hello-listener 8080
The output confirms that port-forwarding is working:
kubectl port-forward service/el-hello-listener 8080 Forwarding from 127.0.0.1:8080 -> 8080 Forwarding from [::1]:8080 -> 8080
Keep this service running, don’t close the terminal.
Monitor the Trigger
Now that the event Listener is running, you can send an event and see what happens:
-
Open a new terminal and submit a payload to the cluster:
curl -v \ -H 'content-Type: application/json' \ -d '{"username": "Tekton"}' \ http://localhost:8080
You can change “Tekton” for any string you want. This value will be ultimately read by teh
goodbye-world
Task.The response is successful:
< HTTP/1.1 202 Accepted < Content-Type: application/json < Date: Fri, 30 Sep 2022 00:11:19 GMT < Content-Length: 164 < {"eventListener":"hello-listener","namespace":"default","eventListenerUID":"35dd0858-3692-4bb5-8c4f-1bf6d705bb73","eventID":"1a0a1120-7833-4078-9f30-0e3688f27dde"} * Connection #0 to host localhost left intact
-
This event triggers a Pipeline Run, check the Pipeline Runs on your cluster :
kubectl get pipelineruns
The output confirms the pipeline is working:
NAME SUCCEEDED REASON STARTTIME COMPLETIONTIME hello-goodbye-run True Succeeded 24m 24m hello-goodbye-run-8hckl True Succeeded 81s 72s
You see two Pipeline Runs, the first one created in the previous guide, the last one was created by the Trigger.
-
Check the Pipeline Run logs. The name is auto-generated adding a suffix for every run. Replace
hello-goodbye-run-xvwfm
in the follwing command with your own output to check the logs:tkn pipelinerun logs hello-goodbye-run-xvwfm -f
And you get the expected output:
[hello : echo] Hello World [goodbye : goodbye] Goodbye Tekton!
Both Tasks completed successfuly. Congratulations!
Clean up
-
Press Ctrl + C in the terminal running the port-forwarding process to stop it.
-
Delete the cluster:
minikube delete
The output confirms that the cluster was deleted:
🔥 Deleting "minikube" in docker ... 🔥 Deleting container "minikube" ... 🔥 Removing /home/user/.minikube/machines/minikube ... 💀 Removed all traces of the "minikube" cluster.
Further reading
For more complex Pipelines examples check:
You can find more Tekton Triggers examples on the Triggers GitHub repository.
Feedback
Was this page helpful?
Thanks! Tell us how we can further improve.
Sorry about that. Tell us how we can further improve.