Eventing

At the end of this chapter you will know and understand:

  • What is an event source?

  • What is a channel?

  • What is a subscriber?

  • What is a trigger?

  • What is a broker?

  • How to make a Knative serving service receive an event?

  • How to make a service a subscriber of an event?

Prerequisite

The following checks ensure that each chapter exercises are done with the right environment settings.

  • Minikube

  • OpenShift

  • Set your local docker to use minikube docker daemon

eval $(minikube docker-env)
  • Kubernetes should be v1.23.0

kubectl version --short

The output should be as shown

Client Version: v1.23.0
Server Version: v1.23.0
  • OpenShift CLI should be v4.6+

oc version

The output should be like

oc version
Client Version: 4.6.1
Kubernetes Version: `v1.23.0`
  • Make sure to be on knativetutorial OpenShift project

oc project -q

If you are not on knativetutorial project, then run following command to change to knativetutorial project:

oc project knativetutorial

Before beginning to run the exercises, navigate to the tutorial chapter’s eventing folder:

cd $TUTORIAL_HOME/eventing

Watching Logs

In the eventing related subsections of this tutorial, event sources are configured to emit events every minute with a PingSource or with a ContainerSource.

The logs could be watched using the command:

kubectl logs -n knativetutorial -f <pod-name> -c user-container
  • Using stern with the command stern -n knativetutorial eventing-hello, to filter the logs further add -c user-container to the stern command.

stern -n knativetutorial -c user-container eventing-hello

The logs will have the output like below printing every 2 minutes.

INFO  [com.red.dev.dem.GreetingService] (XNIO-1 task-1) Event Message Received
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container  {
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container   "message" : "Thanks for doing Knative Tutorial",
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container   "host" : "Event  greeter => 'event-greeter-5cbh5-pod-52d8fb' : 1",
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container   "time" : "13:50:07"
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container }

(OR)

INFO  [com.red.dev.dem.GreetingService] (XNIO-1 task-1) Event Message Received
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container  {
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container   "message" : "Thanks for doing Knative Tutorial",
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container   "host" : "Event  greeter => 'event-greeter-5cbh5-pod-52d8fb' : 2",
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container   "time" : "13:52:07"
event-greeter-g94kp-deployment-89f66cb58-wjl2v user-container }