LogoLogo
Bonsai (0.13) DocsGitHubDiscord CommunityGarden Enterprise
Acorn (0.12)
Acorn (0.12)
  • Welcome!
  • 🌳Basics
    • How Garden Works
    • Quickstart Guide
    • The Stack Graph (Terminology)
  • 🌻Tutorials
    • Your First Project
      • 1. Initialize a Project
      • 2. Connect to a Cluster
      • 3. Deploy and Test
      • 4. Configure Your Project
  • 💐Using Garden
    • Configuration Overview
    • Projects
    • Modules
    • Services
    • Tests
    • Tasks
    • Workflows
    • Variables and templating
    • Module Templates
    • Using the CLI
  • 🌿Kubernetes Plugins
    • About
    • Remote K8s Plugin Configuration
      • 1. Create a Cluster
        • AWS
        • GCP
        • Azure
      • 2. Configure Container Registry (Optional)
        • AWS
        • GCP
        • Azure
      • 3. Set Up Ingress, TLS and DNS
      • 4. Configure the Provider
    • Local K8s Plugin Configuration
      • 1. Install Local Kubernetes
      • 2. Configure the Provider
    • Module Configuration
      • Container
      • Kubernetes
      • Helm
      • PersistentVolumeClaim
      • ConfigMap
    • Advanced
      • In-Cluster Building
      • Minimal RBAC Configuration for Development Clusters
      • Deploying to Production
  • 🌺Terraform Plugin
    • About
    • Provider Configuration
    • Module Configuration
  • ☘️Pulumi Plugin
    • About
    • Provider Configuration
    • Module Configuration
  • 🌹Other Plugins
    • Container
    • Exec (local scripts)
  • 🌼Guides
    • Installing Garden
    • Adopting Garden
    • Code Synchronization (Dev Mode)
    • Connecting a local service to a K8s cluster (Local Mode)
    • Environments and namespaces
    • Hot Reload
    • Migrating from Docker Compose to Garden
    • Using Garden in CI
  • 🌷Advanced
    • cert-manager Integration
    • Using Remote Sources
    • Custom Commands
  • 🪷Reference
    • Providers
      • conftest-container
      • conftest-kubernetes
      • conftest
      • container
      • exec
      • hadolint
      • jib
      • kubernetes
      • local-kubernetes
      • maven-container
      • octant
      • openfaas
      • pulumi
      • terraform
    • Module Types
      • configmap
      • conftest
      • container
      • exec
      • hadolint
      • helm
      • jib-container
      • kubernetes
      • maven-container
      • openfaas
      • persistentvolumeclaim
      • pulumi
      • templated
      • terraform
    • Template Strings
      • Project configuration context
      • Environment configuration context
      • Provider configuration context
      • Module configuration context
      • Remote Source configuration context
      • Project Output configuration context
      • Custom Command configuration context
      • Workflow configuration context
      • Template Helper Functions
    • Glossary
    • Commands
    • Project Configuration
    • Module Template Configuration
    • Workflow Configuration
  • 🎋Misc
    • FAQ
    • Troubleshooting
    • Telemetry
Powered by GitBook
On this page
  • Description
  • Complete YAML Schema
  • Configuration Keys
  • providers[]
  • providers[].dependencies[]
  • providers[].environments[]
  • providers[].buildMode
  • providers[].clusterBuildkit
  • providers[].clusterBuildkit.cache[]
  • providers[].clusterBuildkit.cache[].type
  • providers[].clusterBuildkit.cache[].registry
  • providers[].clusterBuildkit.cache[].registry.hostname
  • providers[].clusterBuildkit.cache[].registry.port
  • providers[].clusterBuildkit.cache[].registry.namespace
  • providers[].clusterBuildkit.cache[].registry.insecure
  • providers[].clusterBuildkit.cache[].mode
  • providers[].clusterBuildkit.cache[].tag
  • providers[].clusterBuildkit.cache[].export
  • providers[].clusterBuildkit.rootless
  • providers[].clusterBuildkit.nodeSelector
  • providers[].clusterBuildkit.tolerations[]
  • providers[].clusterBuildkit.tolerations[].effect
  • providers[].clusterBuildkit.tolerations[].key
  • providers[].clusterBuildkit.tolerations[].operator
  • providers[].clusterBuildkit.tolerations[].tolerationSeconds
  • providers[].clusterBuildkit.tolerations[].value
  • providers[].clusterBuildkit.annotations
  • providers[].clusterDocker
  • providers[].clusterDocker.enableBuildKit
  • providers[].jib
  • providers[].jib.pushViaCluster
  • providers[].kaniko
  • providers[].kaniko.extraFlags[]
  • providers[].kaniko.image
  • providers[].kaniko.namespace
  • providers[].kaniko.nodeSelector
  • providers[].kaniko.tolerations[]
  • providers[].kaniko.tolerations[].effect
  • providers[].kaniko.tolerations[].key
  • providers[].kaniko.tolerations[].operator
  • providers[].kaniko.tolerations[].tolerationSeconds
  • providers[].kaniko.tolerations[].value
  • providers[].kaniko.annotations
  • providers[].kaniko.util
  • providers[].kaniko.util.tolerations[]
  • providers[].kaniko.util.tolerations[].effect
  • providers[].kaniko.util.tolerations[].key
  • providers[].kaniko.util.tolerations[].operator
  • providers[].kaniko.util.tolerations[].tolerationSeconds
  • providers[].kaniko.util.tolerations[].value
  • providers[].kaniko.util.annotations
  • providers[].kaniko.util.nodeSelector
  • providers[].defaultHostname
  • providers[].deploymentStrategy
  • providers[].devMode
  • providers[].devMode.defaults
  • providers[].devMode.defaults.exclude[]
  • providers[].devMode.defaults.fileMode
  • providers[].devMode.defaults.directoryMode
  • providers[].devMode.defaults.owner
  • providers[].devMode.defaults.group
  • providers[].forceSsl
  • providers[].imagePullSecrets[]
  • providers[].imagePullSecrets[].name
  • providers[].imagePullSecrets[].namespace
  • providers[].copySecrets[]
  • providers[].copySecrets[].name
  • providers[].copySecrets[].namespace
  • providers[].resources
  • providers[].resources.builder
  • providers[].resources.builder.limits
  • providers[].resources.builder.limits.cpu
  • providers[].resources.builder.limits.memory
  • providers[].resources.builder.limits.ephemeralStorage
  • providers[].resources.builder.requests
  • providers[].resources.builder.requests.cpu
  • providers[].resources.builder.requests.memory
  • providers[].resources.builder.requests.ephemeralStorage
  • providers[].resources.registry
  • providers[].resources.registry.limits
  • providers[].resources.registry.limits.cpu
  • providers[].resources.registry.limits.memory
  • providers[].resources.registry.limits.ephemeralStorage
  • providers[].resources.registry.requests
  • providers[].resources.registry.requests.cpu
  • providers[].resources.registry.requests.memory
  • providers[].resources.registry.requests.ephemeralStorage
  • providers[].resources.util
  • providers[].resources.util.limits
  • providers[].resources.util.limits.cpu
  • providers[].resources.util.limits.memory
  • providers[].resources.util.limits.ephemeralStorage
  • providers[].resources.util.requests
  • providers[].resources.util.requests.cpu
  • providers[].resources.util.requests.memory
  • providers[].resources.util.requests.ephemeralStorage
  • providers[].resources.sync
  • providers[].resources.sync.limits
  • providers[].resources.sync.limits.cpu
  • providers[].resources.sync.limits.memory
  • providers[].resources.sync.limits.ephemeralStorage
  • providers[].resources.sync.requests
  • providers[].resources.sync.requests.cpu
  • providers[].resources.sync.requests.memory
  • providers[].resources.sync.requests.ephemeralStorage
  • providers[].storage
  • providers[].storage.builder
  • providers[].storage.builder.size
  • providers[].storage.builder.storageClass
  • providers[].storage.nfs
  • providers[].storage.nfs.storageClass
  • providers[].storage.registry
  • providers[].storage.registry.size
  • providers[].storage.registry.storageClass
  • providers[].storage.sync
  • providers[].storage.sync.size
  • providers[].storage.sync.storageClass
  • providers[].tlsCertificates[]
  • providers[].tlsCertificates[].name
  • providers[].tlsCertificates[].hostnames[]
  • providers[].tlsCertificates[].secretRef
  • providers[].tlsCertificates[].secretRef.name
  • providers[].tlsCertificates[].secretRef.namespace
  • providers[].tlsCertificates[].managedBy
  • providers[].certManager
  • providers[].certManager.install
  • providers[].certManager.email
  • providers[].certManager.issuer
  • providers[].certManager.acmeServer
  • providers[].certManager.acmeChallengeType
  • providers[].systemNodeSelector
  • providers[].registryProxyTolerations[]
  • providers[].registryProxyTolerations[].effect
  • providers[].registryProxyTolerations[].key
  • providers[].registryProxyTolerations[].operator
  • providers[].registryProxyTolerations[].tolerationSeconds
  • providers[].registryProxyTolerations[].value
  • providers[].name
  • providers[].context
  • providers[].deploymentRegistry
  • providers[].deploymentRegistry.hostname
  • providers[].deploymentRegistry.port
  • providers[].deploymentRegistry.namespace
  • providers[].deploymentRegistry.insecure
  • providers[].ingressClass
  • providers[].ingressHttpPort
  • providers[].ingressHttpsPort
  • providers[].kubeconfig
  • providers[].kubectlPath
  • providers[].namespace
  • providers[].namespace.name
  • providers[].namespace.annotations
  • providers[].namespace.labels
  • providers[].setupIngressController
  • Outputs
  • ${providers.<provider-name>.outputs.app-namespace}
  • ${providers.<provider-name>.outputs.default-hostname}
  • ${providers.<provider-name>.outputs.metadata-namespace}

