76 KiB
		
	
	
	
	
	
			
		
		
	
	| title | description | keywords | toc_max | 
|---|---|---|---|
| Docker Compose release notes | Release notes for Docker Compose | release notes, compose | 2 | 
1.23.1 (2018-11-01)
Bug Fixes
- 
Fixed a bug where working with containers created with a version of Compose earlier than 1.23.0would cause unexpected crashes.
- 
Fixed an issue where the behavior of the --project-directoryflag would vary depending on which subcommand was used.
1.23.0 (2018-10-30)
Important note
The default naming scheme for containers created by Compose in this version
has changed from <project>_<service>_<index> to
<project>_<service>_<index>_<slug>, where <slug> is a randomly-generated
hexadecimal string. Please make sure to update scripts relying on the old
naming scheme accordingly before upgrading.
Features
- 
Logs for containers restarting after a crash will now appear in the output of the upandlogscommands.
- 
Added --hashoption to thedocker-compose configcommand, allowing users to print a hash string for each service's configuration to facilitate rolling updates.
- 
Added --parallelflag to thedocker-compose buildcommand, allowing Compose to build up to 5 images simultaneously.
- 
Output for the pullcommand now reports status / progress even when pulling multiple images in parallel.
- 
For images with multiple names, Compose will now attempt to match the one present in the service configuration in the output of the imagescommand.
Bug Fixes
- 
Fixed an issue where parallel runcommands for the same service would fail due to name collisions.
- 
Fixed an issue where paths longer than 260 characters on Windows clients would cause docker-compose buildto fail.
- 
Fixed a bug where attempting to mount /var/run/docker.sockwith Docker Desktop for Windows would result in failure.
- 
The --project-directoryoption is now used by Compose to determine where to look for the.envfile.
- 
docker-compose buildno longer fails when attempting to pull an image with credentials provided by the gcloud credential helper.
- 
Fixed the --exit-code-fromoption indocker-compose upto always report the actual exit code even when the watched container is not the cause of the exit.
- 
Fixed an issue that would prevent recreating a service in some cases where a volume would be mapped to the same mountpoint as a volume declared within the Dockerfile for that image. 
- 
Fixed a bug that caused hash configuration with multiple networks to be inconsistent, causing some services to be unnecessarily restarted. 
- 
Fixed a bug that would cause failures with variable substitution for services with a name containing one or more dot characters. 
- 
Fixed a pipe handling issue when using the containerized version of Compose. 
- 
Fixed a bug causing external: falseentries in the Compose file to be printed asexternal: truein the output ofdocker-compose config.
- 
Fixed a bug where issuing a docker-compose pullcommand on services without a defined image key would cause Compose to crash.
- 
Volumes and binds are now mounted in the order they are declared in the service definition. 
Miscellaneous
- The zshcompletion script has been updated with new options, and no longer suggests container names where service names are expected.
1.22.0 (2018-07-17)
New features
Compose format version 3.7
- 
Introduced version 3.7 of the docker-compose.ymlspecification. This version requires Docker Engine 18.06.0 or above.
- 
Added support for rollback_configin the deploy configuration
- 
Added support for the initparameter in service configurations
- 
Added support for extension fields in service, network, volume, secret, and config configurations 
Compose format version 2.4
- Added support for extension fields in service, network, and volume configurations
Bug Fixes
- 
Fixed a bug that prevented deployment with some Compose files when DOCKER_DEFAULT_PLATFORMwas set
- 
Compose will no longer try to create containers or volumes with invalid starting characters 
- 
Fixed several bugs that prevented Compose commands from working properly with containers created with an older version of Compose 
- 
Fixed an issue with the output of docker-compose configwith the--compatibility-modeflag enabled when the source file contains attachable networks
- 
Fixed a bug that prevented the gcloudcredential store from working properly when used with the Compose binary on UNIX
- 
Fixed a bug that caused connection errors when trying to operate over a non-HTTPS TCP connection on Windows 
- 
Fixed a bug that caused builds to fail on Windows if the Dockerfile was located in a subdirectory of the build context 
- 
Fixed an issue that prevented proper parsing of UTF-8 BOM encoded Compose files on Windows 
- 
Fixed an issue with handling of the double-wildcard ( **) pattern in.dockerignorefiles when usingdocker-compose build
- 
Fixed a bug that caused auth values in legacy .dockercfgfiles to be ignored
- 
docker-compose buildwill no longer attempt to create image names starting with an invalid character
1.21.2 (2018-05-03)
Bug Fixes
- Fixed a bug where the ip_range attribute in IPAM configs was prevented from passing validation
1.21.1 (2018-04-27)
Bug Fixes
- 
In 1.21.0, we introduced a change to how project names are sanitized for internal use in resource names. This caused issues when manipulating an existing, deployed application whose name had changed as a result. This release properly detects resources using "legacy" naming conventions. 
- 
Fixed an issue where specifying an in-context Dockerfile using an absolute path would fail despite being valid. 
- 
Fixed a bug where IPAM option changes were incorrectly detected, preventing redeployments. 
- 
Validation of v2 files now properly checks the structure of IPAM configs. 
- 
Improved support for credentials stores on Windows to include binaries using extensions other than .exe. The list of valid extensions is determined by the contents of thePATHEXTenvironment variable.
- 
Fixed a bug where Compose would generate invalid binds containing duplicate elements with some v3.2 files, triggering errors at the Engine level during deployment. 
1.21.0 (2018-04-11)
New features
Compose file version 2.4
- 
Introduced version 2.4 of the docker-compose.ymlspecification. This version requires Docker Engine 17.12.0 or above.
- 
Added support for the platformparameter in service definitions. If supplied, the parameter is also used when performing build for the service.
Compose file version 2.2 and up
- Added support for the cpu_rt_periodandcpu_rt_runtimeparameters in service definitions (2.x only).
Compose file version 2.1 and up
- 
Added support for the cpu_periodparameter in service definitions (2.x only).
- 
Added support for the isolationparameter in service build configurations. Additionally, theisolationparameter in service definitions is used for builds as well if nobuild.isolationparameter is defined. (2.x only)
All formats
- 
Added support for the --workdirflag indocker-compose exec.
- 
Added support for the --compressflag indocker-compose build.
- 
docker-compose pullis now performed in parallel by default. You can opt out using the--no-parallelflag. The--parallelflag is now deprecated and will be removed in a future version.
- 
Dashes and underscores in project names are no longer stripped out. 
- 
docker-compose buildnow supports the use of Dockerfile from outside the build context.
Bug Fixes
- 
Compose now checks that the volume's configuration matches the remote volume, and errors out if a mismatch is detected. 
- 
Fixed a bug that caused Compose to raise unexpected errors when attempting to create several one-off containers in parallel. 
- 
Fixed a bug with argument parsing when using docker-machine configto generate TLS flags forexecandruncommands.
- 
Fixed a bug where variable substitution with an empty default value (e.g. ${VAR:-}) would print an incorrect warning.
- 
Improved resilience when encoding of the Compose file doesn't match the system's. Users are encouraged to use UTF-8 when possible. 
- 
Fixed a bug where external overlay networks in Swarm would be incorrectly recognized as inexistent by Compose, interrupting otherwise valid operations. 
1.20.0 (2018-03-20)
New features
Compose file version 3.6
- 
Introduced version 3.6 of the docker-compose.ymlspecification. This version must be used with Docker Engine 18.02.0 or above.
- 
Added support for the tmpfs.sizeproperty in volume mappings
Compose file version 3.2 and up
- The --build-argoption can now be used without specifying a service indocker-compose build
Compose file version 2.3
- 
Added support for device_cgroup_rulesin service definitions
- 
Added support for the tmpfs.sizeproperty in long-form volume mappings
- 
The --build-argoption can now be used without specifying a service indocker-compose build
All formats
- 
Added a --log-leveloption to the top-leveldocker-composecommand. Accepted values aredebug,info,warning,error,critical. Default log level isinfo
- 
docker-compose runnow allows users to unset the container's entrypoint
- 
Proxy configuration found in the ~/.docker/config.jsonfile now populates environment and build args for containers created by Compose
- 
Added the --use-aliasesflag todocker-compose run, indicating that network aliases declared in the service's config should be used for the running container
- 
Added the --include-depsflag todocker-compose pull
- 
docker-compose runnow kills and removes the running container upon receivingSIGHUP
- 
docker-compose psnow shows the containers' health status if available
- 
Added the long-form --detachoption to theexec,runandupcommands
Bug Fixes
- 
Fixed .dockerignorehandling, notably with regard to absolute paths and last-line precedence rules
- 
Fixed an issue where Compose would make costly DNS lookups when connecting to the Engine when using Docker For Mac 
- 
Fixed a bug introduced in 1.19.0 which caused the default certificate path to not be honored by Compose 
- 
Fixed a bug where Compose would incorrectly check whether a symlink's destination was accessible when part of a build context 
- 
Fixed a bug where .dockerignorefiles containing lines of whitespace caused Compose to error out on Windows
- 
Fixed a bug where --tls*and--hostoptions wouldn't be properly honored for interactiverunandexeccommands
- 
A seccomp:<filepath>entry in thesecurity_optconfig now correctly sends the contents of the file to the engine
- 
ANSI output for upanddownoperations should no longer affect the wrong lines
- 
Improved support for non-unicode locales 
- 
Fixed a crash occurring on Windows when the user's home directory name contained non-ASCII characters 
- 
Fixed a bug occurring during builds caused by files with a negative mtimevalues in the build context
- 
Fixed an encoding bug when streaming build progress 
1.19.0 (2018-02-07)
Breaking changes
- On UNIX platforms, interactive runandexeccommands now require thedockerCLI to be installed on the client by default. To revert to the previous behavior, users may set theCOMPOSE_INTERACTIVE_NO_CLIenvironment variable.
New features
Compose file version 3.x
- The output of the configcommand should now mergedeployoptions from several Compose files in a more accurate manner
Compose file version 2.3
- Added support for the runtimeoption in service definitions
Compose file version 2.1 and up
- Added support for the ${VAR:?err}and${VAR?err}variable interpolation syntax to indicate mandatory variables
Compose file version 2.x
- Added prioritykey to service network mappings, allowing the user to define in which order the specified service will connect to each network
All formats
- 
Added --renew-anon-volumes(shorthand-V) to theupcommand, preventing Compose from recovering volume data from previous containers for anonymous volumes
- 
Added limit for number of simultaneous parallel operations, which should prevent accidental resource exhaustion of the server. Default is 64 and can be configured using the COMPOSE_PARALLEL_LIMITenvironment variable
- 
Added --always-recreate-depsflag to theupcommand to force recreating dependent services along with the dependency owner
- 
Added COMPOSE_IGNORE_ORPHANSenvironment variable to forgo orphan container detection and suppress warnings
- 
Added COMPOSE_FORCE_WINDOWS_HOSTenvironment variable to force Compose to parse volume definitions as if the Docker host was a Windows system, even if Compose itself is currently running on UNIX
- 
Bash completion should now be able to better differentiate between running, stopped and paused services 
Bug Fixes
- 
Fixed a bug that would cause the buildcommand to report a connection error when the build context contained unreadable files or FIFO objects. These file types will now be handled appropriately
- 
Fixed various issues around interactive run/execsessions.
- 
Fixed a bug where setting TLS options with environment and CLI flags simultaneously would result in part of the configuration being ignored 
- 
Fixed a bug where the DOCKER_TLS_VERIFY environment variable was being ignored by Compose 
- 
Fixed a bug where the -dand--timeoutflags inupwere erroneously marked as incompatible
- 
Fixed a bug where the recreation of a service would break if the image associated with the previous container had been removed 
- 
Fixed a bug where updating a mount's target would break Compose when trying to recreate the associated service 
- 
Fixed a bug where tmpfsvolumes declared using the extended syntax in Compose files using version 3.2 would be erroneously created as anonymous volumes instead
- 
Fixed a bug where type conversion errors would print a stacktrace instead of exiting gracefully 
- 
Fixed some errors related to unicode handling 
- 
Dependent services no longer get recreated along with the dependency owner if their configuration hasn't changed 
- 
Added better validation of labelsfields in Compose files. Label values containing scalar types (number, boolean) now get automatically converted to strings
1.18.0 (2017-12-18)
New features
Compose file version 3.5
- 
Introduced version 3.5 of the docker-compose.ymlspecification. This version requires Docker Engine 17.06.0 or above
- 
Added support for the shm_sizeparameter in build configurations
- 
Added support for the isolationparameter in service definitions
- 
Added support for custom names for network, secret and config definitions 
Compose file version 2.3
- 
Added support for extra_hostsin build configuration
- 
Added support for the long syntax for volume entries, as previously introduced in the 3.2 format. Using this syntax will create mounts instead of volumes. 
Compose file version 2.1 and up
- 
Added support for the oom_kill_disableparameter in service definitions (2.x only)
- 
Added support for custom names for network definitions (2.x only) 
All formats
- 
Values interpolated from the environment will now be converted to the proper type when used in non-string fields. 
- 
Added support for --labelindocker-compose run
- 
Added support for --timeoutindocker-compose down
- 
Added support for --memoryindocker-compose build
- 
Setting stop_grace_periodin service definitions now also sets the container'sstop_timeout
Bug Fixes
- 
Fixed an issue where Compose was still handling service hostname according to legacy engine behavior, causing hostnames containing dots to be cut up 
- 
Fixed a bug where the X-Y:Zsyntax for ports was considered invalid by Compose
- 
Fixed an issue with CLI logging causing duplicate messages and inelegant output to occur 
- 
Fixed an issue that caused stop_grace_periodto be ignored when using multiple Compose files
- 
Fixed a bug that caused docker-compose imagesto crash when using untagged images
- 
Fixed a bug where the valid ${VAR:-}syntax would cause Compose to error out
- 
Fixed a bug where env_fileentries using an UTF-8 BOM were being read incorrectly
- 
Fixed a bug where missing secret files would generate an empty directory in their place 
- 
Fixed character encoding issues in the CLI's error handlers 
- 
Added validation for the testfield in healthchecks
- 
Added validation for the subnetfield in IPAM configurations
- 
Added validation for volumesproperties when using the long syntax in service definitions
- 
The CLI now explicit prevents using -dand--timeouttogether indocker-compose up
1.17.0 (2017-11-01)
New features
Compose file version 3.4
- 
Introduced version 3.4 of the docker-compose.ymlspecification. This version requires to be used with Docker Engine 17.06.0 or above.
- 
Added support for cache_from,networkandtargetoptions in build configurations
- 
Added support for the orderparameter in theupdate_configsection
- 
Added support for setting a custom name in volume definitions using the nameparameter
Compose file version 2.3
- Added support for shm_sizeoption in build configuration
Compose file version 2.x
- Added support for extension fields (x-*). Also available for v3.4 files
All formats
- Added new --no-startto theupcommand, allowing users to create all resources (networks, volumes, containers) without starting services. Thecreatecommand is deprecated in favor of this new option
Bug Fixes
- 
Fixed a bug where extra_hostsvalues would be overridden by extension files instead of merging together
- 
Fixed a bug where the validation for v3.2 files would prevent using the consistencyfield in service volume definitions
- 
Fixed a bug that would cause a crash when configuration fields expecting unique items would contain duplicates 
- 
Fixed a bug where mount overrides with a different mode would create a duplicate entry instead of overriding the original entry 
- 
Fixed a bug where build labels declared as a list wouldn't be properly parsed 
- 
Fixed a bug where the output of docker-compose configwould be invalid for some versions if the file contained custom-named external volumes
- 
Improved error handling when issuing a build command on Windows using an unsupported file version 
- 
Fixed an issue where networks with identical names would sometimes be created when running upcommands concurrently.
1.16.0 (2017-08-31)
New features
Compose file version 2.3
- 
Introduced version 2.3 of the docker-compose.ymlspecification. This version requires to be used with Docker Engine 17.06.0 or above.
- 
Added support for the targetparameter in build configurations
- 
Added support for the start_periodparameter in healthcheck configurations
Compose file version 2.x
- 
Added support for the blkio_configparameter in service definitions
- 
Added support for setting a custom name in volume definitions using the nameparameter (not available for version 2.0)
All formats
- Added new CLI flag --no-ansito suppress ANSI control characters in output
Bug Fixes
- 
Fixed a bug where nested extendsinstructions weren't resolved properly, causing "file not found" errors
- 
Fixed several issues with .dockerignoreparsing
- 
Fixed issues where logs of TTY-enabled services were being printed incorrectly and causing MemoryErrorexceptions
- 
Fixed a bug where printing application logs would sometimes be interrupted by a UnicodeEncodeErrorexception on Python 3
- 
The $character in the output ofdocker-compose configis now properly escaped
- 
Fixed a bug where running docker-compose topwould sometimes fail with an uncaught exception
- 
Fixed a bug where docker-compose pullwith the--parallelflag would return a0exit code when failing
- 
Fixed an issue where keys in deploy.resourceswere not being validated
- 
Fixed an issue where the loggingoptions in the output ofdocker-compose configwould be set tonull, an invalid value
- 
Fixed the output of the docker-compose imagescommand when an image would come from a private repository using an explicit port number
- 
Fixed the output of docker-compose configwhen a port definition used0as the value for the published port
1.15.0 (2017-07-26)
New features
Compose file version 2.2
- Added support for the networkparameter in build configurations.
Compose file version 2.1 and up
- 
The pidoption in a service's definition now supports aservice:<name>value.
- 
Added support for the storage_optparameter in in service definitions. This option is not available for the v3 format
All formats
- 
Added --quietflag todocker-compose pull, suppressing progress output
- 
Some improvements to CLI output 
Bug Fixes
- 
Volumes specified through the --volumeflag ofdocker-compose runnow complement volumes declared in the service's definition instead of replacing them
- 
Fixed a bug where using multiple Compose files would unset the scale value defined inside the Compose file. 
- 
Fixed an issue where the credHelpersentries in theconfig.jsonfile were not being honored by Compose
- 
Fixed a bug where using multiple Compose files with port declarations would cause failures in Python 3 environments 
- 
Fixed a bug where some proxy-related options present in the user's environment would prevent Compose from running 
- 
Fixed an issue where the output of docker-compose configwould be invalid if the original file usedYorNvalues
- 
Fixed an issue preventing upoperations on a previously created stack on Windows Engine.
1.14.0 (2017-06-19)
New features
Compose file version 3.3
- Introduced version 3.3 of the docker-compose.ymlspecification. This version requires to be used with Docker Engine 17.06.0 or above. Note: thecredential_specandconfigskeys only apply to Swarm services and will be ignored by Compose
Compose file version 2.2
- Added the following parameters in service definitions: cpu_count,cpu_percent,cpus
Compose file version 2.1
- Added support for build labels. This feature is also available in the 2.2 and 3.3 formats.
All formats
- 
Added shorthand -ufor--userflag indocker-compose exec
- 
Differences in labels between the Compose file and remote network will now print a warning instead of preventing redeployment. 
Bug Fixes
- 
Fixed a bug where service's dependencies were being rescaled to their default scale when running a docker-compose runcommand
- 
Fixed a bug where docker-compose rmwith the--stopflag was not behaving properly when provided with a list of services to remove
- 
Fixed a bug where cache_fromin the build section would be ignored when using more than one Compose file.
- 
Fixed a bug that prevented binding the same port to different IPs when using more than one Compose file. 
- 
Fixed a bug where override files would not be picked up by Compose if they had the .yamlextension
- 
Fixed a bug on Windows Engine where networks would be incorrectly flagged for recreation 
- 
Fixed a bug where services declaring ports would cause crashes on some versions of Python 3 
- 
Fixed a bug where the output of docker-compose configwould sometimes contain invalid port definitions
1.13.0 (2017-05-02)
Breaking changes
- docker-compose upnow resets a service's scaling to its default value. You can use the newly introduced- --scaleoption to specify a custom scale value
New features
Compose file version 2.2
- 
Introduced version 2.2 of the docker-compose.ymlspecification. This version requires to be used with Docker Engine 1.13.0 or above
- 
Added support for initin service definitions.
- 
Added support for scalein service definitions. The configuration's value can be overridden using the--scaleflag indocker-compose up. Thescalecommand is disabled for this file format
Compose file version 2.x
- Added support for optionsin theipamsection of network definitions
Bug Fixes
- 
Fixed a bug where paths provided to compose via the -foption were not being resolved properly
- 
Fixed a bug where the ext_ip::target_portnotation in the ports section was incorrectly marked as invalid
- 
Fixed an issue where the execcommand would sometimes not return control to the terminal when using the-dflag
- 
Fixed a bug where secrets were missing from the output of the configcommand for v3.2 files
- 
Fixed an issue where docker-composewould hang if no internet connection was available
- 
Fixed an issue where paths containing unicode characters passed via the -fflag were causing Compose to crash
- 
Fixed an issue where the output of docker-compose configwould be invalid if the Compose file contained external secrets
- 
Fixed a bug where using --exit-code-fromwithupwould fail if Compose was installed in a Python 3 environment
- 
Fixed a bug where recreating containers using a combination of tmpfsandvolumeswould result in an invalid config state
1.12.0 (2017-04-04)
New features
Compose file version 3.2
- 
Introduced version 3.2 of the docker-compose.ymlspecification
- 
Added support for cache_fromin thebuildsection of services
- 
Added support for the new expanded ports syntax in service definitions 
- 
Added support for the new expanded volumes syntax in service definitions 
Compose file version 2.1
- Added support for pids_limitin service definitions
Compose file version 2.0 and up
- 
Added --volumesoption todocker-compose configthat lists named volumes declared for that project
- 
Added support for mem_reservationin service definitions (2.x only)
- 
Added support for dns_optin service definitions (2.x only)
All formats
- 
Added a new docker-compose imagescommand that lists images used by the current project's containers
- 
Added a --stop(shorthand-s) option todocker-compose rmthat stops the running containers before removing them
- 
Added a --resolve-image-digestsoption todocker-compose configthat pins the image version for each service to a permanent digest
- 
Added a --exit-code-from SERVICEoption todocker-compose up. When used,docker-composewill exit on any container's exit with the code corresponding to the specified service's exit code
- 
Added a --paralleloption todocker-compose pullthat enables images for multiple services to be pulled simultaneously
- 
Added a --build-argoption todocker-compose build
- 
Added a --volume <volume_mapping>(shorthand-v) option todocker-compose runto declare runtime volumes to be mounted
- 
Added a --project-directory PATHoption todocker-composethat will affect path resolution for the project
- 
When using --abort-on-container-exitindocker-compose up, the exit code for the container that caused the abort will be the exit code of thedocker-compose upcommand
- 
Users can now configure which path separator character they want to use to separate the COMPOSE_FILEenvironment value using theCOMPOSE_PATH_SEPARATORenvironment variable
- 
Added support for port range to single port in port mappings, such as 8000-8010:80.
Bug Fixes
- 
docker-compose run --rmnow removes anonymous volumes after execution, matching the behavior ofdocker run --rm.
- 
Fixed a bug where override files containing port lists would cause a TypeError to be raised 
- 
Fixed a bug where the deploykey would be missing from the output ofdocker-compose config
- 
Fixed a bug where scaling services up or down would sometimes re-use obsolete containers 
- 
Fixed a bug where the output of docker-compose configwould be invalid if the project declared anonymous volumes
- 
Variable interpolation now properly occurs in the secretssection of the Compose file
- 
The secretssection now properly appears in the output ofdocker-compose config
- 
Fixed a bug where changes to some networks properties would not be detected against previously created networks 
- 
Fixed a bug where docker-composewould crash when trying to write into a closed pipe
- 
Fixed an issue where Compose would not pick up on the value of COMPOSE_TLS_VERSION when used in combination with command-line TLS flags 
1.11.2 (2017-02-17)
Bug Fixes
- 
Fixed a bug that was preventing secrets configuration from being loaded properly 
- 
Fixed a bug where the docker-compose configcommand would fail if the config file contained secrets definitions
- 
Fixed an issue where Compose on some linux distributions would pick up and load an outdated version of the requests library 
- 
Fixed an issue where socket-type files inside a build folder would cause docker-composeto crash when trying to build that service
- 
Fixed an issue where recursive wildcard patterns **were not being recognized in.dockerignorefiles.
1.11.1 (2017-02-09)
Bug Fixes
- Fixed a bug where the 3.1 file format was not being recognized as valid by the Compose parser
1.11.0 (2017-02-08)
New Features
Compose file version 3.1
- Introduced version 3.1 of the docker-compose.ymlspecification. This version requires Docker Engine 1.13.0 or above. It introduces support for secrets. See the documentation for more information
Compose file version 2.0 and up
- Introduced the docker-compose topcommand that displays processes running for the different services managed by Compose.
Bug Fixes
- 
Fixed a bug where extending a service defining a healthcheck dictionary would cause docker-composeto error out.
- 
Fixed an issue where the pidentry in a service definition was being ignored when using multiple Compose files.
1.10.1 (2017-02-01)
Bug Fixes
- 
Fixed an issue where presence of older versions of the docker-py package would cause unexpected crashes while running Compose 
- 
Fixed an issue where healthcheck dependencies would be lost when using multiple compose files for a project 
- 
Fixed a few issues that made the output of the configcommand invalid
- 
Fixed an issue where adding volume labels to v3 Compose files would result in an error 
- 
Fixed an issue on Windows where build context paths containing unicode characters were being improperly encoded 
- 
Fixed a bug where Compose would occasionally crash while streaming logs when containers would stop or restart 
1.10.0 (2017-01-18)
New Features
Compose file version 3.0
- Introduced version 3.0 of the docker-compose.ymlspecification. This version requires to be used with Docker Engine 1.13 or above and is specifically designed to work with thedocker stackcommands.
Compose file version 2.1 and up
- 
Healthcheck configuration can now be done in the service definition using the healthcheckparameter
- 
Containers dependencies can now be set up to wait on positive healthchecks when declared using depends_on. See the documentation for the updated syntax. Note: This feature will not be ported to version 3 Compose files.
- 
Added support for the sysctlsparameter in service definitions
- 
Added support for the userns_modeparameter in service definitions
- 
Compose now adds identifying labels to networks and volumes it creates 
Compose file version 2.0 and up
- Added support for the stop_grace_periodoption in service definitions.
Bug Fixes
- 
Colored output now works properly on Windows. 
- 
Fixed a bug where docker-compose run would fail to set up link aliases in interactive mode on Windows. 
- 
Networks created by Compose are now always made attachable (Compose files v2.1 and up). 
- 
Fixed a bug where falsy values of COMPOSE_CONVERT_WINDOWS_PATHS(0,false, empty value) were being interpreted as true.
- 
Fixed a bug where forward slashes in some .dockerignore patterns weren't being parsed correctly on Windows 
1.9.0 (2016-11-16)
Breaking changes
- When using Compose with Docker Toolbox/Machine on Windows, volume paths are
no longer converted from C:\Usersto/c/Users-style by default. To re-enable this conversion so that your volumes keep working, set the environment variableCOMPOSE_CONVERT_WINDOWS_PATHS=1. Users of Docker for Windows are not affected and do not need to set the variable.
New Features
- 
Interactive mode for docker-compose runanddocker-compose execis now supported on Windows platforms. Thedockerbinary is required to be present on the system for this feature to work.
- 
Introduced version 2.1 of the docker-compose.ymlspecification. This version requires to be used with Docker Engine 1.12 or above.- Added support for setting volume labels and network labels in
docker-compose.yml.
- Added support for the isolationparameter in service definitions.
- Added support for link-local IPs in the service networks definitions.
- Added support for shell-style inline defaults in variable interpolation.
The supported forms are ${FOO-default}(fall back if FOO is unset) and${FOO:-default}(fall back if FOO is unset or empty).
 
