Skip to content

Commit

Permalink
doc(install): support helm-controller
Browse files Browse the repository at this point in the history
Signed-off-by: James Munson <james.munson@suse.com>
  • Loading branch information
james-munson committed Oct 28, 2024
1 parent 9ee1acc commit 1b9e1b5
Show file tree
Hide file tree
Showing 8 changed files with 181 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ The default settings can be customized in the following ways:
- [Using the Rancher UI](#using-the-rancher-ui)
- [Using the Longhorn Deployment YAML File](#using-the-longhorn-deployment-yaml-file)
- [Using Helm](#using-helm)
- [Using Helm Controller](#using-helm-controller)
- [Update Settings](#update-settings)
- [Using the Longhorn UI](#using-the-longhorn-ui)
- [Using the Rancher UI](#using-the-rancher-ui-1)
Expand Down Expand Up @@ -159,6 +160,20 @@ You can also provide a copy of the `values.yaml` file with the default settings
For more info about using helm, see the section about
[installing Longhorn with Helm](../../../deploy/install/install-with-helm)

### Using Helm Controller

In the HelmChart YAML file, add lines to spec.set with the desired settings:
```yaml
spec:
...
set:
defaultSettings.priorityClass: system-node-critical
defaultSettings.replicaAutoBalance: least-effort
defaultSettings.storageOverProvisioningPercentage: "200"
persistence.defaultClassReplicaCount: "2"
```

## Update Settings

### Using the Longhorn UI
Expand Down
1 change: 1 addition & 0 deletions content/docs/1.8.0/deploy/install/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ Longhorn can be installed on a Kubernetes cluster in several ways:
- [Rancher catalog app](./install-with-rancher)
- [kubectl](./install-with-kubectl/)
- [Helm](./install-with-helm/)
- [Helm Controller](./install-with-helm-controller/)
- [Fleet](./install-with-fleet/)
- [Flux](./install-with-flux/)
- [ArgoCD](./install-with-argocd/)
Expand Down
2 changes: 1 addition & 1 deletion content/docs/1.8.0/deploy/install/install-with-argocd.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Install with ArgoCD
weight: 12
weight: 13
---

## Prerequisites
Expand Down
2 changes: 1 addition & 1 deletion content/docs/1.8.0/deploy/install/install-with-fleet.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Install with Fleet
weight: 10
weight: 11
---

## Prerequisites
Expand Down
2 changes: 1 addition & 1 deletion content/docs/1.8.0/deploy/install/install-with-flux.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Install with Flux
weight: 11
weight: 12
---

## Prerequisites
Expand Down
124 changes: 124 additions & 0 deletions content/docs/1.8.0/deploy/install/install-with-helm-controller.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
---
title: Install with Helm Controller
weight: 10
---

In this section, you will learn how to install Longhorn with the HelmChart controller built into RKE2 and K3S.

### Prerequisites

- Kubernetes cluster: Ensure that each node fulfills the [installation requirements](../#installation-requirements). Cluster should be running RKE2 or K3S.

> [This script](https://github.com/longhorn/longhorn/blob/v{{< current-version >}}/scripts/environment_check.sh) can be used to check the Longhorn environment for potential issues.
### Installing Longhorn


> **Note**:
> * The initial settings for Longhorn can be [customized using Helm options or by editing the deployment configuration file.](../../../advanced-resources/deploy/customizing-default-settings/#using-helm)
> * For Kubernetes < v1.25, if your cluster still enables Pod Security Policy admission controller, set the helm value `enablePSP` to `true` to install `longhorn-psp` PodSecurityPolicy resource which allows privileged Longhorn pods to start.

1. Create a HelmChart yaml file similar to this:

```yaml
apiVersion: helm.cattle.io/v1
kind: HelmChart
metadata:
annotations:
helmcharts.cattle.io/managed-by: helm-controller
finalizers:
- wrangler.cattle.io/on-helm-chart-remove
generation: 1
name: longhorn-install
namespace: default
spec:
version: v1.8.0
chart: longhorn
repo: https://charts.longhorn.io
failurePolicy: abort
targetNamespace: longhorn-system
createNamespace: true

```

> **IMPORTANT!** Ensure that `spec.failurePolicy` is set to "abort". The only other value is the default: "reinstall", which performs an uninstall of Longhorn. With "abort", it retries periodically, giving the user a chance to fix the problem.

> **Note:** Rather than specify the repo, version, and chart name, the yaml can also use an image of the charts themselves:
```yaml
spec:
chartContent: <tarball of chart directory | base64 -w 0>
```
> For full details see the HelmChart controller docs: https://docs.rke2.io/helm or https://docs.k3s.io/helm.

2. Apply it to create the HelmChart CR and an installation job:

```shell
$ kubectl apply -f helmchart_repo_install.yaml
helmchart.helm.cattle.io/longhorn-install created
```

> **Note:** Deleting the helmchart CR will initiate an uninstall of Longhorn.

3. To show the created resources:

```shell
$ kubectl get jobs
NAME COMPLETIONS DURATION AGE
helm-install-longhorn-install 0/1 8s 8s
$ kubectl get pods
NAME READY STATUS RESTARTS AGE
helm-install-longhorn-install-lngm8 0/1 Completed 0 25s
$ kubectl get helmcharts
NAME JOB CHART TARGETNAMESPACE VERSION REPO HELMVERSION BOOTSTRAP
longhorn-install helm-install-longhorn longhorn longhorn-system v1.8.0 https://charts.longhorn.io
```

4. To confirm that the deployment succeeded, run:

```bash
kubectl -n longhorn-system get pod
```

The result should look like the following:

```bash
NAME READY STATUS RESTARTS AGE
csi-attacher-85c7684cfd-67kqc 1/1 Running 0 29m
csi-attacher-85c7684cfd-jbddj 1/1 Running 0 29m
csi-attacher-85c7684cfd-t85bw 1/1 Running 0 29m
csi-provisioner-68cdb8b96-46d9q 1/1 Running 0 29m
csi-provisioner-68cdb8b96-dgf5f 1/1 Running 0 29m
csi-provisioner-68cdb8b96-mh8q7 1/1 Running 0 29m
csi-resizer-86dd765b9-d27cs 1/1 Running 0 29m
csi-resizer-86dd765b9-scqxm 1/1 Running 0 29m
csi-resizer-86dd765b9-zpcv7 1/1 Running 0 29m
csi-snapshotter-65b46b8749-dtvh2 1/1 Running 0 29m
csi-snapshotter-65b46b8749-g67fn 1/1 Running 0 29m
csi-snapshotter-65b46b8749-nfgzm 1/1 Running 0 29m
engine-image-ei-221c9c21-gd5d6 1/1 Running 0 29m
engine-image-ei-221c9c21-v6clp 1/1 Running 0 29m
engine-image-ei-221c9c21-zzdrt 1/1 Running 0 29m
instance-manager-77d11dda6091967f9b30011c9876341b 1/1 Running 0 29m
instance-manager-870c250b69a4fe01382ed46156d33f47 1/1 Running 0 29m
instance-manager-a4099c5ce28b423c3cc2667906f4b0b4 1/1 Running 0 29m
longhorn-csi-plugin-jfbh5 3/3 Running 0 29m
longhorn-csi-plugin-w768w 3/3 Running 0 29m
longhorn-csi-plugin-xcghm 3/3 Running 0 29m
longhorn-driver-deployer-586bc86bf9-bkwk6 1/1 Running 0 30m
longhorn-manager-c4xtv 1/1 Running 1 (30m ago) 30m
longhorn-manager-kgqts 1/1 Running 0 30m
longhorn-manager-n8xdr 1/1 Running 0 30m
longhorn-ui-69667f9678-2lvxn 1/1 Running 0 30m
longhorn-ui-69667f9678-2xmc9 1/1 Running 0 30m
```

5. To enable access to the Longhorn UI, you need to set up an Ingress controller. Authentication to the Longhorn UI is not enabled by default. For information on creating an NGINX Ingress controller with basic authentication, refer to [this section.](../../accessing-the-ui/longhorn-ingress)

6. Access the Longhorn UI using [these steps.](../../accessing-the-ui)

12 changes: 12 additions & 0 deletions content/docs/1.8.0/deploy/uninstall/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@ In this section, you'll learn how to uninstall Longhorn.
- [Prerequisite](#prerequisite)
- [Uninstalling Longhorn from the Rancher UI](#uninstalling-longhorn-from-the-rancher-ui)
- [Uninstalling Longhorn using Helm](#uninstalling-longhorn-using-helm)
- [Uninstalling Longhorn using Helm Controller](#uninstalling-longhorn-using-helm-controller)
- [Uninstalling Longhorn using Fleet](#uninstalling-longhorn-using-fleet)
- [Uninstalling Longhorn using Flux](#uninstalling-longhorn-using-flux)
- [Uninstalling Longhorn using Argo CD](#uninstalling-longhorn-using-argo-cd)
- [Uninstalling Longhorn using kubectl](#uninstalling-longhorn-using-kubectl)
- [Troubleshooting](#troubleshooting)
- [Uninstalling using Rancher UI or Helm failed, I am not sure why](#uninstalling-using-rancher-ui-or-helm-failed-i-am-not-sure-why)
Expand Down Expand Up @@ -37,6 +41,14 @@ Run this command:
helm uninstall longhorn -n longhorn-system
```

### Uninstalling Longhorn using Helm Controller

Run this command:

```
kubectl delete helmchart <HelmChart name> -n <HelmChart namespace>
```

### Uninstalling Longhorn Using Fleet

Run the following command:
Expand Down
28 changes: 26 additions & 2 deletions content/docs/1.8.0/deploy/upgrade/longhorn-manager.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,11 +59,35 @@ To upgrade with Helm, run this command:
helm upgrade longhorn longhorn/longhorn --namespace longhorn-system --version {{< current-version >}}
```

#### Upgrade with Helm Controller

Update the value of `spec.version` in the `HelmChart` YAML file:

```yaml
spec:
version: v{{< current-version >}} # Replace with the Longhorn version you'd like to upgrade to
chart: longhorn
repo: https://charts.longhorn.io
failurePolicy: abort
```
Alternatively, if using the `spec.chartContent` key, create a patch file with
```yaml
spec:
chartContent: <base64 content> # tar cz of longhorn charts directory for release | base64 -w 0
```
and then apply it with
```
kubectl patch helmchart longhorn -n <namespace> --type merge --patch-file <name of patch file>
```
> **IMPORTANT!** In both cases, ensure that `spec.failurePolicy` is set to "abort". The only other value is the default: "reinstall", which performs an uninstall of Longhorn if the pre-upgrade check or the upgrade fails. With "abort", it retries periodically, giving the user a chance to fix the problem.
#### Upgrade with Fleet
Update the value of `helm.version` in the `fleet` YAML file of your GitOps repository.
```
```yaml
helm:
repo: https://charts.longhorn.io
chart: longhorn
Expand All @@ -75,7 +99,7 @@ helm:

Update the value of `spec.chart.spec.version` in the `HelmRelease` YAML file of your GitOps repository.

```
```yaml
spec:
chart:
spec:
Expand Down

0 comments on commit 1b9e1b5

Please sign in to comment.