Getting Started with Tekton Part 1: Hello World
Brian McClain
Tekton provides a set of open source Kubernetes resources to build and run CI/CD pipelines, such as parameterized tasks, inputs and outputs, as well as runtime definitions. This guide will walk you through setting up Tekton on Minikube as well as setting up your first task.
Before You Begin
There’s just a few things you’ll need before you get started:
- Minikube: Tekton runs on Kubernetes, so to keep things simple, this guide will assume you’re using Minikube to get up and running quickly
- A Docker Hub account: You’ll use this registry to push up container images built from your pipelines.
- The Tekton CLI
Setting Up Tekton
While Tekton can run on any Kubernetes cluster, this guide assumes you will be using Minikube. If you’d prefer to run Tekton differently, make sure to reference the Installation Guide.
First, create a Minikube cluster with 4GB of memory and 10GB of storage:
minikube start --memory=4096 --disk-size=10g
Once your Minikube environment is created, you can install Tekton by applying the YAML from the latest release:
Install Tekton
kubectl apply --filename https://storage.googleapis.com/tekton-releases/pipeline/latest/release.yaml
You can monitor the progress of the install by watching the pods in the newly created tekton-pipelines
namespace:
kubectl get pods --namespace tekton-pipelines --watch
Once the install is complete, you’ll see two newly created pods:
tekton-pipelines-webhook-69796f78cf-b28z4 1/1 Running 0 9s
tekton-pipelines-controller-6d55778887-df59t 1/1 Running 0 13s
Finally, in a couple of the examples, you’ll be pushing container images to Docker Hub. Create a secret that Tekton can use to log in to Docker Hub. Substitute the placeholder values with your own:
kubectl create secret docker-registry dockercreds --docker-server=https://index.docker.io/v1/ --docker-username=<DOCKERHUB_USERNAME> --docker-password=<DOCKERHUB_PASSWORD> --docker-email <DOCKERHUB_EMAIL>
Create Your Own Task
What better place to start than with a good ‘ole “Hello World” example? For this example, you’ll start with the most basic building block of a pipeline: a task. This task will simply start up a container, write “Hello World”, and end:
apiVersion: tekton.dev/v1beta1
kind: Task
metadata:
name: echo-hello-world
spec:
steps:
- name: echo
image: ubuntu
command:
- echo
args:
- "Hello World"
Take a moment to digest this part. While a task
can become much more complex, this specific task has no inputs, no outputs, and just a single step. That step (named echo
) uses the Ubuntu image from Docker Hub, and executes the following command:
echo "Hello World"
Tekton automatically stores the output of all tasks that are run, so even though the container that will run these tasks will quickly go away, you can reference the results of that task after the fact.
However, in order to actually run the task, you need to create one more resource, a TaskRun
. This resource defines how to run specific tasks. Consider the following for this example:
apiVersion: tekton.dev/v1beta1
kind: TaskRun
metadata:
name: echo-hello-world-task-run
spec:
taskRef:
name: echo-hello-world
Again, keeping the example as simple as possible, TaskRun
definitions could fill in any parameters required by a task, but in this case, since the task that is being run takes no parameters, this resource only defines the task that it is going to run: echo-hello-world
.
As with any Kubernetes custom resources definition (CRD), this can all be done in one file, which you can find on GitHub, and use to apply these two examples directly:
kubectl apply -f https://raw.githubusercontent.com/BrianMMcClain/tekton-examples/main/hello-task.yml
If you run kubectl get pods
β even if you do so quickly β you’ll likely see this task already completed:
NAME READY STATUS RESTARTS AGE
echo-hello-world-task-run-pod-vm6f5 0/1 Completed 0 12s
But as previously mentioned, Tekton stores the results of a TaskRun
, and that’s where the Tekton CLI comes in. First, check out Tekton’s description of your TaskRun
:
tkn taskrun describe echo-hello-world-task-run
Name: echo-hello-world-task-run
Namespace: default
Task Ref: echo-hello-world
Timeout: 1h0m0s
Labels:
app.kubernetes.io/managed-by=tekton-pipelines
tekton.dev/task=echo-hello-world
π‘οΈ Status
STARTED DURATION STATUS
10 minutes ago 7 seconds Succeeded
π¨ Input Resources
No input resources
π‘ Output Resources
No output resources
β Params
No params
π¦Ά Steps
NAME STATUS
β echo ---
π Sidecars
No sidecars
Since the task has no inputs, outputs, or resources, the above is a bit bare. What’s important is that the Status
is set to Succeeded
. Great! Next, take a look at the output of that TaskRun
:
tkn taskrun logs echo-hello-world-task-run
[echo] Hello World
Just as you would expect, the output of the echo
task was “Hello World”.
Keep Learning
In part two of this guide, you’ll learn about inputs into and outputs from tasks, as well as how you can use Cloud Native Buildpacks with Tekton. If you want to dive deeper into what has already been covered, give the official documentation a read to learn more!