Getting Started with Keptn
Keptn is a flexible workflow and automation engine. It is extremely easy to get started with Keptn, you can be up, running and modelling your own workflows in under 10 minutes...
Keptn 101: Getting Started in 3 Steps
- Define what you want to achieve
- Model that intention in a Shipyard file
- Define the tooling that you want to use to achieve those tasks
1. Define Tasks
Start by deciding what you want to achieve. In Keptn's world, the high level requirement is a sequence and the individual tasks are, ummm tasks.
The most simple example would be a desire to create a report. Most likely this is a very simple workflow consisting of a single "create report" task.
A more complex example may be that you wish to build an entire demo system including infrastructure, user onboarding and notifications when completed. In which case, the tasks you must run are:
- Create infrastructure
- Install application
- Onboard a user
- Notify user that they now have access to the demo system
- Report to a third party system to record that the demo system is available
2. Model Your World
Keptn models the world in a file called a Shipyard YAML file.
Some quick FYIs:
- Sequences (by default) are standalone
- Sequences and tasks can be named anything you want
- When a sequence is triggered to run, Keptn will automatically execute each task sequentially
- Sequences can be linked together to build complex workflows
- Metadata can be provided to each task either in the Shipyard or via the Keptn API when triggering a sequence
Define the basics of your shipyard:
---
apiVersion: "spec.keptn.sh/0.2.2"
kind: "Shipyard"
metadata:
name: "my-first-shipyard"
Now decide how many stages
you want to model. In our case, we only need one as we're not modelling anything pipeline related (where things "move" from one "stage" to the next). So we'll call our stage main
---
apiVersion: "spec.keptn.sh/0.2.2"
kind: "Shipyard"
metadata:
name: "my-first-shipyard"
spec:
stages:
- name: "main"
Define your sequences and tasks. Modelling the simple "create report" sequence might look like this, where we have a single sequence and a matching single task.
Remember that the name values can be any string you want, so you're free to make up your own sequence and task names.
---
apiVersion: "spec.keptn.sh/0.2.2"
kind: "Shipyard"
metadata:
name: "my-first-shipyard"
spec:
stages:
- name: "main"
sequences:
- name: "makereport"
tasks:
- name: "createreport"
The more complex "create a demo system" workflow might look like this:
---
apiVersion: "spec.keptn.sh/0.2.2"
kind: "Shipyard"
metadata:
name: "my-first-shipyard"
spec:
stages:
- name: "main"
sequences:
- name: "createdemosystem"
tasks:
- name: "createinfra"
- name: "installapp"
- name: "onboarduser"
- name: "notify"
- name: "report"
3. Define Your Tooling
It is now time to define the tooling you wish to execute each task. This tooling can take a number of forms:
- An HTTP request to an endpoint, shell script or Python script
- A container image that should run for a particular task
- A more complex or custom workflow that's modelled by a "full Keptn service" (example: JIRA Service)
You may decide that:
createreport
task is best handled by running a Python filecreateinfra
task is best handled by theaws-service
installapp
task is best handled by running a shell scriptonboarduser
task is best handled by running theexample/someimage:1.0.2
containernotify
best handled byslack-service
report
best handled byjira-service
Tooling in Keptn listens for and reacts to sh.keptn.event.{taskname}.*
events. Usually the taskname.triggered
event. The exact events your service listens for is easily set via an environment variable when installing the service.
In the above example:
- Install the generic executor service and configure the environment variable to listen for the
sh.keptn.event.buildreport.triggered
event - Install the
aws-service
and configure the env var to listen for thesh.keptn.event.createinfra.triggered
event - Configure the generic executor service to listen for a second event:
sh.keptn.event.installapp.triggered
event and run the shell script - Install the job executor service and configure it to listen for the
sh.keptn.event.onboarduser.triggered
event - Install the Slack service and configure it to listen for the
sh.keptn.event.notify.triggered
event - Install the JIRA Service and configure it to listen for the
sh.keptn.event.report.triggered
event
Step 4: Trigger Sequence
Your system is set up and ready to go! Trigger the sequence and Keptn will handle the lifecycle of the tasks for you. Your tooling will respond and your tasks will be achieved.
curl -X POST https://keptn/...
{
...
"type": "sh.keptn.event.main.createdemosystem.triggered"
...
}
Summary
Modelling workflows and tasks in Keptn is relatively painless. Keptn is designed to split the workflow from tooling. You decide the best tool for the job and Keptn handles the rest.
Check out the Keptn public demo system to see how sequences are executed.
Is there a service you'd like to use with Keptn? Join the Keptn community on Slack and suggest an integration.