Releases: docker/compose
1.2.0 RC4
This is a release candidate for Compose 1.2.0. To try it out, run the following commands:
curl -L https://github.com/docker/compose/releases/download/1.2.0rc4/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
Optionally, you can also install command completion for the bash shell.
On top of the changes listed below for RC1-RC3, the following bugs have been fixed:
- Environment variables and the user's home directory (~) were not expanding properly in
volumeshost paths.
Here are the changes for RC3:
- When copying a service's configuration with
extends,imageandbuildcould come into conflict, resulting in an error, as it makes no sense to have both defined. Each now overwrites the other: if a service withimagedefined is extended andbuildis added, theimageentry will be removed. - When copying a service's configuration with
extends, if both services defined a multi-value option such asportsordns, the original value would be completely discarded. They are now concatenated instead. - When a relative path is supplied to
build, it is 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.
Here are the changes for RC2:
- A bug has been fixed where containers were being created with blank entries for "Dns" and "DnsSearch", causing DNS lookups from within a container to fail.
Here are the changes for RC1:
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. - Filenames in
env_fileand volume host paths involumesare 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>.- Problems with authentication when using images from third-party registries have been fixed.
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, @moysesb, @thaJeztah and @vmalloc!
1.2.0 RC3
This is a release candidate for Compose 1.2.0. To try it out, run the following commands:
curl -L https://github.com/docker/compose/releases/download/1.2.0rc3/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
Optionally, you can also install command completion for the bash shell.
On top of the changes listed below for RC1 and RC2, the following bugs have been fixed:
- When copying a service's configuration with
extends,imageandbuildcould come into conflict, resulting in an error, as it makes no sense to have both defined. Each now overwrites the other: if a service withimagedefined is extended andbuildis added, theimageentry will be removed. - When copying a service's configuration with
extends, if both services defined a multi-value option such asportsordns, the original value would be completely discarded. They are now concatenated instead. - When a relative path is supplied to
build, it is 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.
Here are the changes for RC2:
- A bug has been fixed where containers were being created with blank entries for "Dns" and "DnsSearch", causing DNS lookups from within a container to fail.
Here are the changes for RC1:
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. - Filenames in
env_fileand volume host paths involumesare 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>.- Problems with authentication when using images from third-party registries have been fixed.
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, @moysesb, @thaJeztah and @vmalloc!
1.2.0 RC2
This is a release candidate for Compose 1.2.0. To try it out, run the following commands:
curl -L https://github.com/docker/compose/releases/download/1.2.0rc2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
Optionally, you can also install command completion for the bash shell.
- On top of the changes listed below for RC1, a bug has been fixed where containers were being created with blank entries for "Dns" and "DnsSearch", causing DNS lookups from within a container to fail.
Here are the changes for RC1:
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. - Filenames in
env_fileand volume host paths involumesare 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>.- Problems with authentication when using images from third-party registries have been fixed.
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.2.0 RC1
This is a release candidate for Compose 1.2.0. To try it out, run the following commands:
curl -L https://github.com/docker/compose/releases/download/1.2.0rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
Optionally, you can also install command completion for the bash shell.
Here's what's new:
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. - Filenames in
env_fileand volume host paths involumesare 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>.- Problems with authentication when using images from third-party registries have been fixed.
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
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.ymltodocker-compose.yml. - If you’re installing via PyPi, the package is now
docker-compose, so install it withpip install docker-compose.
To install Compose, run the following commands:
curl -L https://github.com/docker/compose/releases/download/1.1.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
Besides that, there’s a lot of new stuff in this release:
docker-compose runnow has a--service-portsflag for exposing ports on the given service. This is useful for e.g. running your webapp with an interactive debugger.- 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
- 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. Check the integration doc to see how it's progressing.
- 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, @benlangfeld, @albers, @ggtools, @bersace, @dtenenba, @petercv, @drewkett, @TFenby, @paulRbr, @Aigeruth and @salehe!
1.1.0-rc2
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.
- The PyPi package is now
docker-compose.
This is a release candidate for Docker Compose 1.1.0. To try it out, install via curl:
curl -L https://github.com/docker/fig/releases/download/1.1.0-rc2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose; chmod +x /usr/local/bin/docker-compose
(If you install via PyPi, use pip install docker-compose==1.1.0-rc2.)
On top of the changelog for 1.1.0-rc1 (see below), the following bugs have been fixed:
- When an environment variables file specified with
env_filedoesn't exist, Compose was showing a stack trace instead of a helpful error. - Configuration files using the old name (
fig.yml) were not being read unless explicitly specified withdocker-compose -f. Compose now reads them and prints a deprecation warning. - Bash tab completion now reads
fig.ymlif it's present.
Here's the changelog for 1.1.0-rc1:
- 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 e.g. running your webapp with an interactive debugger.- 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_dropandrestartoptions, analogous todocker run’s--dns-search,--cap-add,--cap-dropand--restartoptions. - Compose now ships with Bash tab completion - see the installation and usage docs at https://github.com/docker/fig/blob/1.1.0-rc1/docs/completion.md
- A number of bugs have been fixed - see the milestone for details: https://github.com/docker/fig/issues?q=milestone%3A1.1.0+
1.1.0-rc1
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.
- The PyPi package is now
docker-compose.
This is a release candidate for Docker Compose 1.1.0. To try it out, install via curl:
curl -L https://github.com/docker/fig/releases/download/1.1.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose; chmod +x /usr/local/bin/docker-compose
(If you install via PyPi, use pip install docker-compose==1.1.0-rc1.)
Besides the rename, there’s a lot of new stuff:
- 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 e.g. running your webapp with an interactive debugger.- 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_dropandrestartoptions, analogous todocker run’s--dns-search,--cap-add,--cap-dropand--restartoptions. - A number of bugs have been fixed - see the milestone for details: https://github.com/docker/fig/issues?q=milestone%3A1.1.0+
1.0.1
Install/upgrade instructions here.
- 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
Install/upgrade instructions here.
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 (e.g.
db_1,db_2, etc). As a convenience, Fig will now give the first container an alias of the service name (e.g.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
Install/upgrade instructions here.
- 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!