Was this helpful?

  1. Reference
  2. Providers

kubernetes

PreviousjibNextlocal-kubernetes

Last updated 1 year ago

Was this helpful?

Description

The kubernetes provider allows you to deploy to Kubernetes clusters, and adds the and module types.

For usage information, please refer to the . A good place to start is the guide if you're connecting to remote clusters. The guide is also helpful as an introduction.

Note that if you're using a local Kubernetes cluster (e.g. minikube or Docker Desktop), the simplifies (and automates) the configuration and setup quite a bit.

Below is the full schema reference for the provider configuration. For an introduction to configuring a Garden project with providers, please look at our .

The reference is divided into two sections. The contains the complete YAML schema, and the describes each schema key.

Complete YAML Schema

The values in the schema below are the default values.

providers:
  - # List other providers that should be resolved before this one.
    dependencies: []

    # If specified, this provider will only be used in the listed environments. Note that an empty array effectively
    # disables the provider. To use a provider in all environments, omit this field.
    environments:

    # Choose the mechanism for building container images before deploying. By default your local Docker daemon is
    # used, but you can set it to `cluster-buildkit` or `kaniko` to sync files to the cluster, and build container
    # images there. This removes the need to run Docker locally, and allows you to share layer and image caches
    # between multiple developers, as well as between your development and CI workflows.
    #
    # For more details on all the different options and what makes sense to use for your setup, please check out the
    # [in-cluster building
    # guide](https://docs.garden.io/v/acorn-0.12/kubernetes-plugins/advanced/in-cluster-building).
    #
    # **Note:** The `cluster-docker` mode has been deprecated and will be removed in a future release!
    buildMode: local-docker

    # Configuration options for the `cluster-buildkit` build mode.
    clusterBuildkit: {}
      # Use the `cache` configuration to customize the default cluster-buildkit cache behaviour.
      #
      # The default value is:
      # clusterBuildkit:
      #   cache:
      #     - type: registry
      #       mode: auto
      #
      # For every build, this will
      # - import cached layers from a docker image tag named `_buildcache`
      # - when the build is finished, upload cache information to `_buildcache`
      #
      # For registries that support it, `mode: auto` (the default) will enable the buildkit `mode=max`
      # option.
      #
      # See the following table for details on our detection mechanism:
      #
      # | Registry Name                   | Registry Domain         | Assumed `mode=max` support |
      # |---------------------------------|-------------------------|------------------------------|
      # | Google Cloud Artifact Registry  | `pkg.dev`             | Yes                          |
      # | Azure Container Registry        | `azurecr.io`          | Yes                          |
      # | GitHub Container Registry       | `ghcr.io`             | Yes                          |
      # | DockerHub                       | `hub.docker.com`     | Yes                          |
      # | Garden In-Cluster Registry      |                         | Yes                          |
      # | Any other registry              |                         | No                           |
      #
      # In case you need to override the defaults for your registry, you can do it like so:
      #
      # clusterBuildkit:
      #   cache:
      #     - type: registry
      #       mode: max
      #
      # When you add multiple caches, we will make sure to pass the `--import-cache` options to buildkit in the same
      # order as provided in the cache configuration. This is because buildkit will not actually use all imported
      # caches
      # for every build, but it will stick with the first cache that yields a cache hit for all the following layers.
      #
      # An example for this is the following:
      #
      # clusterBuildkit:
      #   cache:
      #     - type: registry
      #       tag: _buildcache-${slice(kebabCase(git.branch), "0", "30")}
      #     - type: registry
      #       tag: _buildcache-main
      #       export: false
      #
      # Using this cache configuration, every build will first look for a cache specific to your feature branch.
      # If it does not exist yet, it will import caches from the main branch builds (`_buildcache-main`).
      # When the build is finished, it will only export caches to your feature branch, and avoid polluting the `main`
      # branch caches.
      # A configuration like that may improve your cache hit rate and thus save time.
      #
      # If you need to disable caches completely you can achieve that with the following configuration:
      #
      # clusterBuildkit:
      #   cache: []
      cache:
        - # Use the Docker registry configured at `deploymentRegistry` to retrieve and store buildkit cache
          # information.
          #
          # See also the [buildkit registry cache
          # documentation](https://github.com/moby/buildkit#registry-push-image-and-cache-separately)
          type:

          # The registry from which the cache should be imported from, or which it should be exported to.
          #
          # If not specified, use the configured `deploymentRegistry` in your kubernetes provider config, or the
          # internal in-cluster registry in case `deploymentRegistry` is not set.
          #
          # Important: You must make sure `imagePullSecrets` includes authentication with the specified cache
          # registry, that has the appropriate write privileges (usually full write access to the configured
          # `namespace`).
          registry:
            # The hostname (and optionally port, if not the default port) of the registry.
            hostname:

            # The port where the registry listens on, if not the default.
            port:

            # The registry namespace. Will be placed between hostname and image name, like so:
            # <hostname>/<namespace>/<image name>
            namespace: _

            # Set to true to allow insecure connections to the registry (without SSL).
            insecure: false

          # This is the buildkit cache mode to be used.
          #
          # The value `inline` ensures that garden is using the buildkit option `--export-cache inline`. Cache
          # information will be inlined and co-located with the Docker image itself.
          #
          # The values `min` and `max` ensure that garden passes the `mode=max` or `mode=min` modifiers to the
          # buildkit `--export-cache` option. Cache manifests will only be
          # stored stored in the configured `tag`.
          #
          # `auto` is the same as `max` for some registries that are known to support it. Garden will fall back to
          # `inline` for all other registries.
          #  See the [clusterBuildkit cache option](#providers-.clusterbuildkit.cache) for a description of the
          # detection mechanism.
          #
          # See also the [buildkit export cache documentation](https://github.com/moby/buildkit#export-cache)
          mode: auto

          # This is the Docker registry tag name buildkit should use for the registry build cache. Default is
          # `_buildcache`
          #
          # **NOTE**: `tag` can only be used together with the `registry` cache type
          tag: _buildcache

          # If this is false, only pass the `--import-cache` option to buildkit, and not the `--export-cache` option.
          # Defaults to true.
          export: true

      # Enable rootless mode for the cluster-buildkit daemon, which runs the daemon with decreased privileges.
      # Please see [the buildkit docs](https://github.com/moby/buildkit/blob/master/docs/rootless.md) for caveats when
      # using this mode.
      rootless: false

      # Exposes the `nodeSelector` field on the PodSpec of the BuildKit deployment. This allows you to constrain the
      # BuildKit daemon to only run on particular nodes.
      #
      # [See here](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/) for the official Kubernetes
      # guide to assigning Pods to nodes.
      nodeSelector: {}

      # Specify tolerations to apply to cluster-buildkit daemon. Useful to control which nodes in a cluster can run
      # builds.
      tolerations:
        - # "Effect" indicates the taint effect to match. Empty means match all taint effects. When specified,
          # allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".
          effect:

          # "Key" is the taint key that the toleration applies to. Empty means match all taint keys.
          # If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.
          key:

          # "Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal".
          # Defaults to
          # "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a
          # particular category.
          operator: Equal

          # "TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute",
          # otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate
          # the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately)
          # by the system.
          tolerationSeconds:

          # "Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be
          # empty,
          # otherwise just a regular string.
          value:

      # Specify annotations to apply to both the Pod and Deployment resources associated with cluster-buildkit.
      # Annotations may have an effect on the behaviour of certain components, for example autoscalers.
      annotations:

    # Setting related to Jib image builds.
    jib:
      # In some cases you may need to push images built with Jib to the remote registry via Kubernetes cluster, e.g.
      # if you don't have connectivity or access from where Garden is being run. In that case, set this flag to true,
      # but do note that the build will take considerably take longer to complete! Only applies when using in-cluster
      # building.
      pushViaCluster: false

    # Configuration options for the `kaniko` build mode.
    kaniko:
      # Specify extra flags to use when building the container image with kaniko. Flags set on `container` modules
      # take precedence over these.
      extraFlags:

      # Change the kaniko image (repository/image:tag) to use when building in kaniko mode.
      image: 'gcr.io/kaniko-project/executor:v1.11.0-debug'

      # Choose the namespace where the Kaniko pods will be run. Set to `null` to use the project namespace.
      #
      # **IMPORTANT: The default namespace will change to the project namespace instead of the garden-system namespace
      # in an upcoming release!**
      namespace: garden-system

      # Exposes the `nodeSelector` field on the PodSpec of the Kaniko pods. This allows you to constrain the Kaniko
      # pods to only run on particular nodes. The same nodeSelector will be used for each util pod unless they are
      # specifically set under `util.nodeSelector`.
      #
      # [See here](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/) for the official Kubernetes
      # guide to assigning pods to nodes.
      nodeSelector:

      # Specify tolerations to apply to each Kaniko builder pod. Useful to control which nodes in a cluster can run
      # builds. The same tolerations will be used for each util pod unless they are specifically set under
      # `util.tolerations`
      tolerations:
        - # "Effect" indicates the taint effect to match. Empty means match all taint effects. When specified,
          # allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".
          effect:

          # "Key" is the taint key that the toleration applies to. Empty means match all taint keys.
          # If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.
          key:

          # "Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal".
          # Defaults to
          # "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a
          # particular category.
          operator: Equal

          # "TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute",
          # otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate
          # the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately)
          # by the system.
          tolerationSeconds:

          # "Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be
          # empty,
          # otherwise just a regular string.
          value:

      # Specify annotations to apply to each Kaniko builder pod. Annotations may have an effect on the behaviour of
      # certain components, for example autoscalers. The same annotations will be used for each util pod unless they
      # are specifically set under `util.annotations`
      annotations:

      util:
        # Specify tolerations to apply to each garden-util pod.
        tolerations:
          - # "Effect" indicates the taint effect to match. Empty means match all taint effects. When specified,
            # allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".
            effect:

            # "Key" is the taint key that the toleration applies to. Empty means match all taint keys.
            # If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.
            key:

            # "Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal".
            # Defaults to
            # "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a
            # particular category.
            operator: Equal

            # "TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute",
            # otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate
            # the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately)
            # by the system.
            tolerationSeconds:

            # "Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be
            # empty,
            # otherwise just a regular string.
            value:

        # Specify annotations to apply to each garden-util pod and deployments.
        annotations:

        # Specify the nodeSelector constraints for each garden-util pod.
        nodeSelector:

    # A default hostname to use when no hostname is explicitly configured for a service.
    defaultHostname:

    # Sets the deployment strategy for `container` services.
    #
    # The default is `"rolling"`, which performs rolling updates. There is also experimental support for blue/green
    # deployments (via the `"blue-green"` strategy).
    #
    # Note that this setting only applies to `container` services (and not, for example,  `kubernetes` or `helm`
    # services).
    deploymentStrategy: rolling

    # Configuration options for dev mode.
    devMode:
      # Specifies default settings for dev mode syncs (e.g. for `container`, `kubernetes` and `helm` services).
      #
      # These are overridden/extended by the settings of any individual dev mode sync specs for a given module or
      # service.
      #
      # Dev mode is enabled when running the `garden dev` command, and by setting the `--dev` flag on the `garden
      # deploy` command.
      #
      # See the [Code Synchronization guide](https://docs.garden.io/v/acorn-0.12/guides/code-synchronization-dev-mode)
      # for more information.
      defaults:
        # Specify a list of POSIX-style paths or glob patterns that should be excluded from the sync.
        #
        # Any exclusion patterns defined in individual dev mode sync specs will be applied in addition to these
        # patterns.
        #
        # `.git` directories and `.garden` directories are always ignored.
        exclude:

        # The default permission bits, specified as an octal, to set on files at the sync target. Defaults to 0600
        # (user read/write). See the [Mutagen
        # docs](https://mutagen.io/documentation/synchronization/permissions#permissions) for more information.
        fileMode:

        # The default permission bits, specified as an octal, to set on directories at the sync target. Defaults to
        # 0700 (user read/write). See the [Mutagen
        # docs](https://mutagen.io/documentation/synchronization/permissions#permissions) for more information.
        directoryMode:

        # Set the default owner of files and directories at the target. Specify either an integer ID or a string name.
        # See the [Mutagen docs](https://mutagen.io/documentation/synchronization/permissions#owners-and-groups) for
        # more information.
        owner:

        # Set the default group on files and directories at the target. Specify either an integer ID or a string name.
        # See the [Mutagen docs](https://mutagen.io/documentation/synchronization/permissions#owners-and-groups) for
        # more information.
        group:

    # Require SSL on all `container` module services. If set to true, an error is raised when no certificate is
    # available for a configured hostname on a `container` module.
    forceSsl: false

    # References to `docker-registry` secrets to use for authenticating with remote registries when pulling
    # images. This is necessary if you reference private images in your module configuration, and is required
    # when configuring a remote Kubernetes environment with buildMode=local.
    imagePullSecrets:
      - # The name of the Kubernetes secret.
        name:

        # The namespace where the secret is stored. If necessary, the secret may be copied to the appropriate
        # namespace before use.
        namespace: default

    # References to secrets you need to have copied into all namespaces deployed to. These secrets will be
    # ensured to exist in the namespace before deploying any service.
    copySecrets:
      - # The name of the Kubernetes secret.
        name:

        # The namespace where the secret is stored. If necessary, the secret may be copied to the appropriate
        # namespace before use.
        namespace: default

    # Resource requests and limits for the in-cluster builder, container registry and code sync service. (which are
    # automatically installed and used when `buildMode` is `cluster-docker` or `kaniko`).
    resources:
      # Resource requests and limits for the in-cluster builder. It's important to consider which build mode you're
      # using when configuring this.
      #
      # When `buildMode` is `kaniko`, this refers to _each Kaniko pod_, i.e. each individual build, so you'll want to
      # consider the requirements for your individual image builds, with your most expensive/heavy images in mind.
      #
      # When `buildMode` is `cluster-buildkit`, this applies to the BuildKit deployment created in _each project
      # namespace_. So think of this as the resource spec for each individual user or project namespace.
      #
      # When `buildMode` is `cluster-docker`, this applies to the single Docker Daemon that is installed and run
      # cluster-wide. This is shared across all users and builds in the cluster, so it should be resourced
      # accordingly, factoring in how many concurrent builds you expect and how heavy your builds tend to be. **Note
      # that the cluster-docker build mode has been deprecated!**
      builder:
        limits:
          # CPU limit in millicpu.
          cpu: 4000

          # Memory limit in megabytes.
          memory: 8192

          # Ephemeral storage limit in megabytes.
          ephemeralStorage:

        requests:
          # CPU request in millicpu.
          cpu: 100

          # Memory request in megabytes.
          memory: 512

          # Ephemeral storage request in megabytes.
          ephemeralStorage:

      # Resource requests and limits for the in-cluster image registry. Built images are pushed to this registry,
      # so that they are available to all the nodes in your cluster.
      #
      # This is shared across all users and builds, so it should be resourced accordingly, factoring
      # in how many concurrent builds you expect and how large your images tend to be.
      registry:
        limits:
          # CPU limit in millicpu.
          cpu: 2000

          # Memory limit in megabytes.
          memory: 4096

          # Ephemeral storage limit in megabytes.
          ephemeralStorage:

        requests:
          # CPU request in millicpu.
          cpu: 200

          # Memory request in megabytes.
          memory: 512

          # Ephemeral storage request in megabytes.
          ephemeralStorage:

      # Resource requests and limits for the util pod for in-cluster builders.
      # This pod is used to get, start, stop and inquire the status of the builds.
      #
      # This pod is created in each garden namespace.
      util:
        limits:
          # CPU limit in millicpu.
          cpu: 256

          # Memory limit in megabytes.
          memory: 512

          # Ephemeral storage limit in megabytes.
          ephemeralStorage:

        requests:
          # CPU request in millicpu.
          cpu: 256

          # Memory request in megabytes.
          memory: 512

          # Ephemeral storage request in megabytes.
          ephemeralStorage:

    # Storage parameters to set for the in-cluster builder, container registry and code sync persistent volumes
    # (which are automatically installed and used when `buildMode` is `cluster-docker` or `kaniko`).
    #
    # These are all shared cluster-wide across all users and builds, so they should be resourced accordingly,
    # factoring in how many concurrent builds you expect and how large your images and build contexts tend to be.
    storage:
      # Storage parameters for the in-cluster Docker registry volume. Built images are stored here, so that they
      # are available to all the nodes in your cluster.
      #
      # Only applies when `buildMode` is set to `cluster-docker` or `kaniko`, ignored otherwise.
      registry:
        # Volume size in megabytes.
        size: 20480

        # Storage class to use for the volume.
        storageClass: null

    # One or more certificates to use for ingress.
    tlsCertificates:
      - # A unique identifier for this certificate.
        name:

        # A list of hostnames that this certificate should be used for. If you don't specify these, they will be
        # automatically read from the certificate.
        hostnames:

        # A reference to the Kubernetes secret that contains the TLS certificate and key for the domain.
        secretRef:
          # The name of the Kubernetes secret.
          name:

          # The namespace where the secret is stored. If necessary, the secret may be copied to the appropriate
          # namespace before use.
          namespace: default

    # Exposes the `nodeSelector` field on the PodSpec of system services. This allows you to constrain the system
    # services to only run on particular nodes.
    #
    # [See here](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/) for the official Kubernetes guide
    # to assigning Pods to nodes.
    systemNodeSelector: {}

    # For setting tolerations on the registry-proxy when using in-cluster building.
    # The registry-proxy is a DaemonSet that proxies connections to the docker registry service on each node.
    #
    # Use this only if you're doing in-cluster building and the nodes in your cluster
    # have [taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/).
    registryProxyTolerations:
      - # "Effect" indicates the taint effect to match. Empty means match all taint effects. When specified,
        # allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".
        effect:

        # "Key" is the taint key that the toleration applies to. Empty means match all taint keys.
        # If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.
        key:

        # "Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal". Defaults
        # to
        # "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a
        # particular category.
        operator: Equal

        # "TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute",
        # otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate
        # the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately)
        # by the system.
        tolerationSeconds:

        # "Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be
        # empty,
        # otherwise just a regular string.
        value:

    # The name of the provider plugin to use.
    name: kubernetes

    # The kubectl context to use to connect to the Kubernetes cluster.
    context:

    # The registry where built containers should be pushed to, and then pulled to the cluster when deploying services.
    #
    # Important: If you specify this in combination with in-cluster building, you must make sure `imagePullSecrets`
    # includes authentication with the specified deployment registry, that has the appropriate write privileges
    # (usually full write access to the configured `deploymentRegistry.namespace`).
    deploymentRegistry:
      # The hostname (and optionally port, if not the default port) of the registry.
      hostname:

      # The port where the registry listens on, if not the default.
      port:

      # The registry namespace. Will be placed between hostname and image name, like so: <hostname>/<namespace>/<image
      # name>
      namespace: _

      # Set to true to allow insecure connections to the registry (without SSL).
      insecure: false

    # The ingress class to use on configured Ingresses (via the `kubernetes.io/ingress.class` annotation)
    # when deploying `container` services. Use this if you have multiple ingress controllers in your cluster.
    ingressClass:

    # The external HTTP port of the cluster's ingress controller.
    ingressHttpPort: 80

    # The external HTTPS port of the cluster's ingress controller.
    ingressHttpsPort: 443

    # Path to kubeconfig file to use instead of the system default.
    kubeconfig:

    # Set a specific path to a kubectl binary, instead of having Garden download it automatically as required.
    #
    # It may be useful in some scenarios to allow individual users to set this, e.g. with an environment variable. You
    # could configure that with something like `kubectlPath: ${local.env.GARDEN_KUBECTL_PATH}?`.
    #
    # **Warning**: Garden may make some assumptions with respect to the kubectl version, so it is suggested to only
    # use this when necessary.
    kubectlPath:

    # Specify which namespace to deploy services to, and optionally annotations/labels to apply to the namespace.
    #
    # You can specify a string as a shorthand for `name: <name>`. Defaults to `<project name>-<environment
    # namespace>`.
    #
    # Note that the framework may generate other namespaces as well with this name as a prefix. Also note that if the
    # namespace previously exists, Garden will attempt to add the specified labels and annotations. If the user does
    # not have permissions to do so, a warning is shown.
    namespace:
      # A valid Kubernetes namespace name. Must be a valid RFC1035/RFC1123 (DNS) label (may contain lowercase letters,
      # numbers and dashes, must start with a letter, and cannot end with a dash) and must not be longer than 63
      # characters.
      name:

      # Map of annotations to apply to the namespace when creating it.
      annotations:

      # Map of labels to apply to the namespace when creating it.
      labels:

    # Set this to `nginx` to install/enable the NGINX ingress controller.
    setupIngressController: false

