Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Helm migration instructions for 2.12 #1245

Merged
merged 7 commits into from
Jan 10, 2022
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
123 changes: 55 additions & 68 deletions linkerd.io/content/2.12/tasks/install-helm.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,10 @@ to generate new ones.
## Adding Linkerd's Helm repository

```bash
# To add the repo for Linkerd2 stable releases:
# To add the repo for Linkerd stable releases:
helm repo add linkerd https://helm.linkerd.io/stable

# To add the repo for Linkerd2 edge releases:
# To add the repo for Linkerd edge releases:
helm repo add linkerd-edge https://helm.linkerd.io/edge
```

Expand All @@ -30,106 +30,91 @@ release, just replace with `linkerd-edge`.

## Helm install procedure

You need to install two separate charts in succession: first `linkerd-base` and
then `linkerd-control-plane`.

### linkerd-base

The `linkerd-base` chart sets up all the cluster-level resources, including
CRDs. Therefore you require cluster-level privileges for setting it up:
alpeb marked this conversation as resolved.
Show resolved Hide resolved

```bash
# set expiry date one year from now, in Mac:
exp=$(date -v+8760H +"%Y-%m-%dT%H:%M:%SZ")
# in Linux:
exp=$(date -d '+8760 hour' +"%Y-%m-%dT%H:%M:%SZ")
helm install linkerd-base -n linkerd --create-namespace linkerd/linkerd-base
```

helm install linkerd2 \
{{< note >}}
This will create the `linkerd` namespace. If it already exists or you're
creating it beforehand elsewhere in your pipeline, just omit the
`--create-namespace` flag.
{{< /note >}}

### linkerd-control-plane

The `linkerd-control-plane` chart sets up all the resources inside the `linkerd`
namespace. It only requires namespace-level privileges.

```bash
helm install linkerd-control-plane \
-n linkerd \
--set-file identityTrustAnchorsPEM=ca.crt \
--set-file identity.issuer.tls.crtPEM=issuer.crt \
--set-file identity.issuer.tls.keyPEM=issuer.key \
--set identity.issuer.crtExpiry=$exp \
linkerd/linkerd2
linkerd/linkerd-control-plane
```

{{< note >}}
For Helm versions < v3, `--name` flag has to specifically be passed.
In Helm v3, It has been deprecated, and is the first argument as
specified above.
You can use a different namespace, but it must be the same you referred to when
installing `linkerd-base`.
{{< /note >}}

The chart values will be picked from the chart's `values.yaml` file.

You can override the values in that file by providing your own `values.yaml`
file passed with a `-f` option, or overriding specific values using the family of
`--set` flags like we did above for certificates.

## Disabling The Proxy Init Container

If installing with CNI, make sure that you add the `--set
cniEnabled=true` flag to your `helm install` command.
cniEnabled=true` flag to your `helm install` command in both charts.

## Setting High-Availability

The chart contains a file `values-ha.yaml` that overrides some
default values as to set things up under a high-availability scenario, analogous
to the `--ha` option in `linkerd install`. Values such as higher number of
replicas, higher memory/cpu limits and affinities are specified in that file.
Both charts contain a file `values-ha.yaml` that override some default values as
alpeb marked this conversation as resolved.
Show resolved Hide resolved
to set things up under a high-availability scenario, analogous to the `--ha`
option in `linkerd install`. Values such as higher number of replicas, higher
memory/cpu limits and affinities are specified in those files.

You can get ahold of `values-ha.yaml` by fetching the chart files:

```bash
helm fetch --untar linkerd/linkerd2
helm fetch --untar linkerd/linkerd-base
helm fetch --untar linkerd/linkerd-control-plane
```

Then use the `-f` flag to provide the override file, for example:

```bash
## see above on how to set $exp
helm install linkerd2 \
helm install linkerd-control-plane \
--set-file identityTrustAnchorsPEM=ca.crt \
--set-file identity.issuer.tls.crtPEM=issuer.crt \
--set-file identity.issuer.tls.keyPEM=issuer.key \
--set identity.issuer.crtExpiry=$exp \
-f linkerd2/values-ha.yaml \
linkerd/linkerd2
-f linkerd-control-plane/values-ha.yaml \
linkerd/linkerd-control-plane
```

{{< note >}}
For Helm versions < v3, `--name` flag has to specifically be passed.
In Helm v3, It has been deprecated, and is the first argument as
specified above.
{{< /note >}}

## Customizing the Namespace

To install Linkerd to a different namespace than the default `linkerd`,
override the `Namespace` variable.

By default, the chart creates the control plane namespace with the
`config.linkerd.io/admission-webhooks: disabled` label. It is required for the
control plane to work correctly. This means that the chart won't work with
Helm v2's `--namespace` option. If you're relying on a separate tool to create
the control plane namespace, make sure that:

1. The namespace is labeled with `config.linkerd.io/admission-webhooks: disabled`
1. The `installNamespace` is set to `false`
1. The `namespace` variable is overridden with the name of your namespace

{{< note >}}
In Helm v3 the `--namespace` option must be used with an existing namespace.
{{< /note >}}

## Helm upgrade procedure

Make sure your local Helm repos are updated:

```bash
helm repo update

