Deploying the Virtual Garden with Landscaper
The virtual garden can be deployed using the container deployer of Landscaper.
This requires a cluster on which the landscaper is installed.
The container deployer executes an image with the deploy logic that is implemented in this project. The following steps describe how to build this image and push it into an OCI registry.
-
Adjust the
REGISTRY
variable in the Makefile so that it points to your OCI registry. -
Execute the following command to build the image
make docker-images
-
Login to the OCI registry and execute the following command to push the image into the OCI registry.
make docker-push
The following command creates a component descriptor for the virtual garden component and pushes it into the OCI registry.
make cnudie
The component descriptor contains the list of all resources required for the deployment of the virtual garden:
- the blueprint,
- the image from the previous step, which will be executed by the container deployer,
- the images of etcd, kube-apiserver, etc. which will be deployed to the runtime cluster of the virtual garden.
In order to trigger the deployment of the virtual garden, we must create a Target and an Installation on the landscaper cluster. Both must be in the same namespace.
-
Create a Target custom resource on the landscaper cluster. The Target must have the type
landscaper.gardener.cloud/kubernetes-cluster
and contain the kubeconfig of the host cluster of the virtual garden. -
Use the following command to create the yaml manifest of an Installation:
make create-installation
-
Adjust the Installation:
-
Field
.spec.imports.targets[0].target
must contain a hash sign#
followed by the name of the Target created in the previous step. -
Field
.spec.importDataMappings
contains the configuration of the virtual garden.
-
-
Apply the Installation to the landscaper cluster.