Configuration Keys

providers[]

Type
Default
Required

array[object]

[]

No

providers[].dependencies[]

List other providers that should be resolved before this one.

Type
Default
Required

array[string]

[]

No

Example:

providers:
  - dependencies:
      - exec

providers[].environments[]

If specified, this provider will only be used in the listed environments. Note that an empty array effectively disables the provider. To use a provider in all environments, omit this field.

Type
Required

array[string]

No

Example:

providers:
  - environments:
      - dev
      - stage

providers[].buildMode

Choose the mechanism for building container images before deploying. By default your local Docker daemon is used, but you can set it to cluster-buildkit or kaniko to sync files to the cluster, and build container images there. This removes the need to run Docker locally, and allows you to share layer and image caches between multiple developers, as well as between your development and CI workflows.

Note: The cluster-docker mode has been deprecated and will be removed in a future release!

Type
Allowed Values
Default
Required

string

"local-docker", "cluster-docker", "kaniko", "cluster-buildkit"

"local-docker"

Yes

providers[].clusterBuildkit

Configuration options for the cluster-buildkit build mode.

Type
Default
Required

object

{}

No

providers[].clusterBuildkit.cache[]

Use the cache configuration to customize the default cluster-buildkit cache behaviour.

The default value is:

clusterBuildkit:
  cache:
    - type: registry
      mode: auto

