container
Description
Specify a container image to build or pull from a remote registry. You may also optionally specify services to deploy, tasks or tests to run inside the container.
Note that the runtime services have somewhat limited features in this module type. For example, you cannot specify replicas for redundancy, and various platform-specific options are not included. For those, look at other module types like helm or kubernetes.
Below is the full schema reference. For an introduction to configuring Garden modules, please look at our Configuration guide.
The first section contains the complete YAML schema, and the second section describes each schema key.
container
modules also export values that are available in template strings. See the Outputs section below for details.
Complete YAML Schema
The values in the schema below are the default values.
Configuration Keys
apiVersion
apiVersion
The schema version of this config (currently not used).
Type | Allowed Values | Default | Required |
---|---|---|---|
| "garden.io/v0" |
| Yes |
kind
kind
Type | Allowed Values | Default | Required |
---|---|---|---|
| "Module" |
| Yes |
type
type
The type of this module.
Type | Required |
---|---|
| Yes |
Example:
name
name
The name of this module.
Type | Required |
---|---|
| Yes |
Example:
build
build
Specify how to build the module. Note that plugins may define additional keys on this object.
Type | Default | Required |
---|---|---|
|
| No |
build.dependencies[]
build.dependencies[]
build > dependencies
A list of modules that must be built before this module is built.
Type | Default | Required |
---|---|---|
|
| No |
Example:
build.dependencies[].name
build.dependencies[].name
build > dependencies > name
Module name to build ahead of this module.
Type | Required |
---|---|
| Yes |
build.dependencies[].copy[]
build.dependencies[].copy[]
build > dependencies > copy
Specify one or more files or directories to copy from the built dependency to this module.
Type | Default | Required |
---|---|---|
|
| No |
build.dependencies[].copy[].source
build.dependencies[].copy[].source
build > dependencies > copy > source
POSIX-style path or filename of the directory or file(s) to copy to the target.
Type | Required |
---|---|
| Yes |
build.dependencies[].copy[].target
build.dependencies[].copy[].target
build > dependencies > copy > target
POSIX-style path or filename to copy the directory or file(s), relative to the build directory. Defaults to the same as source path.
Type | Required |
---|---|
| No |
build.timeout
build.timeout
build > timeout
Maximum time in seconds to wait for build to finish.
Type | Default | Required |
---|---|---|
|
| No |
build.targetImage
build.targetImage
build > targetImage
For multi-stage Dockerfiles, specify which image to build (see https://docs.docker.com/engine/reference/commandline/build/#specifying-target-build-stage---target for details).
Type | Required |
---|---|
| No |
description
description
A description of the module.
Type | Required |
---|---|
| No |
disabled
disabled
Set this to true
to disable the module. You can use this with conditional template strings to disable modules based on, for example, the current environment or other variables (e.g. disabled: ${environment.name == "prod"}
). This can be handy when you only need certain modules for specific environments, e.g. only for development.
Disabling a module means that any services, tasks and tests contained in it will not be deployed or run. It also means that the module is not built unless it is declared as a build dependency by another enabled module (in which case building this module is necessary for the dependant to be built).
If you disable the module, and its services, tasks or tests are referenced as runtime dependencies, Garden will automatically ignore those dependency declarations. Note however that template strings referencing the module's service or task outputs (i.e. runtime outputs) will fail to resolve when the module is disabled, so you need to make sure to provide alternate values for those if you're using them, using conditional expressions.
Type | Default | Required |
---|---|---|
|
| No |
include[]
include[]
Specify a list of POSIX-style paths or globs that should be regarded as the source files for this module. Files that do not match these paths or globs are excluded when computing the version of the module, when responding to filesystem watch events, and when staging builds.
Note that you can also exclude files using the exclude
field or by placing .gardenignore
files in your source tree, which use the same format as .gitignore
files. See the Configuration Files guide for details.
Also note that specifying an empty list here means no sources should be included.
If neither include
nor exclude
is set, and the module has a Dockerfile, Garden will parse the Dockerfile and automatically set include
to match the files and folders added to the Docker image (via the COPY
and ADD
directives in the Dockerfile).
If neither include
nor exclude
is set, and the module specifies a remote image, Garden automatically sets include
to []
.
Type | Required |
---|---|
| No |
Example:
exclude[]
exclude[]
Specify a list of POSIX-style paths or glob patterns that should be excluded from the module. Files that match these paths or globs are excluded when computing the version of the module, when responding to filesystem watch events, and when staging builds.
Note that you can also explicitly include files using the include
field. If you also specify the include
field, the files/patterns specified here are filtered from the files matched by include
. See the Configuration Files guide for details.
Unlike the modules.exclude
field in the project config, the filters here have no effect on which files and directories are watched for changes. Use the project modules.exclude
field to affect those, if you have large directories that should not be watched for changes.
Type | Required |
---|---|
| No |
Example:
repositoryUrl
repositoryUrl
A remote repository URL. Currently only supports git servers. Must contain a hash suffix pointing to a specific branch or tag, with the format: #<branch|tag>
Garden will import the repository source code into this module, but read the module's config from the local garden.yml file.
Type | Required |
---|---|
| No |
Example:
allowPublish
allowPublish
When false, disables pushing this module to remote registries.
Type | Default | Required |
---|---|---|
|
| No |
generateFiles[]
generateFiles[]
A list of files to write to the module directory when resolving this module. This is useful to automatically generate (and template) any supporting files needed for the module.
Type | Default | Required |
---|---|---|
|
| No |
generateFiles[].sourcePath
generateFiles[].sourcePath
generateFiles > sourcePath
POSIX-style filename to read the source file contents from, relative to the path of the module (or the ModuleTemplate configuration file if one is being applied). This file may contain template strings, much like any other field in the configuration.
Type | Required |
---|---|
| No |
generateFiles[].targetPath
generateFiles[].targetPath
generateFiles > targetPath
POSIX-style filename to write the resolved file contents to, relative to the path of the module source directory (for remote modules this means the root of the module repository, otherwise the directory of the module configuration).
Note that any existing file with the same name will be overwritten. If the path contains one or more directories, they will be automatically created if missing.
Type | Required |
---|---|
| Yes |
generateFiles[].resolveTemplates
generateFiles[].resolveTemplates
generateFiles > resolveTemplates
By default, Garden will attempt to resolve any Garden template strings in source files. Set this to false to skip resolving template strings. Note that this does not apply when setting the value
field, since that's resolved earlier when parsing the configuration.
Type | Default | Required |
---|---|---|
|
| No |
generateFiles[].value
generateFiles[].value
generateFiles > value
The desired file contents as a string.
Type | Required |
---|---|
| No |
variables
variables
A map of variables scoped to this particular module. These are resolved before any other parts of the module configuration and take precedence over project-scoped variables. They may reference project-scoped variables, and generally use any template strings normally allowed when resolving modules.
Type | Required |
---|---|
| No |
varfile
varfile
Specify a path (relative to the module root) to a file containing variables, that we apply on top of the module-level variables
field.
The format of the files is determined by the configured file's extension:
.env
- Standard "dotenv" format, as defined by dotenv..yaml
/.yml
- YAML. The file must consist of a YAML document, which must be a map (dictionary). Keys may contain any value type..json
- JSON. Must contain a single JSON object (not an array).
NOTE: The default varfile format will change to YAML in Garden v0.13, since YAML allows for definition of nested objects and arrays.
To use different module-level varfiles in different environments, you can template in the environment name to the varfile name, e.g. varfile: "my-module.${environment.name}.env
(this assumes that the corresponding varfiles exist).
Type | Required |
---|---|
| No |
Example:
buildArgs
buildArgs
Specify build arguments to use when building the container image.
Note: Garden will always set a GARDEN_MODULE_VERSION
argument with the module version at build time.
Type | Default | Required |
---|---|---|
|
| No |
extraFlags[]
extraFlags[]
Specify extra flags to use when building the container image. Note that arguments may not be portable across implementations.
Type | Required |
---|---|
| No |
image
image
Specify the image name for the container. Should be a valid Docker image identifier. If specified and the module does not contain a Dockerfile, this image will be used to deploy services for this module. If specified and the module does contain a Dockerfile, this identifier is used when pushing the built image.
Type | Required |
---|---|
| No |
hotReload
hotReload
Specifies which files or directories to sync to which paths inside the running containers of hot reload-enabled services when those files or directories are modified. Applies to this module's services, and to services with this module as their sourceModule
.
Type | Required |
---|---|
| No |
hotReload.sync[]
hotReload.sync[]
hotReload > sync
Specify one or more source files or directories to automatically sync into the running container.
Type | Required |
---|---|
| Yes |
hotReload.sync[].source
hotReload.sync[].source
POSIX-style path of the directory to sync to the target, relative to the module's top-level directory. Must be a relative path. Defaults to the module's top-level directory if no value is provided.
Type | Default | Required |
---|---|---|
|
| No |
Example:
hotReload.sync[].target
hotReload.sync[].target
POSIX-style absolute path to sync the directory to inside the container. The root path (i.e. "/") is not allowed.
Type | Required |
---|---|
| Yes |
Example:
hotReload.postSyncCommand[]
hotReload.postSyncCommand[]
hotReload > postSyncCommand
An optional command to run inside the container after syncing.
Type | Required |
---|---|
| No |
Example:
dockerfile
dockerfile
POSIX-style name of Dockerfile, relative to module root.
Type | Required |
---|---|
| No |
services[]
services[]
A list of services to deploy from this container module.
Type | Default | Required |
---|---|---|
|
| No |
services[].name
services[].name
services > name
Valid RFC1035/RFC1123 (DNS) label (may contain lowercase letters, numbers and dashes, must start with a letter, and cannot end with a dash), cannot contain consecutive dashes or start with garden
, or be longer than 63 characters.
Type | Required |
---|---|
| Yes |
services[].dependencies[]
services[].dependencies[]
services > dependencies
The names of any services that this service depends on at runtime, and the names of any tasks that should be executed before this service is deployed.
Type | Default | Required |
---|---|---|
|
| No |
services[].disabled
services[].disabled
services > disabled
Set this to true
to disable the service. You can use this with conditional template strings to enable/disable services based on, for example, the current environment or other variables (e.g. enabled: ${environment.name != "prod"}
). This can be handy when you only need certain services for specific environments, e.g. only for development.
Disabling a service means that it will not be deployed, and will also be ignored if it is declared as a runtime dependency for another service, test or task.
Note however that template strings referencing the service's outputs (i.e. runtime outputs) will fail to resolve when the service is disabled, so you need to make sure to provide alternate values for those if you're using them, using conditional expressions.
Type | Default | Required |
---|---|---|
|
| No |
services[].annotations
services[].annotations
services > annotations
Annotations to attach to the service (note: May not be applicable to all providers).
When using the Kubernetes provider, these annotations are applied to both Service and Pod resources. You can generally specify the annotations intended for both Pods or Services here, and the ones that don't apply on either side will be ignored (i.e. if you put a Service annotation here, it'll also appear on Pod specs but will be safely ignored there, and vice versa).
Type | Default | Required |
---|---|---|
|
| No |
Example:
services[].command[]
services[].command[]
services > command
The command/entrypoint to run the container with when starting the service.
Type | Required |
---|---|
| No |
Example:
services[].args[]
services[].args[]
services > args
The arguments to run the container with when starting the service.
Type | Required |
---|---|
| No |
Example:
services[].daemon
services[].daemon
services > daemon
Whether to run the service as a daemon (to ensure exactly one instance runs per node). May not be supported by all providers.
Type | Default | Required |
---|---|---|
|
| No |
services[].devMode
services[].devMode
services > devMode
Specifies which files or directories to sync to which paths inside the running containers of the service when it's in dev mode, and overrides for the container command and/or arguments.
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 for more information.
Type | Required |
---|---|
| No |
services[].devMode.args[]
services[].devMode.args[]
Override the default container arguments when in dev mode.
Type | Required |
---|---|
| No |
services[].devMode.command[]
services[].devMode.command[]
Override the default container command (i.e. entrypoint) when in dev mode.
Type | Required |
---|---|
| No |
services[].devMode.sync[]
services[].devMode.sync[]
Specify one or more source files or directories to automatically sync with the running container.
Type | Required |
---|---|
| No |
services[].devMode.sync[].target
services[].devMode.sync[].target
services > devMode > sync > target
POSIX-style absolute path to sync the directory to inside the container. The root path (i.e. "/") is not allowed.
Type | Required |
---|---|
| Yes |
Example:
services[].devMode.sync[].exclude[]
services[].devMode.sync[].exclude[]
services > devMode > sync > exclude
Specify a list of POSIX-style paths or glob patterns that should be excluded from the sync.
.git
directories and .garden
directories are always ignored.
Type | Required |
---|---|
| No |
Example:
services[].devMode.sync[].source
services[].devMode.sync[].source
services > devMode > sync > source
POSIX-style path of the directory to sync to the target. Can be either a relative or an absolute path. Defaults to the module's top-level directory if no value is provided.
Type | Default | Required |
---|---|---|
|
| No |
Example:
services[].devMode.sync[].mode
services[].devMode.sync[].mode
services > devMode > sync > mode
The sync mode to use for the given paths. See the Dev Mode guide for details.
Type | Allowed Values | Default | Required |
---|---|---|---|
| "one-way", "one-way-safe", "one-way-replica", "one-way-reverse", "one-way-replica-reverse", "two-way", "two-way-safe", "two-way-resolved" |
| Yes |
services[].devMode.sync[].defaultFileMode
services[].devMode.sync[].defaultFileMode
services > devMode > sync > defaultFileMode
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 for more information.
Type | Required |
---|---|
| No |
services[].devMode.sync[].defaultDirectoryMode
services[].devMode.sync[].defaultDirectoryMode
services > devMode > sync > defaultDirectoryMode
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 for more information.
Type | Required |
---|---|
| No |
services[].devMode.sync[].defaultOwner
services[].devMode.sync[].defaultOwner
services > devMode > sync > defaultOwner
Set the default owner of files and directories at the target. Specify either an integer ID or a string name. See the Mutagen docs for more information.
Type | Required |
---|---|
| No |
services[].devMode.sync[].defaultGroup
services[].devMode.sync[].defaultGroup
services > devMode > sync > defaultGroup
Set the default group on files and directories at the target. Specify either an integer ID or a string name. See the Mutagen docs for more information.
Type | Required |
---|---|
| No |
services[].localMode
services[].localMode
services > localMode
[EXPERIMENTAL] Configures the local application which will send and receive network requests instead of the target resource.
The target service will be replaced by a proxy container which runs an SSH server to proxy requests. Reverse port-forwarding will be automatically configured to route traffic to the local service and back.
Local mode is enabled by setting the --local
option on the garden deploy
or garden dev
commands. Local mode always takes the precedence over dev mode if there are any conflicting service names.
Health checks are disabled for services running in local mode.
See the Local Mode guide for more information.
Note! This feature is still experimental. Some incompatible changes can be made until the first non-experimental release.
Type | Required |
---|---|
| No |
services[].localMode.ports[]
services[].localMode.ports[]
The reverse port-forwards configuration for the local application.
Type | Required |
---|---|
| No |
services[].localMode.ports[].local
services[].localMode.ports[].local
services > localMode > ports > local
The local port to be used for reverse port-forward.
Type | Required |
---|---|
| No |
services[].localMode.ports[].remote
services[].localMode.ports[].remote
services > localMode > ports > remote
The remote port to be used for reverse port-forward.
Type | Required |
---|---|
| No |
services[].localMode.command[]
services[].localMode.command[]
services > localMode > command
The command to run the local application. If not present, then the local application should be started manually.
Type | Required |
---|---|
| No |
services[].localMode.restart
services[].localMode.restart
services > localMode > restart
Specifies restarting policy for the local application. By default, the local application will be restarting infinitely with 1000ms between attempts.
Type | Default | Required |
---|---|---|
|
| No |
services[].localMode.restart.delayMsec
services[].localMode.restart.delayMsec
services > localMode > restart > delayMsec
Delay in milliseconds between the local application restart attempts. The default value is 1000ms.
Type | Default | Required |
---|---|---|
|
| No |
services[].localMode.restart.max
services[].localMode.restart.max
services > localMode > restart > max
Max number of the local application restarts. Unlimited by default.
Type | Default | Required |
---|---|---|
|
| No |
services[].ingresses[]
services[].ingresses[]
services > ingresses
List of ingress endpoints that the service exposes.
Type | Default | Required |
---|---|---|
|
| No |
Example:
services[].ingresses[].annotations
services[].ingresses[].annotations
services > ingresses > annotations
Annotations to attach to the ingress (Note: May not be applicable to all providers)
Type | Default | Required |
---|---|---|
|
| No |
Example:
services[].ingresses[].hostname
services[].ingresses[].hostname
services > ingresses > hostname
The hostname that should route to this service. Defaults to the default hostname configured in the provider configuration.
Note that if you're developing locally you may need to add this hostname to your hosts file.
Type | Required |
---|---|
| No |
services[].ingresses[].linkUrl
services[].ingresses[].linkUrl
services > ingresses > linkUrl
The link URL for the ingress to show in the console and on the dashboard. Also used when calling the service with the call
command.
Use this if the actual URL is different from what's specified in the ingress, e.g. because there's a load balancer in front of the service that rewrites the paths.
Otherwise Garden will construct the link URL from the ingress spec.
Type | Required |
---|---|
| No |
services[].ingresses[].path
services[].ingresses[].path
The path which should be routed to the service.
Type | Default | Required |
---|---|---|
|
| No |
services[].ingresses[].port
services[].ingresses[].port
The name of the container port where the specified paths should be routed.
Type | Required |
---|---|
| Yes |
services[].env
services[].env
services > env
Key/value map of environment variables. Keys must be valid POSIX environment variable names (must not start with GARDEN
) and values must be primitives or references to secrets.
Type | Default | Required |
---|---|---|
|
| No |
Example:
services[].healthCheck
services[].healthCheck
services > healthCheck
Specify how the service's health should be checked after deploying.
Type | Required |
---|---|
| No |
services[].healthCheck.httpGet
services[].healthCheck.httpGet
services > healthCheck > httpGet
Set this to check the service's health by making an HTTP request.
Type | Required |
---|---|
| No |
services[].healthCheck.httpGet.path
services[].healthCheck.httpGet.path
services > healthCheck > httpGet > path
The path of the service's health check endpoint.
Type | Required |
---|---|
| Yes |
services[].healthCheck.httpGet.port
services[].healthCheck.httpGet.port
services > healthCheck > httpGet > port
The name of the port where the service's health check endpoint should be available.
Type | Required |
---|---|
| Yes |
services[].healthCheck.httpGet.scheme
services[].healthCheck.httpGet.scheme
services > healthCheck > httpGet > scheme
Type | Default | Required |
---|---|---|
|
| No |
services[].healthCheck.command[]
services[].healthCheck.command[]
services > healthCheck > command
Set this to check the service's health by running a command in its container.
Type | Required |
---|---|
| No |
services[].healthCheck.tcpPort
services[].healthCheck.tcpPort
services > healthCheck > tcpPort
Set this to check the service's health by checking if this TCP port is accepting connections.
Type | Required |
---|---|
| No |
services[].healthCheck.readinessTimeoutSeconds
services[].healthCheck.readinessTimeoutSeconds
services > healthCheck > readinessTimeoutSeconds
The maximum number of seconds to wait until the readiness check counts as failed.
Type | Default | Required |
---|---|---|
|
| No |
services[].healthCheck.livenessTimeoutSeconds
services[].healthCheck.livenessTimeoutSeconds
services > healthCheck > livenessTimeoutSeconds
The maximum number of seconds to wait until the liveness check counts as failed.
Type | Default | Required |
---|---|---|
|
| No |
services[].hotReloadCommand[]
services[].hotReloadCommand[]
services > hotReloadCommand
If this module uses the hotReload
field, the container will be run with this command/entrypoint when the service is deployed with hot reloading enabled.
Type | Required |
---|---|
| No |
Example:
services[].hotReloadArgs[]
services[].hotReloadArgs[]
services > hotReloadArgs
If this module uses the hotReload
field, the container will be run with these arguments when the service is deployed with hot reloading enabled.
Type | Required |
---|---|
| No |
Example:
services[].timeout
services[].timeout
services > timeout
The maximum duration (in seconds) to wait for resources to deploy and become healthy.
Type | Default | Required |
---|---|---|
|
| No |
services[].limits
services[].limits
services > limits
Deprecated: This field will be removed in a future release.
Specify resource limits for the service.
Type | Required |
---|---|
| No |
services[].limits.cpu
services[].limits.cpu
Deprecated: This field will be removed in a future release.
The maximum amount of CPU the service can use, in millicpus (i.e. 1000 = 1 CPU)
Type | Required |
---|---|
| No |
services[].limits.memory
services[].limits.memory
Deprecated: This field will be removed in a future release.
The maximum amount of RAM the service can use, in megabytes (i.e. 1024 = 1 GB)
Type | Required |
---|---|
| No |
services[].cpu
services[].cpu
services > cpu
Type | Default | Required |
---|---|---|
|
| No |
services[].cpu.min
services[].cpu.min
The minimum amount of CPU the service needs to be available for it to be deployed, in millicpus (i.e. 1000 = 1 CPU)
Type | Default | Required |
---|---|---|
|
| No |
services[].cpu.max
services[].cpu.max
The maximum amount of CPU the service can use, in millicpus (i.e. 1000 = 1 CPU). If set to null will result in no limit being set.
Type | Default | Required |
---|---|---|
|
| No |
services[].memory
services[].memory
services > memory
Type | Default | Required |
---|---|---|
|
| No |
services[].memory.min
services[].memory.min
The minimum amount of RAM the service needs to be available for it to be deployed, in megabytes (i.e. 1024 = 1 GB)
Type | Default | Required |
---|---|---|
|
| No |
services[].memory.max
services[].memory.max
The maximum amount of RAM the service can use, in megabytes (i.e. 1024 = 1 GB) If set to null will result in no limit being set.
Type | Default | Required |
---|---|---|
|
| No |
services[].ports[]
services[].ports[]
services > ports
List of ports that the service container exposes.
Type | Default | Required |
---|---|---|
|
| No |
services[].ports[].name
services[].ports[].name
The name of the port (used when referencing the port elsewhere in the service configuration).
Type | Required |
---|---|
| Yes |
services[].ports[].protocol
services[].ports[].protocol
The protocol of the port.
Type | Default | Required |
---|---|---|
|
| No |
services[].ports[].containerPort
services[].ports[].containerPort
services > ports > containerPort
The port exposed on the container by the running process. This will also be the default value for servicePort
. This is the port you would expose in your Dockerfile and that your process listens on. This is commonly a non-priviledged port like 8080 for security reasons. The service port maps to the container port: servicePort:80 -> containerPort:8080 -> process:8080
Type | Required |
---|---|
| Yes |
Example:
services[].ports[].localPort
services[].ports[].localPort
Specify a preferred local port to attach to when creating a port-forward to the service port. If this port is busy, a warning will be shown and an alternative port chosen.
Type | Required |
---|---|
| No |
Example:
services[].ports[].servicePort
services[].ports[].servicePort
services > ports > servicePort
The port exposed on the service. Defaults to containerPort
if not specified. This is the port you use when calling a service from another service within the cluster. For example, if your service name is my-service and the service port is 8090, you would call it with: http://my-service:8090/some-endpoint. It is common to use port 80, the default port number, so that you can call the service directly with http://my-service/some-endpoint. The service port maps to the container port: servicePort:80 -> containerPort:8080 -> process:8080
Type | Required |
---|---|
| No |
Example:
services[].ports[].hostPort
services[].ports[].hostPort
Deprecated: This field will be removed in a future release.
Type | Required |
---|---|
| No |
services[].ports[].nodePort
services[].ports[].nodePort
Set this to expose the service on the specified port on the host node (may not be supported by all providers). Set to true
to have the cluster pick a port automatically, which is most often advisable if the cluster is shared by multiple users. This allows you to call the service from the outside by the node's IP address and the port number set in this field.
Type | Required |
---|---|
| No |
services[].replicas
services[].replicas
services > replicas
The number of instances of the service to deploy. Defaults to 3 for environments configured with production: true
, otherwise 1. Note: This setting may be overridden or ignored in some cases. For example, when running with daemon: true
, with hot-reloading enabled, or if the provider doesn't support multiple replicas.
Type | Required |
---|---|
| No |
services[].volumes[]
services[].volumes[]
services > volumes
List of volumes that should be mounted when deploying the service.
Note: If neither hostPath
nor module
is specified, an empty ephemeral volume is created and mounted when deploying the container.
Type | Default | Required |
---|---|---|
|
| No |
services[].volumes[].name
services[].volumes[].name
The name of the allocated volume.
Type | Required |
---|---|
| Yes |
services[].volumes[].containerPath
services[].volumes[].containerPath
services > volumes > containerPath
The path where the volume should be mounted in the container.
Type | Required |
---|---|
| Yes |
services[].volumes[].hostPath
services[].volumes[].hostPath
NOTE: Usage of hostPath is generally discouraged, since it doesn't work reliably across different platforms and providers. Some providers may not support it at all.
A local path or path on the node that's running the container, to mount in the container, relative to the module source path (or absolute).
Type | Required |
---|---|
| No |
Example:
services[].volumes[].module
services[].volumes[].module
The name of a volume module that should be mounted at containerPath
. The supported module types will depend on which provider you are using. The kubernetes
provider supports the persistentvolumeclaim module, for example.
When a module
is specified, the referenced module/volume will be automatically configured as a runtime dependency of this service, as well as a build dependency of this module.
Note: Make sure to pay attention to the supported accessModes
of the referenced volume. Unless it supports the ReadWriteMany access mode, you'll need to make sure it is not configured to be mounted by multiple services at the same time. Refer to the documentation of the module type in question to learn more.
Type | Required |
---|---|
| No |
services[].privileged
services[].privileged
services > privileged
If true, run the service's main container in privileged mode. Processes in privileged containers are essentially equivalent to root on the host. Defaults to false.
Type | Required |
---|---|
| No |
services[].tty
services[].tty
services > tty
Specify if containers in this module have TTY support enabled (which implies having stdin support enabled).
Type | Default | Required |
---|---|---|
|
| No |
services[].addCapabilities[]
services[].addCapabilities[]
services > addCapabilities
POSIX capabilities to add to the running service's main container.
Type | Required |
---|---|
| No |
services[].dropCapabilities[]
services[].dropCapabilities[]
services > dropCapabilities
POSIX capabilities to remove from the running service's main container.
Type | Required |
---|---|
| No |
services[].deploymentStrategy
services[].deploymentStrategy
services > deploymentStrategy
Specifies the container's deployment strategy.
Type | Allowed Values | Default | Required |
---|---|---|---|
| "RollingUpdate", "Recreate" |
| Yes |
tests[]
tests[]
A list of tests to run in the module.
Type | Default | Required |
---|---|---|
|
| No |
tests[].name
tests[].name
tests > name
The name of the test.
Type | Required |
---|---|
| Yes |
tests[].dependencies[]
tests[].dependencies[]
tests > dependencies
The names of any services that must be running, and the names of any tasks that must be executed, before the test is run.
Type | Default | Required |
---|---|---|
|
| No |
tests[].disabled
tests[].disabled
tests > disabled
Set this to true
to disable the test. You can use this with conditional template strings to enable/disable tests based on, for example, the current environment or other variables (e.g. enabled: ${environment.name != "prod"}
). This is handy when you only want certain tests to run in specific environments, e.g. only during CI.
Type | Default | Required |
---|---|---|
|
| No |
tests[].timeout
tests[].timeout
tests > timeout
Maximum duration (in seconds) of the test run.
Type | Default | Required |
---|---|---|
|
| No |
tests[].args[]
tests[].args[]
tests > args
The arguments used to run the test inside the container.
Type | Required |
---|---|
| No |
Example:
tests[].artifacts[]
tests[].artifacts[]
tests > artifacts
Specify artifacts to copy out of the container after the run. The artifacts are stored locally under the .garden/artifacts
directory.
Note: Depending on the provider, this may require the container image to include sh
tar
, in order to enable the file transfer.
Type | Required |
---|---|
| No |
Example:
tests[].artifacts[].source
tests[].artifacts[].source
A POSIX-style path or glob to copy. Must be an absolute path. May contain wildcards.
Type | Required |
---|---|
| Yes |
Example:
tests[].artifacts[].target
tests[].artifacts[].target
A POSIX-style path to copy the artifacts to, relative to the project artifacts directory at .garden/artifacts
.
Type | Default | Required |
---|---|---|
|
| No |
Example:
tests[].command[]
tests[].command[]
tests > command
The command/entrypoint used to run the test inside the container.
Type | Required |
---|---|
| No |
Example:
tests[].env
tests[].env
tests > env
Key/value map of environment variables. Keys must be valid POSIX environment variable names (must not start with GARDEN
) and values must be primitives or references to secrets.
Type | Default | Required |
---|---|---|
|
| No |
Example:
tests[].cpu
tests[].cpu
tests > cpu
Type | Default | Required |
---|---|---|
|
| No |
tests[].cpu.min
tests[].cpu.min
The minimum amount of CPU the test needs to be available for it to be deployed, in millicpus (i.e. 1000 = 1 CPU)
Type | Default | Required |
---|---|---|
|
| No |
tests[].cpu.max
tests[].cpu.max
The maximum amount of CPU the test can use, in millicpus (i.e. 1000 = 1 CPU). If set to null will result in no limit being set.
Type | Default | Required |
---|---|---|
|
| No |
tests[].memory
tests[].memory
tests > memory
Type | Default | Required |
---|---|---|
|
| No |
tests[].memory.min
tests[].memory.min
The minimum amount of RAM the test needs to be available for it to be deployed, in megabytes (i.e. 1024 = 1 GB)
Type | Default | Required |
---|---|---|
|
| No |
tests[].memory.max
tests[].memory.max
The maximum amount of RAM the test can use, in megabytes (i.e. 1024 = 1 GB) If set to null will result in no limit being set.
Type | Default | Required |
---|---|---|
|
| No |
tests[].volumes[]
tests[].volumes[]
tests > volumes
List of volumes that should be mounted when deploying the test.
Note: If neither hostPath
nor module
is specified, an empty ephemeral volume is created and mounted when deploying the container.
Type | Default | Required |
---|---|---|
|
| No |
tests[].volumes[].name
tests[].volumes[].name
The name of the allocated volume.
Type | Required |
---|---|
| Yes |
tests[].volumes[].containerPath
tests[].volumes[].containerPath
tests > volumes > containerPath
The path where the volume should be mounted in the container.
Type | Required |
---|---|
| Yes |
tests[].volumes[].hostPath
tests[].volumes[].hostPath
NOTE: Usage of hostPath is generally discouraged, since it doesn't work reliably across different platforms and providers. Some providers may not support it at all.
A local path or path on the node that's running the container, to mount in the container, relative to the module source path (or absolute).
Type | Required |
---|---|
| No |
Example:
tests[].volumes[].module
tests[].volumes[].module
The name of a volume module that should be mounted at containerPath
. The supported module types will depend on which provider you are using. The kubernetes
provider supports the persistentvolumeclaim module, for example.
When a module
is specified, the referenced module/volume will be automatically configured as a runtime dependency of this service, as well as a build dependency of this module.
Note: Make sure to pay attention to the supported accessModes
of the referenced volume. Unless it supports the ReadWriteMany access mode, you'll need to make sure it is not configured to be mounted by multiple services at the same time. Refer to the documentation of the module type in question to learn more.
Type | Required |
---|---|
| No |
tests[].privileged
tests[].privileged
tests > privileged
If true, run the test's main container in privileged mode. Processes in privileged containers are essentially equivalent to root on the host. Defaults to false.
Type | Required |
---|---|
| No |
tests[].addCapabilities[]
tests[].addCapabilities[]
tests > addCapabilities
POSIX capabilities to add to the running test's main container.
Type | Required |
---|---|
| No |
tests[].dropCapabilities[]
tests[].dropCapabilities[]
tests > dropCapabilities
POSIX capabilities to remove from the running test's main container.
Type | Required |
---|---|
| No |
tasks[]
tasks[]
A list of tasks that can be run from this container module. These can be used as dependencies for services (executed before the service is deployed) or for other tasks.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].name
tasks[].name
tasks > name
The name of the task.
Type | Required |
---|---|
| Yes |
tasks[].description
tasks[].description
tasks > description
A description of the task.
Type | Required |
---|---|
| No |
tasks[].dependencies[]
tasks[].dependencies[]
tasks > dependencies
The names of any tasks that must be executed, and the names of any services that must be running, before this task is executed.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].disabled
tasks[].disabled
tasks > disabled
Set this to true
to disable the task. You can use this with conditional template strings to enable/disable tasks based on, for example, the current environment or other variables (e.g. enabled: ${environment.name != "prod"}
). This can be handy when you only want certain tasks to run in specific environments, e.g. only for development.
Disabling a task means that it will not be run, and will also be ignored if it is declared as a runtime dependency for another service, test or task.
Note however that template strings referencing the task's outputs (i.e. runtime outputs) will fail to resolve when the task is disabled, so you need to make sure to provide alternate values for those if you're using them, using conditional expressions.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].timeout
tasks[].timeout
tasks > timeout
Maximum duration (in seconds) of the task's execution.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].args[]
tasks[].args[]
tasks > args
The arguments used to run the task inside the container.
Type | Required |
---|---|
| No |
Example:
tasks[].artifacts[]
tasks[].artifacts[]
tasks > artifacts
Specify artifacts to copy out of the container after the run. The artifacts are stored locally under the .garden/artifacts
directory.
Note: Depending on the provider, this may require the container image to include sh
tar
, in order to enable the file transfer.
Type | Required |
---|---|
| No |
Example:
tasks[].artifacts[].source
tasks[].artifacts[].source
A POSIX-style path or glob to copy. Must be an absolute path. May contain wildcards.
Type | Required |
---|---|
| Yes |
Example:
tasks[].artifacts[].target
tasks[].artifacts[].target
A POSIX-style path to copy the artifacts to, relative to the project artifacts directory at .garden/artifacts
.
Type | Default | Required |
---|---|---|
|
| No |
Example:
tasks[].cacheResult
tasks[].cacheResult
tasks > cacheResult
Set to false if you don't want the task's result to be cached. Use this if the task needs to be run any time your project (or one or more of the task's dependants) is deployed. Otherwise the task is only re-run when its version changes (i.e. the module or one of its dependencies is modified), or when you run garden run task
.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].command[]
tasks[].command[]
tasks > command
The command/entrypoint used to run the task inside the container.
Type | Required |
---|---|
| No |
Example:
tasks[].env
tasks[].env
tasks > env
Key/value map of environment variables. Keys must be valid POSIX environment variable names (must not start with GARDEN
) and values must be primitives or references to secrets.
Type | Default | Required |
---|---|---|
|
| No |
Example:
tasks[].cpu
tasks[].cpu
tasks > cpu
Type | Default | Required |
---|---|---|
|
| No |
tasks[].cpu.min
tasks[].cpu.min
The minimum amount of CPU the task needs to be available for it to be deployed, in millicpus (i.e. 1000 = 1 CPU)
Type | Default | Required |
---|---|---|
|
| No |
tasks[].cpu.max
tasks[].cpu.max
The maximum amount of CPU the task can use, in millicpus (i.e. 1000 = 1 CPU). If set to null will result in no limit being set.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].memory
tasks[].memory
tasks > memory
Type | Default | Required |
---|---|---|
|
| No |
tasks[].memory.min
tasks[].memory.min
The minimum amount of RAM the task needs to be available for it to be deployed, in megabytes (i.e. 1024 = 1 GB)
Type | Default | Required |
---|---|---|
|
| No |
tasks[].memory.max
tasks[].memory.max
The maximum amount of RAM the task can use, in megabytes (i.e. 1024 = 1 GB) If set to null will result in no limit being set.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].volumes[]
tasks[].volumes[]
tasks > volumes
List of volumes that should be mounted when deploying the task.
Note: If neither hostPath
nor module
is specified, an empty ephemeral volume is created and mounted when deploying the container.
Type | Default | Required |
---|---|---|
|
| No |
tasks[].volumes[].name
tasks[].volumes[].name
The name of the allocated volume.
Type | Required |
---|---|
| Yes |
tasks[].volumes[].containerPath
tasks[].volumes[].containerPath
tasks > volumes > containerPath
The path where the volume should be mounted in the container.
Type | Required |
---|---|
| Yes |
tasks[].volumes[].hostPath
tasks[].volumes[].hostPath
NOTE: Usage of hostPath is generally discouraged, since it doesn't work reliably across different platforms and providers. Some providers may not support it at all.
A local path or path on the node that's running the container, to mount in the container, relative to the module source path (or absolute).
Type | Required |
---|---|
| No |
Example:
tasks[].volumes[].module
tasks[].volumes[].module
The name of a volume module that should be mounted at containerPath
. The supported module types will depend on which provider you are using. The kubernetes
provider supports the persistentvolumeclaim module, for example.
When a module
is specified, the referenced module/volume will be automatically configured as a runtime dependency of this service, as well as a build dependency of this module.
Note: Make sure to pay attention to the supported accessModes
of the referenced volume. Unless it supports the ReadWriteMany access mode, you'll need to make sure it is not configured to be mounted by multiple services at the same time. Refer to the documentation of the module type in question to learn more.
Type | Required |
---|---|
| No |
tasks[].privileged
tasks[].privileged
tasks > privileged
If true, run the task's main container in privileged mode. Processes in privileged containers are essentially equivalent to root on the host. Defaults to false.
Type | Required |
---|---|
| No |
tasks[].addCapabilities[]
tasks[].addCapabilities[]
tasks > addCapabilities
POSIX capabilities to add to the running task's main container.
Type | Required |
---|---|
| No |
tasks[].dropCapabilities[]
tasks[].dropCapabilities[]
tasks > dropCapabilities
POSIX capabilities to remove from the running task's main container.
Type | Required |
---|---|
| No |
Outputs
Module Outputs
The following keys are available via the ${modules.<module-name>}
template string key for container
modules.
${modules.<module-name>.buildPath}
${modules.<module-name>.buildPath}
The build path of the module.
Type |
---|
|
Example:
${modules.<module-name>.name}
${modules.<module-name>.name}
The name of the module.
Type |
---|
|
${modules.<module-name>.path}
${modules.<module-name>.path}
The local path of the module.
Type |
---|
|
Example:
${modules.<module-name>.var.*}
${modules.<module-name>.var.*}
A map of all variables defined in the module.
Type | Default |
---|---|
|
|
${modules.<module-name>.var.<variable-name>}
${modules.<module-name>.var.<variable-name>}
Type |
---|
|
${modules.<module-name>.version}
${modules.<module-name>.version}
The current version of the module.
Type |
---|
|
Example:
${modules.<module-name>.outputs.local-image-name}
${modules.<module-name>.outputs.local-image-name}
The name of the image (without tag/version) that the module uses for local builds and deployments.
Type |
---|
|
Example:
${modules.<module-name>.outputs.local-image-id}
${modules.<module-name>.outputs.local-image-id}
The full ID of the image (incl. tag/version) that the module uses for local builds and deployments.
Type |
---|
|
Example:
${modules.<module-name>.outputs.deployment-image-name}
${modules.<module-name>.outputs.deployment-image-name}
The name of the image (without tag/version) that the module will use during deployment.
Type |
---|
|
Example:
${modules.<module-name>.outputs.deployment-image-id}
${modules.<module-name>.outputs.deployment-image-id}
The full ID of the image (incl. tag/version) that the module will use during deployment.
Type |
---|
|
Example:
Service Outputs
The following keys are available via the ${runtime.services.<service-name>}
template string key for container
module services. Note that these are only resolved when deploying/running dependants of the service, so they are not usable for every field.
${runtime.services.<service-name>.version}
${runtime.services.<service-name>.version}
The current version of the service.
Type |
---|
|
Example:
Task Outputs
The following keys are available via the ${runtime.tasks.<task-name>}
template string key for container
module tasks. Note that these are only resolved when deploying/running dependants of the task, so they are not usable for every field.
${runtime.tasks.<task-name>.version}
${runtime.tasks.<task-name>.version}
The current version of the task.
Type |
---|
|
Example:
${runtime.tasks.<task-name>.outputs.log}
${runtime.tasks.<task-name>.outputs.log}
The full log from the executed task. (Pro-tip: Make it machine readable so it can be parsed by dependant tasks and services!)
Type | Default |
---|---|
|
|
Last updated