navigation

Camel K Workshop

What is it about

This workshop aims to help gain your first hands-on experience with Camel K and the important concepts such as Kamelets, KameletBindings and Knative.

It requires admin access to an OpenShift Container Platform cluster to install the dependencies such as various operators.

No previous knowledge of any programming language is mandatory, although recommended to understand YAML and Groovy code snippets we will be using.

During the workshop, you are free to create integrations in any language supported by Camel. They can be found here. They are not in scope of this course though.

Architecture overview

The workshop consists of 3 separate exercises.

  1. In the first one, the goal is to create the simplest route file to create a “Hello World” message and log it to the terminal in the set time interval.

Click image to enlarge

  1. The second exercise’s goal is to create an integration using a Kamelet - new concept introduced in Camel K that allow users to connect to external systems via a simplified interface, hiding all the low level details about how those connections are implemented. To showcase the use of it, we will connect to the database of Chuck Norris jokes using just one command. We will send the joke to the terminal first, and then we will also send it as a Telegram message. In order to do that, Telegram account and Telegram bot will be required.

Click image to enlarge

  1. The third and last exercise will teach you about how to utilize Knative to create serverless applications that scale depending on the workload. This time we’ll be sending messages to the Telegram bot and watch it’s behavior, i.e. how it scales up and down depending on the frequency of receiving new messages.

Click image to enlarge

Collaboration

This workshop was created by Rui Zhang, Tala Ismail, Fabian Popp and Adrian Luberda.
Feel free to create a pull request or an issue in GitHub.