For every build, this will

  • import cached layers from a docker image tag named _buildcache

  • when the build is finished, upload cache information to _buildcache

For registries that support it, mode: auto (the default) will enable the buildkit mode=max option.

See the following table for details on our detection mechanism:

Registry Name

Registry Domain

Assumed mode=max support

Google Cloud Artifact Registry

pkg.dev

Yes

Azure Container Registry

azurecr.io

Yes

GitHub Container Registry

ghcr.io

Yes

DockerHub

hub.docker.com

Yes

Garden In-Cluster Registry

Yes

Any other registry

No

In case you need to override the defaults for your registry, you can do it like so:

clusterBuildkit:
  cache:
    - type: registry
      mode: max

When you add multiple caches, we will make sure to pass the --import-cache options to buildkit in the same order as provided in the cache configuration. This is because buildkit will not actually use all imported caches for every build, but it will stick with the first cache that yields a cache hit for all the following layers.

An example for this is the following:

clusterBuildkit:
  cache:
    - type: registry
      tag: _buildcache-${slice(kebabCase(git.branch), "0", "30")}
    - type: registry
      tag: _buildcache-main
      export: false

Using this cache configuration, every build will first look for a cache specific to your feature branch. If it does not exist yet, it will import caches from the main branch builds (_buildcache-main). When the build is finished, it will only export caches to your feature branch, and avoid polluting the main branch caches. A configuration like that may improve your cache hit rate and thus save time.

If you need to disable caches completely you can achieve that with the following configuration:

clusterBuildkit:
  cache: []
Type
Default
Required

array[object]

[{"type":"registry","mode":"auto","tag":"_buildcache","export":true}]

No

providers[].clusterBuildkit.cache[].type

Use the Docker registry configured at deploymentRegistry to retrieve and store buildkit cache information.

Type
Allowed Values
Required

string

"registry"

Yes

providers[].clusterBuildkit.cache[].registry

The registry from which the cache should be imported from, or which it should be exported to.

If not specified, use the configured deploymentRegistry in your kubernetes provider config, or the internal in-cluster registry in case deploymentRegistry is not set.

Important: You must make sure imagePullSecrets includes authentication with the specified cache registry, that has the appropriate write privileges (usually full write access to the configured namespace).

Type
Required

object

No

providers[].clusterBuildkit.cache[].registry.hostname

The hostname (and optionally port, if not the default port) of the registry.

Type
Required

string

Yes

Example:

providers:
  - clusterBuildkit:
      ...
      cache:
        - registry:
            ...
            hostname: "gcr.io"

providers[].clusterBuildkit.cache[].registry.port

The port where the registry listens on, if not the default.

Type
Required

number

No

providers[].clusterBuildkit.cache[].registry.namespace

The registry namespace. Will be placed between hostname and image name, like so: //

Type
Default
Required

string

"_"

No

Example:

providers:
  - clusterBuildkit:
      ...
      cache:
        - registry:
            ...
            namespace: "my-project"

providers[].clusterBuildkit.cache[].registry.insecure

Set to true to allow insecure connections to the registry (without SSL).

Type
Default
Required

boolean

false

No

providers[].clusterBuildkit.cache[].mode

This is the buildkit cache mode to be used.

The value inline ensures that garden is using the buildkit option --export-cache inline. Cache information will be inlined and co-located with the Docker image itself.

The values min and max ensure that garden passes the mode=max or mode=min modifiers to the buildkit --export-cache option. Cache manifests will only be stored stored in the configured tag.

Type
Allowed Values
Default
Required

string

"auto", "min", "max", "inline"

"auto"

Yes

providers[].clusterBuildkit.cache[].tag

This is the Docker registry tag name buildkit should use for the registry build cache. Default is _buildcache

