Install Requirements
K10 can be installed in a variety of different environments and on a number of Kubernetes distributions today. To ensure a smooth install experience, running the pre-flight checks and ensuring that the prerequisites are met is highly recommended.
Pre-Flight Checks
Assuming that your default kubectl
context is pointed to the
cluster you want to install K10 on, you can run pre-flight checks by
deploying the primer
tool. This tool runs in a pod in the
cluster and does the following:
Validates if the Kubernetes settings meet the K10 requirements.
Catalogs the available StorageClasses.
If a CSI provisioner exists, it will also perform a basic validation of the cluster's CSI capabilities and any relevant objects that may be required. It is strongly recommended that the same tool be used to also perform a more complete CSI validation using the documentation here.
Note that this will create, and clean up, a ServiceAccount and ClusterRoleBinding to perform sanity checks on your Kubernetes cluster.
Run the following command to deploy the the pre-check tool:
$ curl https://docs.kasten.io/tools/k10_primer.sh | bash
To run the pre-flight checks in an air-gapped environment, use the following command:
$ curl https://docs.kasten.io/tools/k10_primer.sh | bash /dev/stdin -i repo.example.com/k10tools:|version|
Note
Follow this guide to prepare K10 container images for air-gapped use.
Prerequisites
The Helm package manager (v3.0.0+) and the Kasten Helm charts repository is required. Installing K10 via
helm
will also automatically create a new Service Account to grant K10 the required access to Kubernetes resources. If a pre-existing Service Account needs to be used, please follow these instructions.Add the Kasten Helm charts repository using:
$ helm repo add kasten https://charts.kasten.io/
You need to create the namespace where Kasten will be installed. By default, the documentation uses
kasten-io
.$ kubectl create namespace kasten-io
K10 assumes that the default storage class for is backed by SSDs or similarly fast storage media. If that is not true, please add the following option to the K10 Helm install commands to specify a performance-oriented storage class.
--set global.persistence.storageClass=<storage-class-name>
K10 Image Source Repositories
Here is the list of all the repositories that are used to deploy K10.
docker.io/datawire
docker.io/grafana
docker.io/jimmidyson
gcr.io/kasten-images
ghcr.io/kanisterio
quay.io/prometheus