- Added support for setting volume labels and network labels in
- 
Added support for the group_addandoom_score_adjparameters in service definitions.
- 
Added support for the internalandenable_ipv6parameters in network definitions.
- 
Compose now defaults to using the npipeprotocol on Windows.
- 
Overriding a loggingconfiguration will now properly merge theoptionsmappings if thedrivervalues do not conflict.
Bug Fixes
- 
Fixed several bugs related to npipeprotocol support on Windows.
- 
Fixed an issue with Windows paths being incorrectly converted when using Docker on Windows Server. 
- 
Fixed a bug where an empty restartvalue would sometimes result in an exception being raised.
- 
Fixed an issue where service logs containing unicode characters would sometimes cause an error to occur. 
- 
Fixed a bug where unicode values in environment variables would sometimes raise a unicode exception when retrieved. 
- 
Fixed an issue where Compose would incorrectly detect a configuration mismatch for overlay networks. 
1.8.1 (2016-09-22)
Bug Fixes
- 
Fixed a bug where users using a credentials store were not able to access their private images. 
- 
Fixed a bug where users using identity tokens to authenticate were not able to access their private images. 
- 
Fixed a bug where an HttpHeadersentry in the docker configuration file would cause Compose to crash when trying to build an image.
- 
Fixed a few bugs related to the handling of Windows paths in volume binding declarations. 
- 
Fixed a bug where Compose would sometimes crash while trying to read a streaming response from the engine. 
- 
Fixed an issue where Compose would crash when encountering an API error while streaming container logs. 
- 
Fixed an issue where Compose would erroneously try to output logs from drivers not handled by the Engine's API. 
- 
Fixed a bug where options from the docker-machine configcommand would not be properly interpreted by Compose.
- 
Fixed a bug where the connection to the Docker Engine would sometimes fail when running a large number of services simultaneously. 
- 
Fixed an issue where Compose would sometimes print a misleading suggestion message when running the bundlecommand.
- 
Fixed a bug where connection errors would not be handled properly by Compose during the project initialization phase. 
- 
Fixed a bug where a misleading error would appear when encountering a connection timeout. 
1.8.0 (2016-06-14)
Breaking Changes
- 
As announced in 1.7.0, docker-compose rmnow removes containers created bydocker-compose runby default.
- 
Setting entrypointon a service now empties out any default command that was set on the image (i.e. anyCMDinstruction in the Dockerfile used to build it). This makes it consistent with the--entrypointflag todocker run.
New Features
- 
Added docker-compose bundle, a command that builds a bundle file to be consumed by the new Docker Stack commands in Docker 1.12.
- 
Added docker-compose push, a command that pushes service images to a registry.
- 
Compose now supports specifying a custom TLS version for interaction with the Docker Engine using the COMPOSE_TLS_VERSIONenvironment variable.
Bug Fixes
- 
Fixed a bug where Compose would erroneously try to read .envat the project's root when it is a directory.
- 
docker-compose run -e VARnow passesVARthrough from the shell to the container, as withdocker run -e VAR.
- 
Improved config merging when multiple compose files are involved for several service sub-keys. 
- 
Fixed a bug where volume mappings containing Windows drives would sometimes be parsed incorrectly. 
- 
Fixed a bug in Windows environment where volume mappings of the host's root directory would be parsed incorrectly. 
- 
Fixed a bug where docker-compose configwould output an invalid Compose file if external networks were specified.
- 
Fixed an issue where unset buildargs would be assigned a string containing 'None'instead of the expected empty value.
- 
Fixed a bug where yes/no prompts on Windows would not show before receiving input. 
- 
Fixed a bug where trying to docker-compose execon Windows without the-doption would exit with a stacktrace. This will still fail for the time being, but should do so gracefully.
- 
Fixed a bug where errors during docker-compose upwould show an unrelated stacktrace at the end of the process.
- 
docker-compose createanddocker-compose startshow more descriptive error messages when something goes wrong.
1.7.1 (2016-05-04)
Bug Fixes
- 
Fixed a bug where the output of docker-compose configfor v1 files would be an invalid configuration file.
- 
Fixed a bug where docker-compose configwould not check the validity of links.
- 
Fixed an issue where docker-compose helpwould not output a list of available commands and generic options as expected.
- 
Fixed an issue where filtering by service when using docker-compose logswould not apply for newly created services.
- 
Fixed a bug where unchanged services would sometimes be recreated in in the up phase when using Compose with Python 3. 
- 
Fixed an issue where API errors encountered during the up phase would not be recognized as a failure state by Compose. 
- 
Fixed a bug where Compose would raise a NameError because of an undefined exception name on non-Windows platforms. 
- 
Fixed a bug where the wrong version of docker-pywould sometimes be installed alongside Compose.
- 
Fixed a bug where the host value output by docker-machine config defaultwould not be recognized as valid options by thedocker-composecommand line.
- 
Fixed an issue where Compose would sometimes exit unexpectedly while reading events broadcasted by a Swarm cluster. 
- 
Corrected a statement in the docs about the location of the .envfile, which is indeed read from the current directory, instead of in the same location as the Compose file.
1.7.0 (2016-04-13)
Breaking Changes
- 
docker-compose logsno longer follows log output by default. It now matches the behaviour ofdocker logsand exits after the current logs are printed. Use-fto get the old default behaviour.
- 
Booleans are no longer allows as values for mappings in the Compose file (for keys environment,labelsandextra_hosts). Previously this was a warning. Boolean values should be quoted so they become string values.
New Features
- 
Compose now looks for a .envfile in the directory where it's run and reads any environment variables defined inside, if they're not already set in the shell environment. This lets you easily set defaults for variables used in the Compose file, or for any of theCOMPOSE_*orDOCKER_*variables.
- 
Added a --remove-orphansflag to bothdocker-compose upanddocker-compose downto remove containers for services that were removed from the Compose file.
- 
Added a --allflag todocker-compose rmto include containers created bydocker-compose run. This will become the default behavior in the next version of Compose.
- 
Added support for all the same TLS configuration flags used by the dockerclient:--tls,--tlscert,--tlskey, etc.
- 
Compose files now support the tmpfsandshm_sizeoptions.
- 
Added the --workdirflag todocker-compose run
- 
docker-compose logsnow shows logs for new containers that are created after it starts.
- 
The COMPOSE_FILEenvironment variable can now contain multiple files, separated by the host system's standard path separator (:on Mac/Linux,;on Windows).
- 
You can now specify a static IP address when connecting a service to a network with the ipv4_addressandipv6_addressoptions.
- 
Added --follow,--timestamp, and--tailflags to thedocker-compose logscommand.
- 
docker-compose up, anddocker-compose startwill now start containers in parallel where possible.
- 
docker-compose stopnow stops containers in reverse dependency order instead of all at once.
- 
Added the --buildflag todocker-compose upto force it to build a new image. It now shows a warning if an image is automatically built when the flag is not used.
- 
Added the docker-compose execcommand for executing a process in a running container.
Bug Fixes
- 
docker-compose downnow removes containers created bydocker-compose run.
- 
A more appropriate error is shown when a timeout is hit during upwhen using a tty.
- 
Fixed a bug in docker-compose downwhere it would abort if some resources had already been removed.
- 
Fixed a bug where changes to network aliases would not trigger a service to be recreated. 
- 
Fix a bug where a log message was printed about creating a new volume when it already existed. 
- 
Fixed a bug where interrupting upwould not always shut down containers.
- 
Fixed a bug where log_optandlog_driverwere not properly carried over when extending services in the v1 Compose file format.
- 
Fixed a bug where empty values for build args would cause file validation to fail. 
1.6.2 (2016-02-23)
- Fixed a bug where connecting to a TLS-enabled Docker Engine would fail with a certificate verification error.
1.6.1 (2016-02-23)
Bug Fixes
- 
Fixed a bug where recreating a container multiple times would cause the new container to be started without the previous volumes. 
- 
Fixed a bug where Compose would set the value of unset environment variables to an empty string, instead of a key without a value. 
- 
Provide a better error message when Compose requires a more recent version of the Docker API. 
- 
Add a missing config field network.aliaseswhich allows setting a network scoped alias for a service.
- 
Fixed a bug where runwould not start services listed independs_on.
- 
Fixed a bug where networksandnetwork_modewhere not merged when using extends or multiple Compose files.
- 
Fixed a bug with service aliases where the short container id alias was only contained 10 characters, instead of the 12 characters used in previous versions. 
- 
Added a missing log message when creating a new named volume. 
- 
Fixed a bug where build.argswas not merged when usingextendsor multiple Compose files.
- 
Fixed some bugs with config validation when null values or incorrect types were used instead of a mapping. 
- 
Fixed a bug where a buildsection without acontextwould show a stack trace instead of a helpful validation message.
- 
Improved compatibility with swarm by only setting a container affinity to the previous instance of a services' container when the service uses an anonymous container volume. Previously the affinity was always set on all containers. 
- 
Fixed the validation of some driver_optswould cause an error if a number was used instead of a string.
- 
Some improvements to the run.shscript used by the Compose container install option.
- 
Fixed a bug with up --abort-on-container-exitwhere Compose would exit, but would not stop other containers.
- 
Corrected the warning message that is printed when a boolean value is used as a value in a mapping. 
1.6.0 (2016-01-15)
Major Features:
- 
Compose 1.6 introduces a new format for docker-compose.ymlwhich lets you define networks and volumes in the Compose file as well as services. It also makes a few changes to the structure of some configuration options.You don't have to use it - your existing Compose files will run on Compose 1.6 exactly as they do today. Check the upgrade guide for full details: https://docs.docker.com/compose/compose-file#upgrading 
- 
Support for networking has exited experimental status and is the recommended way to enable communication between containers. If you use the new file format, your app will use networking. If you aren't ready yet, just leave your Compose file as it is and it'll continue to work just the same. By default, you don't have to configure any networks. In fact, using networking with Compose involves even less configuration than using links. Consult the networking guide for how to use it: https://docs.docker.com/compose/networking The experimental flags --x-networkingand--x-network-driver, introduced in Compose 1.5, have been removed.
- 
You can now pass arguments to a build if you're using the new file format: build: context: . args: buildno: 1
- 
You can now specify both a buildand animagekey if you're using the new file format.docker-compose buildwill build the image and tag it with the name you've specified, whiledocker-compose pullwill attempt to pull it.
- 
There's a new eventscommand for monitoring container events from the application, much likedocker events. This is a good primitive for building tools on top of Compose for performing actions when particular things happen, such as containers starting and stopping.
- 
There's a new depends_onoption for specifying dependencies between services. This enforces the order of startup, and ensures that when you rundocker-compose up SERVICEon a service with dependencies, those are started as well.
New Features:
- 
Added a new command configwhich validates and prints the Compose configuration after interpolating variables, resolving relative paths, and merging multiple files andextends.
- 
Added a new command createfor creating containers without starting them.
- 
Added a new command downto stop and remove all the resources created byupin a single command.
- 
Added support for the cpu_quotaconfiguration option.
- 
Added support for the stop_signalconfiguration option.
- 
Commands start,restart,pause, andunpausenow exit with an error status code if no containers were modified.
- 
Added a new --abort-on-container-exitflag toupwhich causesupto stop all container and exit once the first container exits.
- 
Removed support for FIG_FILE,FIG_PROJECT_NAME, and no longer readsfig.ymlas a default Compose file location.
- 
Removed the migrate-to-labelscommand.
- 
Removed the --allow-insecure-sslflag.
Bug Fixes:
- 
Fixed a validation bug that prevented the use of a range of ports in the exposefield.
- 
Fixed a validation bug that prevented the use of arrays in the entrypointfield if they contained duplicate entries.
- 
Fixed a bug that caused ulimitsto be ignored when used withextends.
- 
Fixed a bug that prevented ipv6 addresses in extra_hosts.
- 
Fixed a bug that caused extendsto be ignored when included from multiple Compose files.
- 
Fixed an incorrect warning when a container volume was defined in the Compose file. 
- 
Fixed a bug that prevented the force shutdown behaviour of upandlogs.
- 
Fixed a bug that caused Noneto be printed as the network driver name when the default network driver was used.
- 
Fixed a bug where using the string form of dnsordns_searchwould cause an error.
- 
Fixed a bug where a container would be reported as "Up" when it was in the restarting state. 
- 
Fixed a confusing error message when DOCKER_CERT_PATH was not set properly. 
- 
Fixed a bug where attaching to a container would fail if it was using a non-standard logging driver (or none at all). 
1.5.2 (2015-12-03)
- 
Fixed a bug which broke the use of environmentandenv_filewithextends, and caused environment keys without values to have aNonevalue, instead of a value from the host environment.
- 
Fixed a regression in 1.5.1 that caused a warning about volumes to be raised incorrectly when containers were recreated. 
- 
Fixed a bug which prevented building a Dockerfilethat usedADD <url>
- 
Fixed a bug with docker-compose restartwhich prevented it from starting stopped containers.
- 
Fixed handling of SIGTERM and SIGINT to properly stop containers 
- 
Add support for using a url as the value of build
- 
Improved the validation of the exposeoption
1.5.1 (2015-11-12)
- 
Add the --force-rmoption tobuild.
- 
Add the ulimitoption for services in the Compose file.
- 
Fixed a bug where upwould error with "service needs to be built" if a service changed from usingimageto usingbuild.
- 
Fixed a bug that would cause incorrect output of parallel operations on some terminals. 
- 
Fixed a bug that prevented a container from being recreated when the mode of a volumes_fromwas changed.
- 
Fixed a regression in 1.5.0 where non-utf-8 unicode characters would cause uporlogsto crash.
- 
Fixed a regression in 1.5.0 where Compose would use a success exit status code when a command fails due to an HTTP timeout communicating with the docker daemon. 
- 
Fixed a regression in 1.5.0 where namewas being accepted as a valid service option which would override the actual name of the service.
- 
When using --x-networkingCompose no longer sets the hostname to the container name.
- 
When using --x-networkingCompose will only create the default network if at least one container is using the network.
- 
When printings logs during uporlogs, flush the output buffer after each line to prevent buffering issues from hiding logs.
- 
Recreate a container if one of its dependencies is being created. Previously a container was only recreated if it's dependencies already existed, but were being recreated as well. 
- 
Add a warning when a volumein the Compose file is being ignored and masked by a container volume from a previous container.
- 
Improve the output of pullwhen run without a tty.
- 
When using multiple Compose files, validate each before attempting to merge them together. Previously invalid files would result in not helpful errors. 
- 
Allow dashes in keys in the environmentservice option.
- 
Improve validation error messages by including the filename as part of the error message. 
1.5.0 (2015-11-03)
Breaking changes
With the introduction of variable substitution support in the Compose file, any
Compose file that uses an environment variable ($VAR or ${VAR}) in the command:
or entrypoint: field will break.
Previously these values were interpolated inside the container, with a value from the container environment. In Compose 1.5.0, the values will be interpolated on the host, with a value from the host environment.
To migrate a Compose file to 1.5.0, escape the variables with an extra $
(ex: $$VAR or $${VAR}).  See
https://github.com/docker/compose/blob/8cc8e61/docs/compose-file.md#variable-substitution
Major features
- 
Compose is now available for Windows. 
- 
Environment variables can be used in the Compose file. See https://github.com/docker/compose/blob/8cc8e61/docs/compose-file.md#variable-substitution 
- 
Multiple compose files can be specified, allowing you to override settings in the default Compose file. See https://github.com/docker/compose/blob/8cc8e61/docs/reference/docker-compose.md for more details. 
- 
Compose now produces better error messages when a file contains invalid configuration. 
- 
upnow waits for all services to exit before shutting down, rather than shutting down as soon as one container exits.
- 
Experimental support for the new docker networking system can be enabled with the --x-networkingflag. Read more here: https://github.com/docker/docker/blob/8fee1c20/docs/userguide/dockernetworks.md
New features
- 
You can now optionally pass a mode to volumes_from. For example,volumes_from: ["servicename:ro"].
- 
Since Docker now lets you create volumes with names, you can refer to those volumes by name in docker-compose.yml. For example,volumes: ["mydatavolume:/data"]will mount the volume namedmydatavolumeat the path/datainside the container.If the first component of an entry in volumesstarts with a.,/or~, it is treated as a path and expansion of relative paths is performed as necessary. Otherwise, it is treated as a volume name and passed straight through to Docker.Read more on named volumes and volume drivers here: https://github.com/docker/docker/blob/244d9c33/docs/userguide/dockervolumes.md 
- 
docker-compose build --pullinstructs Compose to pull the base image for each Dockerfile before building.
- 
docker-compose pull --ignore-pull-failuresinstructs Compose to continue if it fails to pull a single service's image, rather than aborting.
- 
You can now specify an IPC namespace in docker-compose.ymlwith theipcoption.
- 
Containers created by docker-compose runcan now be named with the--nameflag.
- 
If you install Compose with pip or use it as a library, it now works with Python 3. 
- 
imagenow supports image digests (in addition to ids and tags). For example,image: "busybox@sha256:38a203e1986cf79639cfb9b2e1d6e773de84002feea2d4eb006b52004ee8502d"
- 
portsnow supports ranges of ports. For example,ports: - "3000-3005" - "9000-9001:8000-8001"
- 
docker-compose runnow supports a-p|--publishparameter, much likedocker run -p, for publishing specific ports to the host.
- 
docker-compose pauseanddocker-compose unpausehave been implemented, analogous todocker pauseanddocker unpause.
- 
When using extendsto copy configuration from another service in the same Compose file, you can omit thefileoption.
- 
Compose can be installed and run as a Docker image. This is an experimental feature. 
Bug fixes
- 
All values for the log_driveroption which are supported by the Docker daemon are now supported by Compose.
- 
docker-compose buildcan now be run successfully against a Swarm cluster.
1.4.2 (2015-09-22)
- Fixed a regression in the 1.4.1 release that would cause docker-compose upwithout the-doption to exit immediately.
1.4.1 (2015-09-10)
Bug fixes
- Some configuration changes (notably changes to links,volumes_from, andnet) were not properly triggering a container recreate as part ofdocker-compose up.
- docker-compose up <service>was showing logs for all services instead of just the specified services.
- Containers with custom container names were showing up in logs as
service_numberinstead of their custom container name.
- When scaling a service sometimes containers would be recreated even when the configuration had not changed.
1.4.0 (2015-08-04)
- 
By default, docker-compose upnow only recreates containers for services whose configuration has changed since they were created. This should result in a dramatic speed-up for many applications.The experimental --x-smart-recreateflag which introduced this feature in Compose 1.3.0 has been removed, and a--force-recreateflag has been added for when you want to recreate everything.
- 
Several of Compose's commands - scale,stop,killandrm- now perform actions on multiple containers in parallel, rather than in sequence, which will run much faster on larger applications.
- 
You can now specify a custom name for a service's container with container_name. Because Docker container names must be unique, this means you can't scale the service beyond one container.
- 
You no longer have to specify a fileoption when usingextends- it will default to the current file.
- 
Service names can now contain dots, dashes and underscores. 
- 
Compose can now read YAML configuration from standard input, rather than from a file, by specifying -as the filename. This makes it easier to generate configuration dynamically:$ echo 'redis: {"image": "redis"}' | docker-compose --file - up
- 
There's a new docker-compose versioncommand which prints extended information about Compose's bundled dependencies.
- 
docker-compose.ymlnow supportslog_optas well aslog_driver, allowing you to pass extra configuration to a service's logging driver.
- 
docker-compose.ymlnow supportsmemswap_limit, similar todocker run --memory-swap.
- 
When mounting volumes with the volumesoption, you can now pass in any mode supported by the daemon, not just:roor:rw. For example, SELinux users can pass:zor:Z.
- 
You can now specify a custom volume driver with the volume_driveroption indocker-compose.yml, much likedocker run --volume-driver.
- 
A bug has been fixed where Compose would fail to pull images from private registries serving plain (unsecured) HTTP. The --allow-insecure-sslflag, which was previously used to work around this issue, has been deprecated and now has no effect.
- 
A bug has been fixed where docker-compose buildwould fail if the build depended on a private Hub image or an image from a private registry.
- 
A bug has been fixed where Compose would crash if there were containers which the Docker daemon had not finished removing. 
- 
Two bugs have been fixed where Compose would sometimes fail with a "Duplicate bind mount" error, or fail to attach volumes to a container, if there was a volume path specified in docker-compose.ymlwith a trailing slash.
Thanks @mnowster, @dnephin, @ekristen, @funkyfuture, @jeffk and @lukemarsden!
1.3.3 (2015-07-15)
Regression fixes
- When stopping containers gracefully, Compose was setting the timeout to 0, effectively forcing a SIGKILL every time.
- Compose would sometimes crash depending on the formatting of container data returned from the Docker API.
1.3.2 (2015-07-14)
Bug fixes
- When there were one-off containers created by running docker-compose runon an older version of Compose,docker-compose runwould fail with a name collision. Compose now shows an error if you have leftover containers of this type lying around, and tells you how to remove them.
- Compose was not reading Docker authentication config files created in the new location, ~/docker/config.json, and authentication against private registries would therefore fail.
- When a container had a pseudo-TTY attached, its output in docker-compose upwould be truncated.
- docker-compose up --x-smart-recreatewould sometimes fail when an image tag was updated.
- docker-compose upwould sometimes create two containers with the same numeric suffix.
- docker-compose rmand- docker-compose pswould sometimes list services that aren't part of the current project (though no containers were erroneously removed).
- Some docker-composecommands would not show an error if invalid service names were passed in.
Thanks @dano, @josephpage, @kevinsimper, @lieryan, @phemmer, @soulrebel and @sschepens!
1.3.1 (2015-06-21)
Bug fixes
- docker-compose buildwould always attempt to pull the base image before building.
- docker-compose help migrate-to-labelsfailed with an error.
- If no network mode was specified, Compose would set it to "bridge", rather than allowing the Docker daemon to use its configured default network mode.
1.3.0 (2015-06-18)
Important notes
- 
This release contains breaking changes, and you will need to either remove or migrate your existing containers before running your app - see the upgrading section of the install docs for details. 
- 
Compose now requires Docker 1.6.0 or later. 
Improvements
- 
Compose now uses container labels, rather than names, to keep track of containers. This makes Compose both faster and easier to integrate with your own tools. 
- 
Compose no longer uses "intermediate containers" when recreating containers for a service. This makes docker-compose upless complex and more resilient to failure.
New features
- 
docker-compose uphas an experimental new behaviour: it will only recreate containers for services whose configuration has changed indocker-compose.yml. This will eventually become the default, but for now you can take it for a spin:$ docker-compose up --x-smart-recreate
- 
When invoked in a subdirectory of a project, docker-composewill now climb up through parent directories until it finds adocker-compose.yml.
Several new configuration keys have been added to docker-compose.yml:
- dockerfile, like- docker build --file, lets you specify an alternate Dockerfile to use with- build.
- labels, like- docker run --labels, lets you add custom metadata to containers.
- extra_hosts, like- docker run --add-host, lets you add entries to a container's- /etc/hostsfile.
- pid: host, like- docker run --pid=host, lets you reuse the same PID namespace as the host machine.
- cpuset, like- docker run --cpuset-cpus, lets you specify which CPUs to allow execution in.
- read_only, like- docker run --read-only, lets you mount a container's filesystem as read-only.
- security_opt, like- docker run --security-opt, lets you specify security options.
- log_driver, like- docker run --log-driver, lets you specify a log driver.
Bug fixes
- The output of docker-compose runwas sometimes truncated, especially when running under Jenkins.
- A service's volumes would sometimes not update after volume configuration was changed in docker-compose.yml.
- Authenticating against third-party registries would sometimes fail.
- docker-compose run --rmwould fail to remove the container if the service had a- restartpolicy in place.
- docker-compose scalewould refuse to scale a service beyond 1 container if it exposed a specific port number on the host.
- Compose would refuse to create multiple volume entries with the same host path.
Thanks @ahromis, @albers, @aleksandr-vin, @antoineco, @ccverak, @chernjie, @dnephin, @edmorley, @fordhurley, @josephpage, @KyleJamesWalker, @lsowen, @mchasal, @noironetworks, @sdake, @sdurrheimer, @sherter, @stephenlawrence, @thaJeztah, @thieman, @turtlemonvh, @twhiteman, @vdemeester, @xuxinkun and @zwily!
1.2.0 (2015-04-16)
- 
docker-compose.ymlnow supports anextendsoption, which enables a service to inherit configuration from another service in another configuration file. This is really good for sharing common configuration between apps, or for configuring the same app for different environments. Here's the documentation.
- 
When using Compose with a Swarm cluster, containers that depend on one another will be co-scheduled on the same node. This means that most Compose apps will now work out of the box, as long as they don't use build.
- 
Repeated invocations of docker-compose upwhen using Compose with a Swarm cluster now work reliably.
- 
Directories passed to build, filenames passed toenv_fileand volume host paths passed tovolumesare now treated as relative to the directory of the configuration file, not the directory thatdocker-composeis being run in. In the majority of cases, those are the same, but if you use the-f|--fileargument to specify a configuration file in another directory, this is a breaking change.
- 
A service can now share another service's network namespace with net: container:<service>.
- 
volumes_fromandnet: container:<service>entries are taken into account when resolving dependencies, sodocker-compose up <service>will correctly start all dependencies of<service>.
- 
docker-compose runnow accepts a--userargument to specify a user to run the command as, just likedocker run.
- 
The up,stopandrestartcommands now accept a--timeout(or-t) argument to specify how long to wait when attempting to gracefully stop containers, just likedocker stop.
- 
docker-compose rmnow accepts-fas a shorthand for--force, just likedocker rm.
Thanks, @abesto, @albers, @alunduil, @dnephin, @funkyfuture, @gilclark, @IanVS, @KingsleyKelly, @knutwalker, @thaJeztah and @vmalloc!
1.1.0 (2015-02-25)
Fig has been renamed to Docker Compose, or just Compose for short. This has several implications for you:
- The command you type is now docker-compose, notfig.
- You should rename your fig.yml to docker-compose.yml.
- If you’re installing via PyPI, the package is now docker-compose, so install it withpip install docker-compose.
Besides that, there’s a lot of new stuff in this release:
- 
We’ve made a few small changes to ensure that Compose will work with Swarm, Docker’s new clustering tool (https://github.com/docker/swarm). Eventually you'll be able to point Compose at a Swarm cluster instead of a standalone Docker host and it’ll run your containers on the cluster with no extra work from you. As Swarm is still developing, integration is rough and lots of Compose features don't work yet. 
- 
docker-compose runnow has a--service-portsflag for exposing ports on the given service. This is useful for running your webapp with an interactive debugger, for example.
- 
You can now link to containers outside your app with the external_linksoption in docker-compose.yml.
- 
You can now prevent docker-compose upfrom automatically building images with the--no-buildoption. This will make fewer API calls and run faster.
- 
If you don’t specify a tag when using the imagekey, Compose will default to thelatesttag, rather than pulling all tags.
- 
docker-compose killnow supports the-sflag, allowing you to specify the exact signal you want to send to a service’s containers.
- 
docker-compose.yml now has an env_filekey, analogous todocker run --env-file, letting you specify multiple environment variables in a separate file. This is great if you have a lot of them, or if you want to keep sensitive information out of version control.
- 
docker-compose.yml now supports the dns_search,cap_add,cap_drop,cpu_sharesandrestartoptions, analogous todocker run’s--dns-search,--cap-add,--cap-drop,--cpu-sharesand--restartoptions.
- 
Compose now ships with Bash tab completion - see the installation and usage docs at https://github.com/docker/compose/blob/1.1.0/docs/completion.md 
- 
A number of bugs have been fixed - see the milestone for details: https://github.com/docker/compose/issues?q=milestone%3A1.1.0+ 
Thanks @dnephin, @squebe, @jbalonso, @raulcd, @benlangfield, @albers, @ggtools, @bersace, @dtenenba, @petercv, @drewkett, @TFenby, @paulRbr, @Aigeruth and @salehe!
1.0.1 (2014-11-04)
- Added an --allow-insecure-ssloption to allowfig up,fig runandfig pullto pull from insecure registries.
- Fixed fig runnot showing output in Jenkins.
- Fixed a bug where Fig couldn't build Dockerfiles with ADD statements pointing at URLs.
1.0.0 (2014-10-16)
The highlights:
- 
Fig has joined Docker. Fig will continue to be maintained, but we'll also be incorporating the best bits of Fig into Docker itself. This means the GitHub repository has moved to https://github.com/docker/fig and our IRC channel is now #docker-fig on Freenode. 
- 
Fig can be used with the official Docker OS X installer. Boot2Docker will mount the home directory from your host machine so volumes work as expected. 
- 
Fig supports Docker 1.3. 
- 
It is now possible to connect to the Docker daemon using TLS by using the DOCKER_CERT_PATHandDOCKER_TLS_VERIFYenvironment variables.
- 
There is a new fig portcommand which outputs the host port binding of a service, in a similar way todocker port.
- 
There is a new fig pullcommand which pulls the latest images for a service.
- 
There is a new fig restartcommand which restarts a service's containers.
- 
Fig creates multiple containers in service by appending a number to the service name. For example, db_1,db_2. As a convenience, Fig will now give the first container an alias of the service name. For example,db.This link alias is also a valid hostname and added to /etc/hostsso you can connect to linked services using their hostname. For example, instead of resolving the environment variablesDB_PORT_5432_TCP_ADDRandDB_PORT_5432_TCP_PORT, you could just use the hostnamedband port5432directly.
- 
Volume definitions now support romode, expanding~and expanding environment variables.
- 
.dockerignoreis supported when building.
- 
The project name can be set with the FIG_PROJECT_NAMEenvironment variable.
- 
The --envand--entrypointoptions have been added tofig run.
- 
The Fig binary for Linux is now linked against an older version of glibc so it works on CentOS 6 and Debian Wheezy. 
Other things:
- fig psnow works on Jenkins and makes fewer API calls to the Docker daemon.
- --verbosedisplays more useful debugging output.
- When starting a service where volumes_frompoints to a service without any containers running, that service will now be started.
- Lots of docs improvements. Notably, environment variables are documented and official repositories are used throughout.
Thanks @dnephin, @d11wtq, @marksteve, @rubbish, @jbalonso, @timfreund, @alunduil, @mieciu, @shuron, @moss, @suzaku and @chmouel! Whew.
0.5.2 (2014-07-28)
- Added a --no-cacheoption tofig build, which bypasses the cache just likedocker build --no-cache.
- Fixed the dns:fig.yml option, which was causing fig to error out.
- Fixed a bug where fig couldn't start under Python 2.6.
- Fixed a log-streaming bug that occasionally caused fig to exit.
Thanks @dnephin and @marksteve!
0.5.1 (2014-07-11)
- If a service has a command defined, fig run [service]with no further arguments will run it.
- The project name now defaults to the directory containing fig.yml, not the current working directory (if they're different)
- volumes_fromnow works properly with containers as well as services
- Fixed a race condition when recreating containers in fig up
Thanks @ryanbrainard and @d11wtq!
0.5.0 (2014-07-11)
- 
Fig now starts links when you run fig runorfig up.For example, if you have a webservice which depends on adbservice,fig run web ...will start thedbservice.
- 
Environment variables can now be resolved from the environment that Fig is running in. Just specify it as a blank variable in your fig.ymland, if set, it'll be resolved:environment: RACK_ENV: development SESSION_SECRET:
- 
volumes_fromis now supported infig.yml. All of the volumes from the specified services and containers will be mounted:volumes_from: - service_name - container_name
- 
A host address can now be specified in ports:ports: - "0.0.0.0:8000:8000" - "127.0.0.1:8001:8001"
- 
The netandworkdiroptions are now supported infig.yml.
- 
The hostnameoption now works in the same way as the Docker CLI, splitting out into adomainnameoption.
- 
TTY behaviour is far more robust, and resizes are supported correctly. 
- 
Load YAML files safely. 
Thanks to @d11wtq, @ryanbrainard, @rail44, @j0hnsmith, @binarin, @Elemecca, @mozz100 and @marksteve for their help with this release!
0.4.2 (2014-06-18)
- Fix various encoding errors when using fig run,fig upandfig build.
0.4.1 (2014-05-08)
- Add support for Docker 0.11.0. (Thanks @marksteve!)
- Make project name configurable. (Thanks @jefmathiot!)
- Return correct exit code from fig run.
0.4.0 (2014-04-29)
- Support Docker 0.9 and 0.10
- Display progress bars correctly when pulling images (no more ski slopes)
- fig upnow stops all services when any container exits
- Added support for the privilegedconfig option in fig.yml (thanks @kvz!)
- Shortened and aligned log prefixes in fig upoutput
- Only containers started with fig runlink back to their own service
- Handle UTF-8 correctly when streaming fig build/run/upoutput (thanks @mauvm and @shanejonas!)
- Error message improvements
0.3.2 (2014-03-05)
- Added an --rmoption tofig run. (Thanks @marksteve!)
- Added an exposeoption tofig.yml.
0.3.1 (2014-03-04)
- Added contribution instructions. (Thanks @kvz!)
- Fixed fig rmthrowing an error.
- Fixed a bug in fig pson Docker 0.8.1 when there is a container with no command.
0.3.0 (2014-03-03)
- We now ship binaries for OS X and Linux. No more having to install with Pip!
- Add -fflag to specify alternatefig.ymlfiles
- Add support for custom link names
- Fix a bug where recreating would sometimes hang
- Update docker-py to support Docker 0.8.0.
- Various documentation improvements
- Various error message improvements
Thanks @marksteve, @Gazler and @teozkr!
0.2.2 (2014-02-17)
- Resolve dependencies using Cormen/Tarjan topological sort
- Fix fig upnot printing log output
- Stop containers in reverse order to starting
- Fix scale command not binding ports
Thanks to @barnybug and @dustinlacewell for their work on this release.
0.2.1 (2014-02-04)
- General improvements to error reporting (#77, #79)
0.2.0 (2014-01-31)
- Link services to themselves so run commands can access the running service. (#67)
- Much better documentation.
- Make service dependency resolution more reliable. (#48)
- Load Fig configurations with a .yamlextension. (#58)
Big thanks to @cameronmaske, @mrchrisadams and @damianmoore for their help with this release.
0.1.4 (2014-01-27)
- Add a link alias without the project name. This makes the environment variables a little shorter: REDIS_1_PORT_6379_TCP_ADDR. (#54)
0.1.3 (2014-01-23)
- Fix ports sometimes being configured incorrectly. (#46)
- Fix log output sometimes not displaying. (#47)
0.1.2 (2014-01-22)
- Add -Toption tofig runto disable pseudo-TTY. (#34)
- Fix fig uprequiring the ubuntu image to be pulled to recreate containers. (#33) Thanks @cameronmaske!
- Improve reliability, fix arrow keys and fix a race condition in fig run. (#34, #39, #40)
0.1.1 (2014-01-17)
- Fix bug where ports were not exposed correctly (#29). Thanks @dustinlacewell!
0.1.0 (2014-01-16)
- Containers are recreated on each fig up, ensuring config is up-to-date withfig.yml(#2)
- Add fig scalecommand (#9)
- Use DOCKER_HOSTenvironment variable to find Docker daemon, for consistency with the official Docker client (was previouslyDOCKER_URL) (#19)
- Truncate long commands in fig ps(#18)
- Fill out CLI help banners for commands (#15, #16)
- Show a friendlier error when fig.ymlis missing (#4)
- Fix bug with fig buildlogging (#3)
- Fix bug where builds would time out if a step took a long time without generating output (#6)
- Fix bug where streaming container output over the Unix socket raised an error (#7)
Big thanks to @tomstuart, @EnTeQuAk, @schickling, @aronasorman and @GeoffreyPlitt.
0.0.2 (2014-01-02)
- Improve documentation
- Try to connect to Docker on tcp://localdocker:4243and a UNIX socket in addition tolocalhost.
- Improve fig upbehaviour
- Add confirmation prompt to fig rm
- Add fig buildcommand
0.0.1 (2013-12-20)
Initial release.