Getting Started
Welcome to Linkerd! đ
In this guide, weâll walk you through how to install Linkerd into your Kubernetes cluster. Then weâll deploy a sample application to show off what Linkerd can do.
This guide is designed to walk you through the basics of Linkerd. First, youâll install the CLI (command-line interface) onto your local machine. Using this CLI, youâll then install the control plane onto your Kubernetes cluster. Finally, youâll âmeshâ an application by adding Linkerdâs data plane to it.
Edge release content
Step 0: Setup
Before anything else, we need to ensure you have access to modern Kubernetes
cluster and a functioning kubectl
command on your local machine. (If you
donât already have a Kubernetes cluster, one easy option is to run one on your
local machine. There are many ways to do this, including
kind, k3d, Docker for
Desktop, and
more.)
Validate your Kubernetes setup by running:
You should see output with both a Client Version
and Server Version
component.
Now that we have our cluster, weâll install the Linkerd CLI and use it validate that your cluster is capable of hosting Linkerd.
Note
Step 1: Install the CLI
If this is your first time running Linkerd, you will need to download the
linkerd
CLI onto your local machine. The CLI will allow you to interact with
your Linkerd deployment.
To install the CLI manually, run:
Be sure to follow the instructions to add it to your path:
This will install the CLI for the latest edge release of Linkerd. (For more information about what edge releases are, see our Releases and Versions page.)
Once installed, verify the CLI is running correctly with:
You should see the CLI version, and also Server version: unavailable
. This is
because you havenât installed the control plane on your cluster. Donât
worryâweâll fix that soon enough.
Make sure that your Linkerd version and Kubernetes version are compatible by checking Linkerdâs supported Kubernetes versions.
Step 2: Validate your Kubernetes cluster
Kubernetes clusters can be configured in many different ways. Before we can install the Linkerd control plane, we need to check and validate that everything is configured correctly. To check that your cluster is ready to install Linkerd, run:
If there are any checks that do not pass, make sure to follow the provided links and fix those issues before proceeding.
Step 3: Install Linkerd onto your cluster
Now that you have the CLI running locally and a cluster that is ready to go, itâs time to install Linkerd on your Kubernetes cluster. To do this, run:
followed by:
These commands generate Kubernetes manifests with all the core resources required
for Linkerd (feel free to inspect this output if youâre curious). Piping these
manifests into kubectl apply
then instructs Kubernetes to add those resources
to your cluster. The install --crds
command installs Linkerdâs Custom Resource
Definitions (CRDs), which must be installed first, while the install
command
installs the Linkerd control plane.
Note
Depending on the speed of your clusterâs Internet connection, it may take a minute or two for the control plane to finish installing. Wait for the control plane to be ready (and verify your installation) by running:
Step 4: Install the demo app
Congratulations, Linkerd is installed! However, itâs not doing anything just yet. To see Linkerd in action, weâre going to need an application.
Letâs install a demo application called Emojivoto. Emojivoto is a simple standalone Kubernetes application that uses a mix of gRPC and HTTP calls to allow the user to vote on their favorite emojis.
Install Emojivoto into the emojivoto
namespace by running:
This command installs Emojivoto onto your cluster, but Linkerd hasnât been activated on it yetâweâll need to âmeshâ the application before Linkerd can work its magic.
Before we mesh it, letâs take a look at Emojivoto in its natural state.
Weâll do this by forwarding traffic to its web-svc
service so that we can
point our browser to it. Forward web-svc
locally to port 8080 by running:
Now visit http://localhost:8080. Voila! You should see Emojivoto in all its glory.
If you click around Emojivoto, you might notice that itâs a little broken! For example, if you try to vote for the donut emoji, youâll get a 404 page. Donât worry, these errors are intentional. (In a later guide, weâll show you how to use Linkerd to identify the problem.)
With Emoji installed and running, weâre ready to mesh itâthat is, to add Linkerdâs data plane proxies to it. We can do this on a live application without downtime, thanks to Kubernetesâs rolling deploys. Mesh your Emojivoto application by running:
This command retrieves all of the deployments running in the emojivoto
namespace, runs their manifests through linkerd inject
, and then reapplies it
to the cluster. (The linkerd inject
command simply adds annotations to the
pod spec that instruct Linkerd to inject the proxy into the pods when they
are created.)
As with install
, inject
is a pure text operation, meaning that you can
inspect the input and output before you use it. Once piped into kubectl apply
, Kubernetes will execute a rolling deploy and update each pod with the
data planeâs proxies.
Congratulations! Youâve now added Linkerd to an application! Just as with the control plane, itâs possible to verify that everything is working the way it should on the data plane side. Check your data plane with:
And, of course, you can visit http://localhost:8080 and once again see Emojivoto in all its meshed glory.
Step 5: Explore Linkerd!
Perhaps that last step was a little unsatisfying. Weâve added Linkerd to Emojivoto, but there are no visible changes to the application! That is part of Linkerdâs designâit does its best not to interfere with a functioning application.
Letâs take a closer look at what Linkerd is actually doing. To do this, weâll need to install an extension. Linkerdâs core control plane is extremely minimal, so Linkerd ships with extensions that add non-critical but often useful functionality to Linkerd, including a variety of dashboards.
Letâs install the viz extension, which will install an on-cluster metric stack and dashboard.
To install the viz extension, run:
Once youâve installed the extension, letâs validate everything one last time:
With the control plane and extensions installed and running, weâre now ready to explore Linkerd! Access the dashboard with:
You should see a screen like this:
Click around, explore, and have fun! For extra credit, see if you can find the live metrics for each Emojivoto component, and determine which one has a partial failure. (See the debugging tutorial below for much more on this.)
Thatâs it! đ
Congratulations, you have joined the exalted ranks of Linkerd users! Give yourself a pat on the back.
Whatâs next? Here are some steps we recommend:
- Learn how to use Linkerd to debug the errors in Emojivoto.
- Learn how to add your own services to Linkerd without downtime.
- Learn how to install other Linkerd extensions such as Jaeger and the multicluster extension.
- Learn more about Linkerdâs architecture
- Learn how to set up automatic control plane mTLS credential rotation for long-lived clusters.
- Learn how to restrict access to services using authorization policy.
- Hop into the
#linkerd
channel on the Linkerd Slack and say hi!
Above all else: welcome to the Linkerd community!