Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 5. Triggers
5.1. Triggers overview
				Brokers can be used in combination with triggers to deliver events from an event source to an event sink. Events are sent from an event source to a broker as an HTTP POST request. After events have entered the broker, they can be filtered by CloudEvent attributes using triggers, and sent as an HTTP POST request to an event sink.
			
If you are using a Knative broker for Apache Kafka, you can configure the delivery order of events from triggers to event sinks. See Configuring event delivery ordering for triggers.
5.1.1. Configuring event delivery ordering for triggers
If you are using a Kafka broker, you can configure the delivery order of events from triggers to event sinks.
Prerequisites
- The OpenShift Serverless Operator, Knative Eventing, and Knative Kafka are installed on your OpenShift Container Platform cluster.
- Kafka broker is enabled for use on your cluster, and you have created a Kafka broker.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
- 
							You have installed the OpenShift (oc) CLI.
Procedure
- Create or modify a - Triggerobject and set the- kafka.eventing.knative.dev/delivery.orderannotation:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The supported consumer delivery guarantees are: - unordered
- An unordered consumer is a non-blocking consumer that delivers messages unordered, while preserving proper offset management.
- ordered
- An ordered consumer is a per-partition blocking consumer that waits for a successful response from the CloudEvent subscriber before it delivers the next message of the partition. - The default ordering guarantee is - unordered.
 
- Apply the - Triggerobject:- oc apply -f <filename> - $ oc apply -f <filename>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.1.2. Next steps
- Configure event delivery parameters that are applied in cases where an event fails to be delivered to an event sink. See Examples of configuring event delivery parameters.
5.2. Creating triggers
				Brokers can be used in combination with triggers to deliver events from an event source to an event sink. Events are sent from an event source to a broker as an HTTP POST request. After events have entered the broker, they can be filtered by CloudEvent attributes using triggers, and sent as an HTTP POST request to an event sink.
			
5.2.1. Creating a trigger by using the Administrator perspective
Using the OpenShift Container Platform web console provides a streamlined and intuitive user interface to create a trigger. After Knative Eventing is installed on your cluster and you have created a broker, you can create a trigger by using the web console.
Prerequisites
- The OpenShift Serverless Operator and Knative Eventing are installed on your OpenShift Container Platform cluster.
- You have logged in to the web console and are in the Administrator perspective.
- You have cluster administrator permissions on OpenShift Container Platform, or you have cluster or dedicated administrator permissions on Red Hat OpenShift Service on AWS or OpenShift Dedicated.
- You have created a Knative broker.
- You have created a Knative service to use as a subscriber.
Procedure
- 
							In the Administrator perspective of the OpenShift Container Platform web console, navigate to Serverless Eventing. 
- 
							In the Broker tab, select the Options menu 
							 for the broker that you want to add a trigger to. for the broker that you want to add a trigger to.
- Click Add Trigger in the list.
- In the Add Trigger dialogue box, select a Subscriber for the trigger. The subscriber is the Knative service that will receive events from the broker.
- Click Add.
5.2.2. Creating a trigger by using the Developer perspective
Using the OpenShift Container Platform web console provides a streamlined and intuitive user interface to create a trigger. After Knative Eventing is installed on your cluster and you have created a broker, you can create a trigger by using the web console.
Prerequisites
- The OpenShift Serverless Operator, Knative Serving, and Knative Eventing are installed on your OpenShift Container Platform cluster.
- You have logged in to the web console.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
- You have created a broker and a Knative service or other event sink to connect to the trigger.
Procedure
- In the Developer perspective, navigate to the Topology page.
- Hover over the broker that you want to create a trigger for, and drag the arrow. The Add Trigger option is displayed.
- Click Add Trigger.
- Select your sink in the Subscriber list.
- Click Add.
Verification
- After the subscription has been created, you can view it in the Topology page, where it is represented as a line that connects the broker to the event sink.
Deleting a trigger
- In the Developer perspective, navigate to the Topology page.
- Click on the trigger that you want to delete.
- In the Actions context menu, select Delete Trigger.
5.2.3. Creating a trigger by using the Knative CLI
					You can use the kn trigger create command to create a trigger.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Eventing are installed on your OpenShift Container Platform cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
Procedure
- Create a trigger: - kn trigger create <trigger_name> --broker <broker_name> --filter <key=value> --sink <sink_name> - $ kn trigger create <trigger_name> --broker <broker_name> --filter <key=value> --sink <sink_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can create a trigger and simultaneously create the - defaultbroker using broker injection:- kn trigger create <trigger_name> --inject-broker --filter <key=value> --sink <sink_name> - $ kn trigger create <trigger_name> --inject-broker --filter <key=value> --sink <sink_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - By default, triggers forward all events sent to a broker to sinks that are subscribed to that broker. Using the - --filterattribute for triggers allows you to filter events from a broker, so that subscribers will only receive a subset of events based on your defined criteria.
5.3. List triggers from the command line
				Using the Knative (kn) CLI to list triggers provides a streamlined and intuitive user interface.
			