NOTE: tag can only be used together with the registry cache type

Type
Default
Required

string

"_buildcache"

No

providers[].clusterBuildkit.cache[].export

If this is false, only pass the --import-cache option to buildkit, and not the --export-cache option. Defaults to true.

Type
Default
Required

boolean

true

No

providers[].clusterBuildkit.rootless

Type
Default
Required

boolean

false

No

providers[].clusterBuildkit.nodeSelector

Exposes the nodeSelector field on the PodSpec of the BuildKit deployment. This allows you to constrain the BuildKit daemon to only run on particular nodes.

Type
Default
Required

object

{}

No

Example:

providers:
  - clusterBuildkit:
      ...
      nodeSelector:
          disktype: ssd

providers[].clusterBuildkit.tolerations[]

Specify tolerations to apply to cluster-buildkit daemon. Useful to control which nodes in a cluster can run builds.

Type
Default
Required

array[object]

[]

No

providers[].clusterBuildkit.tolerations[].effect

"Effect" indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".

Type
Required

string

No

providers[].clusterBuildkit.tolerations[].key

"Key" is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.

Type
Required

string

No

providers[].clusterBuildkit.tolerations[].operator

"Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal". Defaults to "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.

Type
Default
Required

string

"Equal"

No

providers[].clusterBuildkit.tolerations[].tolerationSeconds

"TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute", otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.

Type
Required

string

No

providers[].clusterBuildkit.tolerations[].value

"Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be empty, otherwise just a regular string.

Type
Required

string

No

providers[].clusterBuildkit.annotations

Specify annotations to apply to both the Pod and Deployment resources associated with cluster-buildkit. Annotations may have an effect on the behaviour of certain components, for example autoscalers.

Type
Required

object

No

Example:

providers:
  - clusterBuildkit:
      ...
      annotations:
          cluster-autoscaler.kubernetes.io/safe-to-evict: 'false'

providers[].clusterDocker

Deprecated: This field will be removed in a future release.

Configuration options for the cluster-docker build mode.

Type
Default
Required

object

{}

No

providers[].clusterDocker.enableBuildKit

Deprecated: This field will be removed in a future release.

Type
Default
Required

boolean

false

No

providers[].jib

Setting related to Jib image builds.

Type
Required

object

No

providers[].jib.pushViaCluster

In some cases you may need to push images built with Jib to the remote registry via Kubernetes cluster, e.g. if you don't have connectivity or access from where Garden is being run. In that case, set this flag to true, but do note that the build will take considerably take longer to complete! Only applies when using in-cluster building.

Type
Default
Required

boolean

false

No

providers[].kaniko

Configuration options for the kaniko build mode.

Type
Required

object

No

providers[].kaniko.extraFlags[]

Specify extra flags to use when building the container image with kaniko. Flags set on container modules take precedence over these.

Type
Required

array[string]

No

providers[].kaniko.image

Change the kaniko image (repository/image:tag) to use when building in kaniko mode.

Type
Default
Required

string

"gcr.io/kaniko-project/executor:v1.11.0-debug"

No

providers[].kaniko.namespace

Choose the namespace where the Kaniko pods will be run. Set to null to use the project namespace.

IMPORTANT: The default namespace will change to the project namespace instead of the garden-system namespace in an upcoming release!

Type
Default
Required

string

"garden-system"

No

providers[].kaniko.nodeSelector

Exposes the nodeSelector field on the PodSpec of the Kaniko pods. This allows you to constrain the Kaniko pods to only run on particular nodes. The same nodeSelector will be used for each util pod unless they are specifically set under util.nodeSelector.

Type
Required

object

No

providers[].kaniko.tolerations[]

Specify tolerations to apply to each Kaniko builder pod. Useful to control which nodes in a cluster can run builds. The same tolerations will be used for each util pod unless they are specifically set under util.tolerations

Type
Default
Required

array[object]

[]

No

providers[].kaniko.tolerations[].effect

"Effect" indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".

Type
Required

string

No

providers[].kaniko.tolerations[].key

"Key" is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.

Type
Required

string

No

providers[].kaniko.tolerations[].operator

"Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal". Defaults to "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.

Type
Default
Required

string

"Equal"

No

providers[].kaniko.tolerations[].tolerationSeconds

"TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute", otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.

Type
Required

string

No

providers[].kaniko.tolerations[].value

"Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be empty, otherwise just a regular string.

Type
Required

string

No

providers[].kaniko.annotations

Specify annotations to apply to each Kaniko builder pod. Annotations may have an effect on the behaviour of certain components, for example autoscalers. The same annotations will be used for each util pod unless they are specifically set under util.annotations

Type
Required

object

No

Example:

providers:
  - kaniko:
      ...
      annotations:
          cluster-autoscaler.kubernetes.io/safe-to-evict: 'false'

providers[].kaniko.util

Type
Required

object

No

providers[].kaniko.util.tolerations[]

Specify tolerations to apply to each garden-util pod.

Type
Default
Required

array[object]

[]

No

providers[].kaniko.util.tolerations[].effect

"Effect" indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".

Type
Required

string

No

providers[].kaniko.util.tolerations[].key

"Key" is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.

Type
Required

string

No

providers[].kaniko.util.tolerations[].operator

"Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal". Defaults to "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.

Type
Default
Required

string

"Equal"

No

providers[].kaniko.util.tolerations[].tolerationSeconds

"TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute", otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.

Type
Required

string

No

providers[].kaniko.util.tolerations[].value

"Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be empty, otherwise just a regular string.

Type
Required

string

No

providers[].kaniko.util.annotations

Specify annotations to apply to each garden-util pod and deployments.

Type
Required

object

No

Example:

providers:
  - kaniko:
      ...
      util:
        ...
        annotations:
            cluster-autoscaler.kubernetes.io/safe-to-evict: 'false'

providers[].kaniko.util.nodeSelector

Specify the nodeSelector constraints for each garden-util pod.

Type
Required

object

No

providers[].defaultHostname

A default hostname to use when no hostname is explicitly configured for a service.

Type
Required

string

No

Example:

providers:
  - defaultHostname: "api.mydomain.com"

providers[].deploymentStrategy

Experimental: this is an experimental feature and the API might change in the future.

Sets the deployment strategy for container services.

The default is "rolling", which performs rolling updates. There is also experimental support for blue/green deployments (via the "blue-green" strategy).

Note that this setting only applies to container services (and not, for example, kubernetes or helm services).

Type
Default
Required

string

"rolling"

No

providers[].devMode

Configuration options for dev mode.

Type
Required

object

No

providers[].devMode.defaults

Specifies default settings for dev mode syncs (e.g. for container, kubernetes and helm services).

These are overridden/extended by the settings of any individual dev mode sync specs for a given module or service.

Dev mode is enabled when running the garden dev command, and by setting the --dev flag on the garden deploy command.

Type
Required

object

No

providers[].devMode.defaults.exclude[]

Specify a list of POSIX-style paths or glob patterns that should be excluded from the sync.

Any exclusion patterns defined in individual dev mode sync specs will be applied in addition to these patterns.

.git directories and .garden directories are always ignored.

Type
Required

array[posixPath]

No

Example:

providers:
  - devMode:
      ...
      defaults:
        ...
        exclude:
          - dist/**/*
          - '*.log'

providers[].devMode.defaults.fileMode

Type
Required

number

No

providers[].devMode.defaults.directoryMode

Type
Required

number

No

providers[].devMode.defaults.owner

Type
Required

number | string

No

providers[].devMode.defaults.group

Type
Required

number | string

No

providers[].forceSsl

Require SSL on all container module services. If set to true, an error is raised when no certificate is available for a configured hostname on a container module.

Type
Default
Required

boolean

false

No

providers[].imagePullSecrets[]

References to docker-registry secrets to use for authenticating with remote registries when pulling images. This is necessary if you reference private images in your module configuration, and is required when configuring a remote Kubernetes environment with buildMode=local.

Type
Default
Required

array[object]

[]

No

providers[].imagePullSecrets[].name

The name of the Kubernetes secret.

Type
Required

string

Yes

Example:

providers:
  - imagePullSecrets:
      - name: "my-secret"

providers[].imagePullSecrets[].namespace

The namespace where the secret is stored. If necessary, the secret may be copied to the appropriate namespace before use.

Type
Default
Required

string

"default"

No

providers[].copySecrets[]

References to secrets you need to have copied into all namespaces deployed to. These secrets will be ensured to exist in the namespace before deploying any service.

Type
Default
Required

array[object]

[]

No

providers[].copySecrets[].name

The name of the Kubernetes secret.

Type
Required

string

Yes

Example:

providers:
  - copySecrets:
      - name: "my-secret"

providers[].copySecrets[].namespace

The namespace where the secret is stored. If necessary, the secret may be copied to the appropriate namespace before use.

Type
Default
Required

string

"default"

No

providers[].resources

Resource requests and limits for the in-cluster builder, container registry and code sync service. (which are automatically installed and used when buildMode is cluster-docker or kaniko).

