From 500da9acb0094495f2eee1fa714fa26d5da2b285 Mon Sep 17 00:00:00 2001 From: Eric Paulsen Date: Thu, 19 Oct 2023 04:44:16 -0400 Subject: [PATCH] docs: add imagepullsecret & volume mount steps (#58) --- README.md | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) diff --git a/README.md b/README.md index 294c036..b67620e 100644 --- a/README.md +++ b/README.md @@ -65,6 +65,46 @@ After you have a configuration that resembles the following: `base64` encode the JSON and provide it to envbuilder as the `DOCKER_CONFIG_BASE64` environment variable. +Alternatively, if running `envbuilder` in Kubernetes, you can create an `ImagePullSecret` and +pass it into the pod as a volume mount. This example will work for all registries. + +```shell +# Artifactory example +kubectl create secret docker-registry regcred \ + --docker-server=my-artifactory.jfrog.io \ + --docker-username=read-only \ + --docker-password=secret-pass \ + --docker-email=me@example.com \ + -n coder +``` + +```hcl +resource "kubernetes_deployment" "example" { + metadata { + namespace = coder + } + spec { + spec { + container { + # Define the volumeMount with the pull credentials + volume_mount { + name = "docker-config-volume" + mount_path = "/envbuilder/config.json" + sub_path = ".dockerconfigjson" + } + } + # Define the volume which maps to the pull credentials + volume { + name = "docker-config-volume" + secret { + secret_name = "regcred" + } + } + } + } +} +``` + ### Docker Hub Authenticate with `docker login` to generate `~/.docker/config.json`. Encode this file using the `base64` command: