dhi.io/thanos-chart
Thanos is a highly available metrics system that offers long term storage capabilities.
All examples in this guide use the public chart and images. If you've mirrored the repository for your own use (for example, to your Docker Hub namespace), update your commands to reference the mirrored chart instead of the public one.
For example:
dhi.io/<repository>:<tag><your-namespace>/dhi-<repository>:<tag>For more details about customizing the chart to reference other images, see the documentation.
Step 1: Optional. Mirror the Helm chart and/or its images to your own registry
To optionally mirror a chart to your own third-party registry, you can follow the instructions in How to mirror an image for either the chart, the image, or both.
The same regctl tool that is used for mirroring container images can also be used for mirroring Helm charts, as Helm
charts are OCI artifacts.
For example:
regctl image copy \
"${SRC_CHART_REPO}:${TAG}" \
"${DEST_REG}/${DEST_CHART_REPO}:${TAG}" \
--referrers \
--referrers-src "${SRC_ATT_REPO}" \
--referrers-tgt "${DEST_REG}/${DEST_CHART_REPO}" \
--force-recursive
Step 2: Create a Kubernetes secret for pulling images
The Docker Hardened Images that the chart uses require authentication. To allow your Kubernetes cluster to pull those images, you need to create a Kubernetes secret with your Docker Hub credentials or with the credentials for your own registry.
Follow the authentication instructions for DHI in Kubernetes.
For example:
kubectl create secret docker-registry helm-pull-secret \
--docker-server=dhi.io \
--docker-username=<Docker username> \
--docker-password=<Docker token> \
--docker-email=<Docker email>
Step 3: Install the Helm chart
To install the chart, use helm install. Make sure you use helm login to log in before running helm install.
Optionally, you can also use the --dry-run flag to test the installation without actually installing anything.
helm install my-thanos oci://dhi.io/thanos-chart --version <version> \
--set "global.imagePullSecrets[0]=helm-pull-secret" \
Replace <version> accordingly. If the chart is in your own registry or repository, replace dhi.io with your own
registry and namespace. Replace helm-pull-secret with the name of the image pull secret you created earlier.
Step 4: Verify the installation
The deployment's pod should show up and running almost immediately:
$ kubectl get all
NAME READY STATUS RESTARTS AGE
pod/test-thanos-query-5c5fdb68f9-5v6br 1/1 Running 0 51s
pod/test-thanos-query-frontend-5c8dffb94-v2fc8 1/1 Running 0 51s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 117d
service/test-thanos-query ClusterIP 10.105.219.70 <none> 9090/TCP 51s
service/test-thanos-query-frontend ClusterIP 10.107.25.135 <none> 9090/TCP 51s
service/test-thanos-query-grpc ClusterIP 10.96.181.108 <none> 10901/TCP 51s
NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/test-thanos-query 1/1 1 1 51s
deployment.apps/test-thanos-query-frontend 1/1 1 1 51s
NAME DESIRED CURRENT READY AGE
replicaset.apps/test-thanos-query-5c5fdb68f9 1 1 1 51s
replicaset.apps/test-thanos-query-frontend-5c8dffb94 1 1 1 51s