Type
Default
Required

object

{"builder":{"limits":{"cpu":4000,"memory":8192},"requests":{"cpu":100,"memory":512}},"registry":{"limits":{"cpu":2000,"memory":4096},"requests":{"cpu":200,"memory":512}},"sync":{"limits":{"cpu":500,"memory":512},"requests":{"cpu":100,"memory":90}},"util":{"limits":{"cpu":256,"memory":512},"requests":{"cpu":256,"memory":512}}}

No

providers[].resources.builder

Resource requests and limits for the in-cluster builder. It's important to consider which build mode you're using when configuring this.

When buildMode is kaniko, this refers to each Kaniko pod, i.e. each individual build, so you'll want to consider the requirements for your individual image builds, with your most expensive/heavy images in mind.

When buildMode is cluster-buildkit, this applies to the BuildKit deployment created in each project namespace. So think of this as the resource spec for each individual user or project namespace.

When buildMode is cluster-docker, this applies to the single Docker Daemon that is installed and run cluster-wide. This is shared across all users and builds in the cluster, so it should be resourced accordingly, factoring in how many concurrent builds you expect and how heavy your builds tend to be. Note that the cluster-docker build mode has been deprecated!

Type
Default
Required

object

{"limits":{"cpu":4000,"memory":8192},"requests":{"cpu":100,"memory":512}}

No

providers[].resources.builder.limits

Type
Default
Required

object

{"cpu":4000,"memory":8192}

No

providers[].resources.builder.limits.cpu

CPU limit in millicpu.

Type
Default
Required

number

4000

No

Example:

providers:
  - resources:
      ...
      builder:
        ...
        limits:
          ...
          cpu: 4000

providers[].resources.builder.limits.memory

Memory limit in megabytes.

Type
Default
Required

number

8192

No

Example:

providers:
  - resources:
      ...
      builder:
        ...
        limits:
          ...
          memory: 8192

providers[].resources.builder.limits.ephemeralStorage

Ephemeral storage limit in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      builder:
        ...
        limits:
          ...
          ephemeralStorage: 8192

providers[].resources.builder.requests

Type
Default
Required

object

{"cpu":100,"memory":512}

No

providers[].resources.builder.requests.cpu

CPU request in millicpu.

Type
Default
Required

number

100

No

Example:

providers:
  - resources:
      ...
      builder:
        ...
        requests:
          ...
          cpu: 100

providers[].resources.builder.requests.memory

Memory request in megabytes.

Type
Default
Required

number

512

No

Example:

providers:
  - resources:
      ...
      builder:
        ...
        requests:
          ...
          memory: 512

providers[].resources.builder.requests.ephemeralStorage

Ephemeral storage request in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      builder:
        ...
        requests:
          ...
          ephemeralStorage: 8192

providers[].resources.registry

Resource requests and limits for the in-cluster image registry. Built images are pushed to this registry, so that they are available to all the nodes in your cluster.

This is shared across all users and builds, so it should be resourced accordingly, factoring in how many concurrent builds you expect and how large your images tend to be.

Type
Default
Required

object

{"limits":{"cpu":2000,"memory":4096},"requests":{"cpu":200,"memory":512}}

No

providers[].resources.registry.limits

Type
Default
Required

object

{"cpu":2000,"memory":4096}

No

providers[].resources.registry.limits.cpu

CPU limit in millicpu.

Type
Default
Required

number

2000

No

Example:

providers:
  - resources:
      ...
      registry:
        ...
        limits:
          ...
          cpu: 2000

providers[].resources.registry.limits.memory

Memory limit in megabytes.

Type
Default
Required

number

4096

No

Example:

providers:
  - resources:
      ...
      registry:
        ...
        limits:
          ...
          memory: 4096

providers[].resources.registry.limits.ephemeralStorage

Ephemeral storage limit in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      registry:
        ...
        limits:
          ...
          ephemeralStorage: 8192

providers[].resources.registry.requests

Type
Default
Required

object

{"cpu":200,"memory":512}

No

providers[].resources.registry.requests.cpu

CPU request in millicpu.

Type
Default
Required

number

200

No

Example:

providers:
  - resources:
      ...
      registry:
        ...
        requests:
          ...
          cpu: 200

providers[].resources.registry.requests.memory

Memory request in megabytes.

Type
Default
Required

number

512

No

Example:

providers:
  - resources:
      ...
      registry:
        ...
        requests:
          ...
          memory: 512

providers[].resources.registry.requests.ephemeralStorage

Ephemeral storage request in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      registry:
        ...
        requests:
          ...
          ephemeralStorage: 8192

providers[].resources.util

Resource requests and limits for the util pod for in-cluster builders. This pod is used to get, start, stop and inquire the status of the builds.

This pod is created in each garden namespace.

Type
Default
Required

object

{"limits":{"cpu":256,"memory":512},"requests":{"cpu":256,"memory":512}}

No

providers[].resources.util.limits

Type
Default
Required

object

{"cpu":256,"memory":512}

No

providers[].resources.util.limits.cpu

CPU limit in millicpu.

Type
Default
Required

number

256

No

Example:

providers:
  - resources:
      ...
      util:
        ...
        limits:
          ...
          cpu: 256

providers[].resources.util.limits.memory

Memory limit in megabytes.

Type
Default
Required

number

512

No

Example:

providers:
  - resources:
      ...
      util:
        ...
        limits:
          ...
          memory: 512

providers[].resources.util.limits.ephemeralStorage

Ephemeral storage limit in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      util:
        ...
        limits:
          ...
          ephemeralStorage: 8192

providers[].resources.util.requests

Type
Default
Required

object

{"cpu":256,"memory":512}

No

providers[].resources.util.requests.cpu

CPU request in millicpu.

Type
Default
Required

number

256

No

Example:

providers:
  - resources:
      ...
      util:
        ...
        requests:
          ...
          cpu: 256

providers[].resources.util.requests.memory

Memory request in megabytes.

Type
Default
Required

number

512

No

Example:

providers:
  - resources:
      ...
      util:
        ...
        requests:
          ...
          memory: 512

providers[].resources.util.requests.ephemeralStorage

Ephemeral storage request in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      util:
        ...
        requests:
          ...
          ephemeralStorage: 8192

providers[].resources.sync

Deprecated: This field will be removed in a future release.

Resource requests and limits for the code sync service, which we use to sync build contexts to the cluster ahead of building images. This generally is not resource intensive, but you might want to adjust the defaults if you have many concurrent users.

Type
Default
Required

object

{"limits":{"cpu":500,"memory":512},"requests":{"cpu":100,"memory":90}}

No

providers[].resources.sync.limits

Deprecated: This field will be removed in a future release.

Type
Default
Required

object

{"cpu":500,"memory":512}

No

providers[].resources.sync.limits.cpu

Deprecated: This field will be removed in a future release.

CPU limit in millicpu.

Type
Default
Required

number

500

No

Example:

providers:
  - resources:
      ...
      sync:
        ...
        limits:
          ...
          cpu: 500

providers[].resources.sync.limits.memory

Deprecated: This field will be removed in a future release.

Memory limit in megabytes.

Type
Default
Required

number

512

No

Example:

providers:
  - resources:
      ...
      sync:
        ...
        limits:
          ...
          memory: 512

providers[].resources.sync.limits.ephemeralStorage

Deprecated: This field will be removed in a future release.

Ephemeral storage limit in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      sync:
        ...
        limits:
          ...
          ephemeralStorage: 8192

providers[].resources.sync.requests

Deprecated: This field will be removed in a future release.

Type
Default
Required

object

{"cpu":100,"memory":90}

No

providers[].resources.sync.requests.cpu

Deprecated: This field will be removed in a future release.

CPU request in millicpu.

Type
Default
Required

number

100

No

Example:

providers:
  - resources:
      ...
      sync:
        ...
        requests:
          ...
          cpu: 100

providers[].resources.sync.requests.memory

Deprecated: This field will be removed in a future release.

Memory request in megabytes.

Type
Default
Required

number

90

No

Example:

providers:
  - resources:
      ...
      sync:
        ...
        requests:
          ...
          memory: 90

providers[].resources.sync.requests.ephemeralStorage

Deprecated: This field will be removed in a future release.

Ephemeral storage request in megabytes.

Type
Required

number

No

Example:

providers:
  - resources:
      ...
      sync:
        ...
        requests:
          ...
          ephemeralStorage: 8192

providers[].storage

Storage parameters to set for the in-cluster builder, container registry and code sync persistent volumes (which are automatically installed and used when buildMode is cluster-docker or kaniko).

These are all shared cluster-wide across all users and builds, so they should be resourced accordingly, factoring in how many concurrent builds you expect and how large your images and build contexts tend to be.

Type
Default
Required

object

{"builder":{"size":20480,"storageClass":null},"nfs":{"storageClass":null},"registry":{"size":20480,"storageClass":null},"sync":{"size":10240,"storageClass":null}}

No

providers[].storage.builder