5.3.1. Listing triggers by using the Knative CLI
					You can use the kn trigger list command to list existing triggers in your cluster.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Eventing are installed on your OpenShift Container Platform cluster.
- 
							You have installed the Knative (kn) CLI.
Procedure
- Print a list of available triggers: - kn trigger list - $ kn trigger list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME BROKER SINK AGE CONDITIONS READY REASON email default ksvc:edisplay 4s 5 OK / 5 True ping default ksvc:edisplay 32s 5 OK / 5 True - NAME BROKER SINK AGE CONDITIONS READY REASON email default ksvc:edisplay 4s 5 OK / 5 True ping default ksvc:edisplay 32s 5 OK / 5 True- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Print a list of triggers in JSON format: - kn trigger list -o json - $ kn trigger list -o json- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.4. Describe triggers from the command line
				Using the Knative (kn) CLI to describe triggers provides a streamlined and intuitive user interface.
			
5.4.1. Describing a trigger by using the Knative CLI
					You can use the kn trigger describe command to print information about existing triggers in your cluster by using the Knative CLI.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Eventing are installed on your OpenShift Container Platform cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a trigger.
Procedure
- Enter the command: - kn trigger describe <trigger_name> - $ kn trigger describe <trigger_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.5. Connecting a trigger to a sink
				You can connect a trigger to a sink, so that events from a broker are filtered before they are sent to the sink. A sink that is connected to a trigger is configured as a subscriber in the Trigger object’s resource spec.
			
Example of a Trigger object connected to an Apache Kafka sink
5.6. Filtering triggers from the command line
				Using the Knative (kn) CLI to filter events by using triggers provides a streamlined and intuitive user interface. You can use the kn trigger create command, along with the appropriate flags, to filter events by using triggers.
			
5.6.1. Filtering events with triggers by using the Knative CLI
					In the following trigger example, only events with the attribute type: dev.knative.samples.helloworld are sent to the event sink:
				
kn trigger create <trigger_name> --broker <broker_name> --filter type=dev.knative.samples.helloworld --sink ksvc:<service_name>
$ kn trigger create <trigger_name> --broker <broker_name> --filter type=dev.knative.samples.helloworld --sink ksvc:<service_name>You can also filter events by using multiple attributes. The following example shows how to filter events using the type, source, and extension attributes:
kn trigger create <trigger_name> --broker <broker_name> --sink ksvc:<service_name> \ --filter type=dev.knative.samples.helloworld \ --filter source=dev.knative.samples/helloworldsource \ --filter myextension=my-extension-value
$ kn trigger create <trigger_name> --broker <broker_name> --sink ksvc:<service_name> \
--filter type=dev.knative.samples.helloworld \
--filter source=dev.knative.samples/helloworldsource \
--filter myextension=my-extension-value5.7. Updating triggers from the command line
				Using the Knative (kn) CLI to update triggers provides a streamlined and intuitive user interface.
			
5.7.1. Updating a trigger by using the Knative CLI
					You can use the kn trigger update command with certain flags to update attributes for a trigger.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Eventing are installed on your OpenShift Container Platform cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
Procedure
- Update a trigger: - kn trigger update <trigger_name> --filter <key=value> --sink <sink_name> [flags] - $ kn trigger update <trigger_name> --filter <key=value> --sink <sink_name> [flags]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You can update a trigger to filter exact event attributes that match incoming events. For example, using the - typeattribute:- kn trigger update <trigger_name> --filter type=knative.dev.event - $ kn trigger update <trigger_name> --filter type=knative.dev.event- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- You can remove a filter attribute from a trigger. For example, you can remove the filter attribute with key - type:- kn trigger update <trigger_name> --filter type- - $ kn trigger update <trigger_name> --filter type-- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- You can use the - --sinkparameter to change the event sink of a trigger:- kn trigger update <trigger_name> --sink ksvc:my-event-sink - $ kn trigger update <trigger_name> --sink ksvc:my-event-sink- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
5.8. Deleting triggers from the command line
				Using the Knative (kn) CLI to delete a trigger provides a streamlined and intuitive user interface.
			
5.8.1. Deleting a trigger by using the Knative CLI
					You can use the kn trigger delete command to delete a trigger.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Eventing are installed on your OpenShift Container Platform cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
Procedure
- Delete a trigger: - kn trigger delete <trigger_name> - $ kn trigger delete <trigger_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- List existing triggers: - kn trigger list - $ kn trigger list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the trigger no longer exists: - Example output - No triggers found. - No triggers found.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
