In this example, we use the Landscaper to deploy a simple Helm chart.
For prerequisites, see here.
Our hello-world Helm chart is minimalistic on purpose, in order to concentrate on Landscaper rather than Helm features. Therefore, the chart only deploys a ConfigMap. We have uploaded the chart to a public registry from where the Landscaper reads it during the deployment.
First of all, we need to create two custom resources:
- a
target
custom resource, containing the access information for the target cluster - an
installation
custom resource containing the instructions for deploying the Helm chart
-
Add the kubeconfig of your target cluster to your target.yaml at the specified location.
-
On the Landscaper resource cluster, create a namespace
example
and apply your target.yaml and the installation.yaml:kubectl create ns example kubectl apply -f <path to target.yaml> kubectl apply -f <path to installation.yaml>
Alternative (which requires the Landscaper CLI):
-
In your commands/settings file, specify
- the path to the kubeconfig of your Landscaper resource cluster and
- the path to the kubeconfig of your target cluster.
-
Run script commands/apply-target-and-installation.sh.
After applying the target
and installation
resources to the Landscaper resource cluster, the Landscaper starts with the installation of the Helm chart. Please note that the Landscaper only starts working on an installation, if the annotation landscaper.gardener.cloud/operation: reconcile
is present. This annotation is automatically removed by the Landscaper as soon as it starts with processing the installation.
If you require the Landscaper to process the installation again (in case you did some changes to the installation
resource and thus require a reconcilliation), just add the landscaper.gardener.cloud/operation: reconcile
annotation again.
You can now check the status of the installation:
kubectl get inst -n example hello-world
The most important field in the status section is the phase
, which should have show the value Succeeded
as soon as the Helm chart has been successfully deployed.
status:
phase: Succeeded
If you have already installed the Landscaper CLI, you can inspect the status of the installation with the following command, executed on the Landscaper resource cluster:
landscaper-cli inst inspect -n example hello-world
Another important entry in status section of an installation is the observedGeneration
. It describes to which version of the installation, defined by its generation
, the current status refers to. In order to check if the latest
version of an installation has been processed, you must check
- whether
phase
is equal toSucceeded
orFailed
(orDeleteFailed
, if the deletion of the installation failed) and - whether
generation
is equal toobservedGeneration
.
After the successfull installation, you should find the ConfigMap, which was deployed as part of the Helm chart, on the target cluster:
kubectl get configmap -n example hello-world
In this example, we created an Installation
custom resource, containing the instructions for deploying our example Helm chart, and a Target
custom resource, containing the access information for the target cluster on which the Helm chart should be deployed.
The Installation
contains two main sections in its spec
:
spec:
# Set values for the import parameters of the blueprint
imports:
targets:
- name: cluster # name of an import parameter of the blueprint
target: my-cluster # name of the Target custom resource containing the kubeconfig of the target cluster
blueprint:
...
The imports
section contains the reference to the target object and the blueprint
section the deploy instructions (we will cover the topic of blueprints
in a later example).
You can uninstall the hello-world Helm chart by deleting the Installation
custom resource from the Landscaper resource cluster:
kubectl delete inst -n example hello-world
Note that deleting an Installation
like this will also delete the deployed Helm chart, which is the expected behaviour.
Above we wrote that Landscaper only starts working on an Installation if it has the annotation
landscaper.gardener.cloud/operation: reconcile
. There is also the possibility to let Landscaper add this
annotation automatically such that you get an automatic reconciliation of an Installation. For more details
see here.