Deprecated: This field will be removed in a future release.

Storage parameters for the data volume for the in-cluster Docker Daemon.

Only applies when buildMode is set to cluster-docker, ignored otherwise.

Type
Default
Required

object

{"size":20480,"storageClass":null}

No

providers[].storage.builder.size

Deprecated: This field will be removed in a future release.

Volume size in megabytes.

Type
Default
Required

number

20480

No

providers[].storage.builder.storageClass

Deprecated: This field will be removed in a future release.

Storage class to use for the volume.

Type
Default
Required

string

null

No

providers[].storage.nfs

Deprecated: This field will be removed in a future release.

Storage parameters for the NFS provisioner, which we automatically create for the sync volume, unless you specify a storageClass for the sync volume. See the below sync parameter for more.

Only applies when buildMode is set to cluster-docker or kaniko, ignored otherwise.

Type
Default
Required

object

{"storageClass":null}

No

providers[].storage.nfs.storageClass

Deprecated: This field will be removed in a future release.

Storage class to use as backing storage for NFS .

Type
Default
Required

string

null

No

providers[].storage.registry

Storage parameters for the in-cluster Docker registry volume. Built images are stored here, so that they are available to all the nodes in your cluster.

Only applies when buildMode is set to cluster-docker or kaniko, ignored otherwise.

Type
Default
Required

object

{"size":20480,"storageClass":null}

No

providers[].storage.registry.size

Volume size in megabytes.

Type
Default
Required

number

20480

No

providers[].storage.registry.storageClass

Storage class to use for the volume.

Type
Default
Required

string

null

No

providers[].storage.sync

Deprecated: This field will be removed in a future release.

Storage parameters for the code sync volume, which build contexts are synced to ahead of running in-cluster builds.

Important: The storage class configured here has to support ReadWriteMany access. If you don't specify a storage class, Garden creates an NFS provisioner and provisions an NFS volume for the sync data volume.

Only applies when buildMode is set to cluster-docker, ignored otherwise.

Type
Default
Required

object

{"size":10240,"storageClass":null}

No

providers[].storage.sync.size

Deprecated: This field will be removed in a future release.

Volume size in megabytes.

Type
Default
Required

number

10240

No

providers[].storage.sync.storageClass

Deprecated: This field will be removed in a future release.

Storage class to use for the volume.

Type
Default
Required

string

null

No

providers[].tlsCertificates[]

One or more certificates to use for ingress.

Type
Default
Required

array[object]

[]

No

providers[].tlsCertificates[].name

A unique identifier for this certificate.

Type
Required

string

Yes

Example:

providers:
  - tlsCertificates:
      - name: "www"

providers[].tlsCertificates[].hostnames[]

A list of hostnames that this certificate should be used for. If you don't specify these, they will be automatically read from the certificate.

Type
Required

array[hostname]

No

Example:

providers:
  - tlsCertificates:
      - hostnames:
          - www.mydomain.com

providers[].tlsCertificates[].secretRef

A reference to the Kubernetes secret that contains the TLS certificate and key for the domain.

Type
Required

object

No

Example:

providers:
  - tlsCertificates:
      - secretRef:
            name: my-tls-secret
            namespace: default

providers[].tlsCertificates[].secretRef.name

The name of the Kubernetes secret.

Type
Required

string

Yes

Example:

providers:
  - tlsCertificates:
      - secretRef:
            name: my-tls-secret
            namespace: default
          ...
          name: "my-secret"

providers[].tlsCertificates[].secretRef.namespace

The namespace where the secret is stored. If necessary, the secret may be copied to the appropriate namespace before use.

Type
Default
Required

string

"default"

No

providers[].tlsCertificates[].managedBy

Deprecated: This field will be removed in a future release.

Type
Required

string

No

Example:

providers:
  - tlsCertificates:
      - managedBy: "cert-manager"

providers[].certManager

Deprecated: This field will be removed in a future release.

Type
Required

object

No

providers[].certManager.install

Deprecated: This field will be removed in a future release.

Type
Default
Required

boolean

false

No

providers[].certManager.email

Deprecated: This field will be removed in a future release.

The email to use when requesting Let's Encrypt certificates.

Type
Required

string

Yes

Example:

providers:
  - certManager:
      ...
      email: "yourname@example.com"

providers[].certManager.issuer

Deprecated: This field will be removed in a future release.

The type of issuer for the certificate (only ACME is supported for now).

Type
Default
Required

string

"acme"

No

Example:

providers:
  - certManager:
      ...
      issuer: "acme"

providers[].certManager.acmeServer

Deprecated: This field will be removed in a future release.

Specify which ACME server to request certificates from. Currently Let's Encrypt staging and prod servers are supported.

Type
Default
Required

string

"letsencrypt-staging"

No

Example:

providers:
  - certManager:
      ...
      acmeServer: "letsencrypt-staging"

providers[].certManager.acmeChallengeType

Deprecated: This field will be removed in a future release.

The type of ACME challenge used to validate hostnames and generate the certificates (only HTTP-01 is supported for now).

Type
Default
Required

string

"HTTP-01"

No

Example:

providers:
  - certManager:
      ...
      acmeChallengeType: "HTTP-01"

providers[].systemNodeSelector

Exposes the nodeSelector field on the PodSpec of system services. This allows you to constrain the system services to only run on particular nodes.

Type
Default
Required

object

{}

No

Example:

providers:
  - systemNodeSelector:
        disktype: ssd

providers[].registryProxyTolerations[]

For setting tolerations on the registry-proxy when using in-cluster building. The registry-proxy is a DaemonSet that proxies connections to the docker registry service on each node.

Type
Default
Required

array[object]

[]

No

providers[].registryProxyTolerations[].effect

"Effect" indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are "NoSchedule", "PreferNoSchedule" and "NoExecute".

Type
Required

string

No

providers[].registryProxyTolerations[].key

"Key" is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be "Exists"; this combination means to match all values and all keys.

Type
Required

string

No

providers[].registryProxyTolerations[].operator

"Operator" represents a key's relationship to the value. Valid operators are "Exists" and "Equal". Defaults to "Equal". "Exists" is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.

Type
Default
Required

string

"Equal"

No

providers[].registryProxyTolerations[].tolerationSeconds