helm search repo linkerd2
NAME CHART VERSION APP VERSION DESCRIPTION
linkerd/linkerd2 <chart-semver-version> {{% latestversion %}} Linkerd gives you observability, reliability, and securit...
helm search repo linkerd
NAME CHART VERSION APP VERSION DESCRIPTION
linkerd/linkerd-base <chart-semver-version> {{% latestversion %}} Linkerd gives you observability, reliability, and securit...
linkerd/linkerd-control-plane <chart-semver-version> {{% latestversion %}} Linkerd gives you observability, reliability, and securit...
```

The `helm upgrade` command has a number of flags that allow you to customize
its behaviour. The ones that special attention should be paid to are
`--reuse-values` and `--reset-values` and how they behave when charts change
from version to version and/or overrides are applied through `--set` and
`--set-file`. To summarize there are the following prominent cases that can be
observed:
`--set-file`. To summarize these are prominent cases that can be observed:

- `--reuse-values` with no overrides - all values are reused
- `--reuse-values` with overrides - all except the values that are overridden
Expand All @@ -142,17 +127,19 @@ provided release are applied together with the overrides
- no flag and overrides - `--reset-values` will be used by default

Bearing all that in mind, you have to decide whether you want to reuse the
values in the chart or move to the values specified in the newer chart.
The advised practice is to use a `values.yaml` file that stores all custom
overrides that you have for your chart. Before upgrade, check whether there
are breaking changes to the chart (i.e. renamed or moved keys, etc). You can
consult the [edge](https://hub.helm.sh/charts/linkerd2-edge/linkerd2) or the
[stable](https://hub.helm.sh/charts/linkerd2/linkerd2) chart docs, depending on
which one your are upgrading to. If there are, make the corresponding changes to
your `values.yaml` file. Then you can use:
values in the chart or move to the values specified in the newer chart. The
advised practice is to use a `values.yaml` file that stores all custom overrides
that you have for your chart. Before upgrade, check whether there are breaking
changes to the chart (i.e. renamed or moved keys, etc). You can consult the
[edge](https://artifacthub.io/packages/helm/linkerd2/linkerd-control-plane#values)
or the
[stable](https://artifacthub.io/packages/helm/linkerd2-edge/linkerd-control-plane#values)
chart docs, depending on which one your are upgrading to. If there are, make the
corresponding changes to your `values.yaml` file. Then you can use:

```bash
helm upgrade linkerd2 linkerd/linkerd2 --reset-values -f values.yaml --atomic
helm upgrade linkerd-base linkerd/linkerd-base --reset-values -f values.yaml --atomic
helm upgrade linkerd-control-plane linkerd/linkerd-control-plane --reset-values -f values.yaml --atomic
```

The `--atomic` flag will ensure that all changes are rolled back in case the
Expand Down
68 changes: 66 additions & 2 deletions linkerd.io/content/2.12/tasks/upgrade.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ Before starting, read through the version-specific upgrade notices below, which
may contain important information you need to be aware of before commencing
with the upgrade process:

- [Upgrade notice: stable-2.12.0](#upgrade-notice-stable-2-12-0)
- [Upgrade notice: stable-2.11.0](#upgrade-notice-stable-2-11-0)
- [Upgrade notice: stable-2.10.0](#upgrade-notice-stable-2-10-0)
- [Upgrade notice: stable-2.9.4](#upgrade-notice-stable-2-9-4)
Expand Down Expand Up @@ -149,8 +150,8 @@ your Kubernetes cluster, it is time to upgrade the data plane. The easiest
way to do this is to run a rolling deploy on your services, allowing the
proxy-injector to inject the latest version of the proxy as they come up.

With `kubectl` 1.15+, this can be as simple as using the `kubectl rollout
restart` command to restart all your meshed services. For example,
This can be as simple as using the `kubectl rollout restart` command to restart
all your meshed services. For example,

```bash
kubectl -n <namespace> rollout restart deploy
Expand Down Expand Up @@ -190,6 +191,69 @@ Congratulation! You have successfully upgraded your Linkerd to the newer
version. If you have any questions, feel free to raise them at the #linkerd2
channel in the [Linkerd slack](https://slack.linkerd.io/).

## Upgrade notice: stable-2.12.0

The minimum Kubernetes version supported is `v1.20.0`.

### Breaking changes in the core Helm chart

The `linkerd2` chart has been replaced by two charts: `linkerd-base` and
`linkerd-control-plane`. Please check the updated [Helm
instructions](../install-helm/) for details. Note that all the extension charts
like viz and multicluster remain as-is. Also note that support for Helm v2 has
been dropped.

Migrating to these new charts will incur in downtime for linkerd's control plane
during the process, but as the proxies don't require the control plane to always
be up, the data plane shouldn't incur in downtime. Just make sure you roll your
data plane deployments after the control plane is updated, as explained in
[upgrade the data plane](#upgrade-the-data-plane).

Before proceeding, make sure you retrieve all your chart values customizations,
in particular your trust root and issuer keys (`identityTrustAnchorsPEM`,
`identity.issuer.tls.crtPEM` and `identity.issuer.tls.keyPEM`). These values
will need to be fed again into the `helm install` commands below. The values
will now be split between the two new charts; please consult `linkerd-base`'s
[values.yaml](https://github.com/linkerd/linkerd2/blob/c5a02a42d0af587da3624523386bc9ff8ae2e6af/charts/linkerd-base/values.yaml)
and `linkerd-control-plane`'s
[values.yaml](https://github.com/linkerd/linkerd2/blob/c5a02a42d0af587da3624523386bc9ff8ae2e6af/charts/linkerd-control-plane/values.yaml)
to find out.

To start the migration first find the namespace you used to store the previous
linkerd chart helm config:

```bash
$ helm ls -A
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
linkerd default 1 2021-11-22 17:14:50.751436374 -0500 -05 deployed linkerd2-2.11.1 stable-2.11.1
```

If you did use Helm's `-namespace` flag when you previously installed linkerd,
alpeb marked this conversation as resolved.
Show resolved Hide resolved
then you should see that namespace reflected in the output above, and use it
instead of `default` when deleting the chart:

```bash
helm delete -n default linkerd
```

Then install both new charts, one after the other:

```bash
# first make sure you update the helm repo
helm repo up

# now install the linkerd-base chart
helm install linkerd-base -n linkerd --create-namespace linkerd/linkerd-base

# then install the linkerd-control-plane chart
helm install linkerd-control-plane \
-n linkerd \
--set-file identityTrustAnchorsPEM=ca.crt \
--set-file identity.issuer.tls.crtPEM=issuer.crt \
--set-file identity.issuer.tls.keyPEM=issuer.key \
linkerd/linkerd-control-plane
```

## Upgrade notice: stable-2.11.0

The minimum Kubernetes version supported is `v1.17.0`. There are two breaking
Expand Down