description | keywords | title |
---|---|---|
Declare default environment variables in a file |
fig, composition, compose, docker, orchestration, environment, env file |
Declare default environment variables in file |
Compose supports declaring default environment variables in an environment file
named .env
placed in the folder where the docker-compose
command is executed
(current working directory).
These syntax rules apply to the .env
file:
- Compose expects each line in an
env
file to be inVAR=VAL
format. - Lines beginning with
#
(i.e. comments) are ignored. - Blank lines are ignored.
- There is no special handling of quotation marks (i.e. they will be part of the VAL, you have been warned ;) ).
The environment variables you define here will be used for variable substitution in your Compose file, and can also be used to define the following CLI variables:
COMPOSE_API_VERSION
COMPOSE_CONVERT_WINDOWS_PATHS
COMPOSE_FILE
COMPOSE_HTTP_TIMEOUT
COMPOSE_TLS_VERSION
COMPOSE_PROJECT_NAME
DOCKER_CERT_PATH
DOCKER_HOST
DOCKER_TLS_VERIFY
Notes
Values present in the environment at runtime will always override those defined inside the
.env
file. Similarly, values passed via command-line arguments take precedence as well.Environment variables defined in the
.env
file are not automatically visible inside containers. To set container-applicable environment variables, follow the guidelines in the topic Environment variables in Compose, which describes how to pass shell environment variables through to containers, define environment variables in Compose files, and more. {: .note-vanilla}