"TolerationSeconds" represents the period of time the toleration (which must be of effect "NoExecute", otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.

Type
Required

string

No

providers[].registryProxyTolerations[].value

"Value" is the taint value the toleration matches to. If the operator is "Exists", the value should be empty, otherwise just a regular string.

Type
Required

string

No

providers[].name

The name of the provider plugin to use.

Type
Default
Required

string

"kubernetes"

Yes

Example:

providers:
  - name: "kubernetes"

providers[].context

The kubectl context to use to connect to the Kubernetes cluster.

Type
Required

string

Yes

Example:

providers:
  - context: "my-dev-context"

providers[].deploymentRegistry

The registry where built containers should be pushed to, and then pulled to the cluster when deploying services.

Important: If you specify this in combination with in-cluster building, you must make sure imagePullSecrets includes authentication with the specified deployment registry, that has the appropriate write privileges (usually full write access to the configured deploymentRegistry.namespace).

Type
Required

object

No

providers[].deploymentRegistry.hostname

The hostname (and optionally port, if not the default port) of the registry.

Type
Required

string

Yes

Example:

providers:
  - deploymentRegistry:
      ...
      hostname: "gcr.io"

providers[].deploymentRegistry.port

The port where the registry listens on, if not the default.

Type
Required

number

No

providers[].deploymentRegistry.namespace

The registry namespace. Will be placed between hostname and image name, like so: //

Type
Default
Required

string

"_"

No

Example:

providers:
  - deploymentRegistry:
      ...
      namespace: "my-project"

providers[].deploymentRegistry.insecure

Set to true to allow insecure connections to the registry (without SSL).

Type
Default
Required

boolean

false

No

providers[].ingressClass

The ingress class to use on configured Ingresses (via the kubernetes.io/ingress.class annotation) when deploying container services. Use this if you have multiple ingress controllers in your cluster.

Type
Required

string

No

providers[].ingressHttpPort

The external HTTP port of the cluster's ingress controller.

Type
Default
Required

number

80

No

providers[].ingressHttpsPort

The external HTTPS port of the cluster's ingress controller.

Type
Default
Required

number

443

No

providers[].kubeconfig

Path to kubeconfig file to use instead of the system default.

Type
Required

string

No

providers[].kubectlPath

Set a specific path to a kubectl binary, instead of having Garden download it automatically as required.

It may be useful in some scenarios to allow individual users to set this, e.g. with an environment variable. You could configure that with something like kubectlPath: ${local.env.GARDEN_KUBECTL_PATH}?.

Warning: Garden may make some assumptions with respect to the kubectl version, so it is suggested to only use this when necessary.

Type
Required

string

No

providers[].namespace

Specify which namespace to deploy services to, and optionally annotations/labels to apply to the namespace.

You can specify a string as a shorthand for name: <name>. Defaults to <project name>-<environment namespace>.

Note that the framework may generate other namespaces as well with this name as a prefix. Also note that if the namespace previously exists, Garden will attempt to add the specified labels and annotations. If the user does not have permissions to do so, a warning is shown.

Type
Required

object | string

No

providers[].namespace.name

A valid Kubernetes namespace name. Must be a valid RFC1035/RFC1123 (DNS) label (may contain lowercase letters, numbers and dashes, must start with a letter, and cannot end with a dash) and must not be longer than 63 characters.

Type
Required

string

No

providers[].namespace.annotations

Map of annotations to apply to the namespace when creating it.

Type
Required

object

No

Example:

providers:
  - namespace: ''
      ...
      annotations:
          cluster-autoscaler.kubernetes.io/safe-to-evict: 'false'

providers[].namespace.labels

Map of labels to apply to the namespace when creating it.

Type
Required

object

No

providers[].setupIngressController

Set this to nginx to install/enable the NGINX ingress controller.

Type
Default
Required

string

false

No

Outputs

The following keys are available via the ${providers.<provider-name>} template string key for kubernetes providers.

${providers.<provider-name>.outputs.app-namespace}

The primary namespace used for resource deployments.

Type

string

${providers.<provider-name>.outputs.default-hostname}

The default hostname configured on the provider.

Type

string

${providers.<provider-name>.outputs.metadata-namespace}

Deprecated: This field will be removed in a future release.

The namespace used for Garden metadata (currently always the same as app-namespace).

Type

string

> dependencies

> environments

> buildMode

For more details on all the different options and what makes sense to use for your setup, please check out the .

> clusterBuildkit

> > cache

> > > type

See also the

> > > registry

> > > > hostname

> > > > port

> > > > namespace

> > > > insecure

> > > mode

auto is the same as max for some registries that are known to support it. Garden will fall back to inline for all other registries. See the for a description of the detection mechanism.

See also the

> > > tag

> > > export

> > rootless

Enable rootless mode for the cluster-buildkit daemon, which runs the daemon with decreased privileges. Please see for caveats when using this mode.

> > nodeSelector

for the official Kubernetes guide to assigning Pods to nodes.

> > tolerations

> > > effect

> > > key

> > > operator

> > > tolerationSeconds

> > > value

> > annotations

> clusterDocker

> > enableBuildKit

Enable support. This should in most cases work well and be more performant, but we're opting to keep it optional until it's enabled by default in Docker.

> jib

> > pushViaCluster

> kaniko

> > extraFlags

> > image

> > namespace

> > nodeSelector

for the official Kubernetes guide to assigning pods to nodes.

> > tolerations

> > > effect

> > > key

> > > operator

> > > tolerationSeconds

> > > value

> > annotations

> > util

> > > tolerations

> > > > effect

> > > > key

> > > > operator

> > > > tolerationSeconds

> > > > value

> > > annotations

> > > nodeSelector

> defaultHostname

> deploymentStrategy

> devMode

> > defaults

See the for more information.

> > > exclude

> > > fileMode

The default permission bits, specified as an octal, to set on files at the sync target. Defaults to 0600 (user read/write). See the for more information.

> > > directoryMode

The default permission bits, specified as an octal, to set on directories at the sync target. Defaults to 0700 (user read/write). See the for more information.

> > > owner

Set the default owner of files and directories at the target. Specify either an integer ID or a string name. See the for more information.

> > > group

Set the default group on files and directories at the target. Specify either an integer ID or a string name. See the for more information.

> forceSsl

> imagePullSecrets

> > name

> > namespace

> copySecrets

> > name

> > namespace

> resources

> > builder

> > > limits

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > > requests

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > registry

> > > limits

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > > requests

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > util

> > > limits

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > > requests

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > sync

> > > limits

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> > > requests

> > > > cpu

> > > > memory

> > > > ephemeralStorage

> storage

> > builder

> > > size

> > > storageClass

> > nfs

> > > storageClass

> > registry

> > > size

> > > storageClass

> > sync

> > > size

> > > storageClass

> tlsCertificates

> > name

> > hostnames

> > secretRef

> > > name

> > > namespace

> > managedBy

Set to cert-manager to configure to manage this certificate. See our for details.

> certManager

cert-manager configuration, for creating and managing TLS certificates. See the for details.

> > install

Automatically install cert-manager on initialization. See the for details.

> > email

> > issuer

> > acmeServer

> > acmeChallengeType

> systemNodeSelector

for the official Kubernetes guide to assigning Pods to nodes.

> registryProxyTolerations

Use this only if you're doing in-cluster building and the nodes in your cluster have .

> > effect

> > key

> > operator

> > tolerationSeconds

> > value

> name

> context

> deploymentRegistry

> > hostname

> > port

> > namespace

> > insecure

> ingressClass

> ingressHttpPort

> ingressHttpsPort

> kubeconfig

> kubectlPath

> namespace

> > name

> > annotations

> > labels

> setupIngressController

🪷
in-cluster building guide
buildkit registry cache documentation
buildkit export cache documentation
the buildkit docs
See here
BuildKit
See here
Code Synchronization guide
Mutagen docs
Mutagen docs
Mutagen docs
Mutagen docs
cert-manager
cert-manager integration guide
cert-manager guide
cert-manager integration guide
See here
taints
container modules
helm
kubernetes
guides section
Remote Kubernetes guide
Quickstart guide
local-kubernetes provider
configuration guide
first section
second section
providers
providers
providers
providers
providers
clusterBuildkit
providers
clusterBuildkit
cache
providers
clusterBuildkit
cache
providers
clusterBuildkit
cache
registry
providers
clusterBuildkit
cache
registry
providers
clusterBuildkit
cache
registry
providers
clusterBuildkit
cache
registry
providers
clusterBuildkit
cache
clusterBuildkit cache option
providers
clusterBuildkit
cache
providers
clusterBuildkit
cache
providers
clusterBuildkit
providers
clusterBuildkit
providers
clusterBuildkit
providers
clusterBuildkit
tolerations
providers
clusterBuildkit
tolerations
providers
clusterBuildkit
tolerations
providers
clusterBuildkit
tolerations
providers
clusterBuildkit
tolerations
providers
clusterBuildkit
providers
providers
clusterDocker
providers
providers
jib
providers
providers
kaniko
providers
kaniko
providers
kaniko
providers
kaniko
providers
kaniko
providers
kaniko
tolerations
providers
kaniko
tolerations
providers
kaniko
tolerations
providers
kaniko
tolerations
providers
kaniko
tolerations
providers
kaniko
providers
kaniko
providers
kaniko
util
providers
kaniko
util
tolerations
providers
kaniko
util
tolerations
providers
kaniko
util
tolerations
providers
kaniko
util
tolerations
providers
kaniko
util
tolerations
providers
kaniko
util
providers
kaniko
util
providers
providers
providers
providers
devMode
providers
devMode
defaults
providers
devMode
defaults
providers
devMode
defaults
providers
devMode
defaults
providers
devMode
defaults
providers
providers
providers
imagePullSecrets
providers
imagePullSecrets
providers
providers
copySecrets
providers
copySecrets
providers
providers
resources
providers
resources
builder
providers
resources
builder
limits
providers
resources
builder
limits
providers
resources
builder
limits
providers
resources
builder
providers
resources
builder
requests
providers
resources
builder
requests
providers
resources
builder
requests
providers
resources
providers
resources
registry
providers
resources
registry
limits
providers
resources
registry
limits
providers
resources
registry
limits
providers
resources
registry
providers
resources
registry
requests
providers
resources
registry
requests
providers
resources
registry
requests
providers
resources
providers
resources
util
providers
resources
util
limits
providers
resources
util
limits
providers
resources
util
limits
providers
resources
util
providers
resources
util
requests
providers
resources
util
requests
providers
resources
util
requests
providers
resources
providers
resources
sync
providers
resources
sync
limits
providers
resources
sync
limits
providers
resources
sync
limits
providers
resources
sync
providers
resources
sync
requests
providers
resources
sync
requests
providers
resources
sync
requests
providers
providers
storage
providers
storage
builder
providers
storage
builder
providers
storage
providers
storage
nfs
providers
storage
providers
storage
registry
providers
storage
registry
providers
storage
providers
storage
sync
providers
storage
sync
providers
providers
tlsCertificates
providers
tlsCertificates
providers
tlsCertificates
providers
tlsCertificates
secretRef
providers
tlsCertificates
secretRef
providers
tlsCertificates
providers
providers
certManager
providers
certManager
providers
certManager
providers
certManager
providers
certManager
providers
providers
providers
registryProxyTolerations
providers
registryProxyTolerations
providers
registryProxyTolerations
providers
registryProxyTolerations
providers
registryProxyTolerations
providers
providers
providers
providers
deploymentRegistry
providers
deploymentRegistry
providers
deploymentRegistry
providers
deploymentRegistry
providers
providers
providers
providers
providers
providers
providers
namespace
providers
namespace
providers
namespace
providers