github.com/hustcat/docker@v1.3.3-0.20160314103604-901c67a8eeab/CHANGELOG.md (about) 1 # Changelog 2 3 Items starting with `DEPRECATE` are important deprecation notices. For more 4 information on the list of deprecated flags and APIs please have a look at 5 https://docs.docker.com/misc/deprecated/ where target removal dates can also 6 be found. 7 8 ## 1.10.2 (2016-02-22) 9 10 ### Runtime 11 12 - Prevent systemd from deleting containers' cgroups when its configuration is reloaded [#20518](https://github.com/docker/docker/pull/20518) 13 - Fix SELinux issues by disregarding `--read-only` when mounting `/dev/mqueue` [#20333](https://github.com/docker/docker/pull/20333) 14 - Fix chown permissions used during `docker cp` when userns is used [#20446](https://github.com/docker/docker/pull/20446) 15 - Fix configuration loading issue with all booleans defaulting to `true` [#20471](https://github.com/docker/docker/pull/20471) 16 - Fix occasional panic with `docker logs -f` [#20522](https://github.com/docker/docker/pull/20522) 17 18 ### Distribution 19 20 - Keep layer reference if deletion failed to avoid a badly inconsistent state [#20513](https://github.com/docker/docker/pull/20513) 21 - Handle gracefully a corner case when canceling migration [#20372](https://github.com/docker/docker/pull/20372) 22 - Fix docker import on compressed data [#20367](https://github.com/docker/docker/pull/20367) 23 - Fix tar-split files corruption during migration that later cause docker push and docker save to fail [#20458](https://github.com/docker/docker/pull/20458) 24 25 ### Networking 26 27 - Fix daemon crash if embedded DNS is sent garbage [#20510](https://github.com/docker/docker/pull/20510) 28 29 ### Volumes 30 31 - Fix issue with multiple volume references with same name [#20381](https://github.com/docker/docker/pull/20381) 32 33 ### Security 34 35 - Fix potential cache corruption and delegation conflict issues [#20523](https://github.com/docker/docker/pull/20523) 36 37 ## 1.10.1 (2016-02-11) 38 39 ### Runtime 40 41 * Do not stop daemon on migration hard failure [#20156](https://github.com/docker/docker/pull/20156) 42 - Fix various issues with migration to content-addressable images [#20058](https://github.com/docker/docker/pull/20058) 43 - Fix ZFS permission bug with user namespaces [#20045](https://github.com/docker/docker/pull/20045) 44 - Do not leak /dev/mqueue from the host to all containers, keep it container-specific [#19876](https://github.com/docker/docker/pull/19876) [#20133](https://github.com/docker/docker/pull/20133) 45 - Fix `docker ps --filter before=...` to not show stopped containers without providing `-a` flag [#20135](https://github.com/docker/docker/pull/20135) 46 47 ### Security 48 49 - Fix issue preventing docker events to work properly with authorization plugin [#20002](https://github.com/docker/docker/pull/20002) 50 51 ### Distribution 52 53 * Add additional verifications and prevent from uploading invalid data to registries [#20164](https://github.com/docker/docker/pull/20164) 54 - Fix regression preventing uppercase characters in image reference hostname [#20175](https://github.com/docker/docker/pull/20175) 55 56 ### Networking 57 58 - Fix embedded DNS for user-defined networks in the presence of firewalld [#20060](https://github.com/docker/docker/pull/20060) 59 - Fix issue where removing a network during shutdown left Docker inoperable [#20181](https://github.com/docker/docker/issues/20181) [#20235](https://github.com/docker/docker/issues/20235) 60 - Embedded DNS is now able to return compressed results [#20181](https://github.com/docker/docker/issues/20181) 61 - Fix port-mapping issue with `userland-proxy=false` [#20181](https://github.com/docker/docker/issues/20181) 62 63 ### Logging 64 65 - Fix bug where tcp+tls protocol would be rejected [#20109](https://github.com/docker/docker/pull/20109) 66 67 ### Volumes 68 69 - Fix issue whereby older volume drivers would not receive volume options [#19983](https://github.com/docker/docker/pull/19983) 70 71 ### Misc 72 73 - Remove TasksMax from Docker systemd service [#20167](https://github.com/docker/docker/pull/20167) 74 75 ## 1.10.0 (2016-02-04) 76 77 **IMPORTANT**: Docker 1.10 uses a new content-addressable storage for images and layers. 78 A migration is performed the first time docker is run, and can take a significant amount of time depending on the number of images present. 79 Refer to this page on the wiki for more information: https://github.com/docker/docker/wiki/Engine-v1.10.0-content-addressability-migration 80 We also released a cool migration utility that enables you to perform the migration before updating to reduce downtime. 81 Engine 1.10 migrator can be found on Docker Hub: https://hub.docker.com/r/docker/v1.10-migrator/ 82 83 ### Runtime 84 85 + New `docker update` command that allows updating resource constraints on running containers [#15078](https://github.com/docker/docker/pull/15078) 86 + Add `--tmpfs` flag to `docker run` to create a tmpfs mount in a container [#13587](https://github.com/docker/docker/pull/13587) 87 + Add `--format` flag to `docker images` command [#17692](https://github.com/docker/docker/pull/17692) 88 + Allow to set daemon configuration in a file and hot-reload it with the `SIGHUP` signal [#18587](https://github.com/docker/docker/pull/18587) 89 + Updated docker events to include more meta-data and event types [#18888](https://github.com/docker/docker/pull/18888) 90 This change is backward compatible in the API, but not on the CLI. 91 + Add `--blkio-weight-device` flag to `docker run` [#13959](https://github.com/docker/docker/pull/13959) 92 + Add `--device-read-bps` and `--device-write-bps` flags to `docker run` [#14466](https://github.com/docker/docker/pull/14466) 93 + Add `--device-read-iops` and `--device-write-iops` flags to `docker run` [#15879](https://github.com/docker/docker/pull/15879) 94 + Add `--oom-score-adj` flag to `docker run` [#16277](https://github.com/docker/docker/pull/16277) 95 + Add `--detach-keys` flag to `attach`, `run`, `start` and `exec` commands to override the default key sequence that detaches from a container [#15666](https://github.com/docker/docker/pull/15666) 96 + Add `--shm-size` flag to `run`, `create` and `build` to set the size of `/dev/shm` [#16168](https://github.com/docker/docker/pull/16168) 97 + Show the number of running, stopped, and paused containers in `docker info` [#19249](https://github.com/docker/docker/pull/19249) 98 + Show the `OSType` and `Architecture` in `docker info` [#17478](https://github.com/docker/docker/pull/17478) 99 + Add `--cgroup-parent` flag on `daemon` to set cgroup parent for all containers [#19062](https://github.com/docker/docker/pull/19062) 100 + Add `-L` flag to docker cp to follow symlinks [#16613](https://github.com/docker/docker/pull/16613) 101 + New `status=dead` filter for `docker ps` [#17908](https://github.com/docker/docker/pull/17908) 102 * Change `docker run` exit codes to distinguish between runtime and application errors [#14012](https://github.com/docker/docker/pull/14012) 103 * Enhance `docker events --since` and `--until` to support nanoseconds and timezones [#17495](https://github.com/docker/docker/pull/17495) 104 * Add `--all`/`-a` flag to `stats` to include both running and stopped containers [#16742](https://github.com/docker/docker/pull/16742) 105 * Change the default cgroup-driver to `cgroupfs` [#17704](https://github.com/docker/docker/pull/17704) 106 * Emit a "tag" event when tagging an image with `build -t` [#17115](https://github.com/docker/docker/pull/17115) 107 * Best effort for linked containers' start order when starting the daemon [#18208](https://github.com/docker/docker/pull/18208) 108 * Add ability to add multiple tags on `build` [#15780](https://github.com/docker/docker/pull/15780) 109 * Permit `OPTIONS` request against any url, thus fixing issue with CORS [#19569](https://github.com/docker/docker/pull/19569) 110 - Fix the `--quiet` flag on `docker build` to actually be quiet [#17428](https://github.com/docker/docker/pull/17428) 111 - Fix `docker images --filter dangling=false` to now show all non-dangling images [#19326](https://github.com/docker/docker/pull/19326) 112 - Fix race condition causing autorestart turning off on restart [#17629](https://github.com/docker/docker/pull/17629) 113 - Recognize GPFS filesystems [#19216](https://github.com/docker/docker/pull/19216) 114 - Fix obscure bug preventing to start containers [#19751](https://github.com/docker/docker/pull/19751) 115 - Forbid `exec` during container restart [#19722](https://github.com/docker/docker/pull/19722) 116 - devicemapper: Increasing `--storage-opt dm.basesize` will now increase the base device size on daemon restart [#19123](https://github.com/docker/docker/pull/19123) 117 118 ### Security 119 120 + Add `--userns-remap` flag to `daemon` to support user namespaces (previously in experimental) [#19187](https://github.com/docker/docker/pull/19187) 121 + Add support for custom seccomp profiles in `--security-opt` [#17989](https://github.com/docker/docker/pull/17989) 122 + Add default seccomp profile [#18780](https://github.com/docker/docker/pull/18780) 123 + Add `--authorization-plugin` flag to `daemon` to customize ACLs [#15365](https://github.com/docker/docker/pull/15365) 124 + Docker Content Trust now supports the ability to read and write user delegations [#18887](https://github.com/docker/docker/pull/18887) 125 This is an optional, opt-in feature that requires the explicit use of the Notary command-line utility in order to be enabled. 126 Enabling delegation support in a specific repository will break the ability of Docker 1.9 and 1.8 to pull from that repository, if content trust is enabled. 127 * Allow SELinux to run in a container when using the BTRFS storage driver [#16452](https://github.com/docker/docker/pull/16452) 128 129 ### Distribution 130 131 * Use content-addressable storage for images and layers [#17924](https://github.com/docker/docker/pull/17924) 132 Note that a migration is performed the first time docker is run; it can take a significant amount of time depending on the number of images and containers present. 133 Images no longer depend on the parent chain but contain a list of layer references. 134 `docker load`/`docker save` tarballs now also contain content-addressable image configurations. 135 For more information: https://github.com/docker/docker/wiki/Engine-v1.10.0-content-addressability-migration 136 * Add support for the new [manifest format ("schema2")](https://github.com/docker/distribution/blob/master/docs/spec/manifest-v2-2.md) [#18785](https://github.com/docker/docker/pull/18785) 137 * Lots of improvements for push and pull: performance++, retries on failed downloads, cancelling on client disconnect [#18353](https://github.com/docker/docker/pull/18353), [#18418](https://github.com/docker/docker/pull/18418), [#19109](https://github.com/docker/docker/pull/19109), [#18353](https://github.com/docker/docker/pull/18353) 138 * Limit v1 protocol fallbacks [#18590](https://github.com/docker/docker/pull/18590) 139 - Fix issue where docker could hang indefinitely waiting for a nonexistent process to pull an image [#19743](https://github.com/docker/docker/pull/19743) 140 141 ### Networking 142 143 + Use DNS-based discovery instead of `/etc/hosts` [#19198](https://github.com/docker/docker/pull/19198) 144 + Support for network-scoped alias using `--net-alias` on `run` and `--alias` on `network connect` [#19242](https://github.com/docker/docker/pull/19242) 145 + Add `--ip` and `--ip6` on `run` and `network connect` to support custom IP addresses for a container in a network [#19001](https://github.com/docker/docker/pull/19001) 146 + Add `--ipam-opt` to `network create` for passing custom IPAM options [#17316](https://github.com/docker/docker/pull/17316) 147 + Add `--internal` flag to `network create` to restrict external access to and from the network [#19276](https://github.com/docker/docker/pull/19276) 148 + Add `kv.path` option to `--cluster-store-opt` [#19167](https://github.com/docker/docker/pull/19167) 149 + Add `discovery.heartbeat` and `discovery.ttl` options to `--cluster-store-opt` to configure discovery TTL and heartbeat timer [#18204](https://github.com/docker/docker/pull/18204) 150 + Add `--format` flag to `network inspect` [#17481](https://github.com/docker/docker/pull/17481) 151 + Add `--link` to `network connect` to provide a container-local alias [#19229](https://github.com/docker/docker/pull/19229) 152 + Support for Capability exchange with remote IPAM plugins [#18775](https://github.com/docker/docker/pull/18775) 153 + Add `--force` to `network disconnect` to force container to be disconnected from network [#19317](https://github.com/docker/docker/pull/19317) 154 * Support for multi-host networking using built-in overlay driver for all engine supported kernels: 3.10+ [#18775](https://github.com/docker/docker/pull/18775) 155 * `--link` is now supported on `docker run` for containers in user-defined network [#19229](https://github.com/docker/docker/pull/19229) 156 * Enhance `docker network rm` to allow removing multiple networks [#17489](https://github.com/docker/docker/pull/17489) 157 * Include container names in `network inspect` [#17615](https://github.com/docker/docker/pull/17615) 158 * Include auto-generated subnets for user-defined networks in `network inspect` [#17316](https://github.com/docker/docker/pull/17316) 159 * Add `--filter` flag to `network ls` to hide predefined networks [#17782](https://github.com/docker/docker/pull/17782) 160 * Add support for network connect/disconnect to stopped containers [#18906](https://github.com/docker/docker/pull/18906) 161 * Add network ID to container inspect [#19323](https://github.com/docker/docker/pull/19323) 162 - Fix MTU issue where Docker would not start with two or more default routes [#18108](https://github.com/docker/docker/pull/18108) 163 - Fix duplicate IP address for containers [#18106](https://github.com/docker/docker/pull/18106) 164 - Fix issue preventing sometimes docker from creating the bridge network [#19338](https://github.com/docker/docker/pull/19338) 165 - Do not substitute 127.0.0.1 name server when using `--net=host` [#19573](https://github.com/docker/docker/pull/19573) 166 167 ### Logging 168 169 + New logging driver for Splunk [#16488](https://github.com/docker/docker/pull/16488) 170 + Add support for syslog over TCP+TLS [#18998](https://github.com/docker/docker/pull/18998) 171 * Enhance `docker logs --since` and `--until` to support nanoseconds and time [#17495](https://github.com/docker/docker/pull/17495) 172 * Enhance AWS logs to auto-detect region [#16640](https://github.com/docker/docker/pull/16640) 173 174 ### Volumes 175 176 + Add support to set the mount propagation mode for a volume [#17034](https://github.com/docker/docker/pull/17034) 177 * Add `ls` and `inspect` endpoints to volume plugin API [#16534](https://github.com/docker/docker/pull/16534) 178 Existing plugins need to make use of these new APIs to satisfy users' expectation 179 For that, please use the new MIME type `application/vnd.docker.plugins.v1.2+json` [#19549](https://github.com/docker/docker/pull/19549) 180 - Fix data not being copied to named volumes [#19175](https://github.com/docker/docker/pull/19175) 181 - Fix issues preventing volume drivers from being containerized [#19500](https://github.com/docker/docker/pull/19500) 182 - Fix `docker volumes ls --dangling=false` to now show all non-dangling volumes [#19671](https://github.com/docker/docker/pull/19671) 183 - Do not remove named volumes on container removal [#19568](https://github.com/docker/docker/pull/19568) 184 - Allow external volume drivers to host anonymous volumes [#19190](https://github.com/docker/docker/pull/19190) 185 186 ### Builder 187 188 + Add support for `**` in `.dockerignore` to wildcard multiple levels of directories [#17090](https://github.com/docker/docker/pull/17090) 189 - Fix handling of UTF-8 characters in Dockerfiles [#17055](https://github.com/docker/docker/pull/17055) 190 - Fix permissions problem when reading from STDIN [#19283](https://github.com/docker/docker/pull/19283) 191 192 ### Client 193 194 + Add support for overriding the API version to use via an `DOCKER_API_VERSION` environment-variable [#15964](https://github.com/docker/docker/pull/15964) 195 - Fix a bug preventing Windows clients to log in to Docker Hub [#19891](https://github.com/docker/docker/pull/19891) 196 197 ### Misc 198 199 * systemd: Set TasksMax in addition to LimitNPROC in systemd service file [#19391](https://github.com/docker/docker/pull/19391) 200 201 ### Deprecations 202 203 * Remove LXC support. The LXC driver was deprecated in Docker 1.8, and has now been removed [#17700](https://github.com/docker/docker/pull/17700) 204 * Remove `--exec-driver` daemon flag, because it is no longer in use [#17700](https://github.com/docker/docker/pull/17700) 205 * Remove old deprecated single-dashed long CLI flags (such as `-rm`; use `--rm` instead) [#17724](https://github.com/docker/docker/pull/17724) 206 * Deprecate HostConfig at API container start [#17799](https://github.com/docker/docker/pull/17799) 207 * Deprecate docker packages for newly EOL'd Linux distributions: Fedora 21 and Ubuntu 15.04 (Vivid) [#18794](https://github.com/docker/docker/pull/18794), [#18809](https://github.com/docker/docker/pull/18809) 208 * Deprecate `-f` flag for docker tag [#18350](https://github.com/docker/docker/pull/18350) 209 210 ## 1.9.1 (2015-11-21) 211 212 ### Runtime 213 214 - Do not prevent daemon from booting if images could not be restored (#17695) 215 - Force IPC mount to unmount on daemon shutdown/init (#17539) 216 - Turn IPC unmount errors into warnings (#17554) 217 - Fix `docker stats` performance regression (#17638) 218 - Clarify cryptic error message upon `docker logs` if `--log-driver=none` (#17767) 219 - Fix seldom panics (#17639, #17634, #17703) 220 - Fix opq whiteouts problems for files with dot prefix (#17819) 221 - devicemapper: try defaulting to xfs instead of ext4 for performance reasons (#17903, #17918) 222 - devicemapper: fix displayed fs in docker info (#17974) 223 - selinux: only relabel if user requested so with the `z` option (#17450, #17834) 224 - Do not make network calls when normalizing names (#18014) 225 226 ### Client 227 228 - Fix `docker login` on windows (#17738) 229 - Fix bug with `docker inspect` output when not connected to daemon (#17715) 230 - Fix `docker inspect -f {{.HostConfig.Dns}} somecontainer` (#17680) 231 232 ### Builder 233 234 - Fix regression with symlink behavior in ADD/COPY (#17710) 235 236 ### Networking 237 238 - Allow passing a network ID as an argument for `--net` (#17558) 239 - Fix connect to host and prevent disconnect from host for `host` network (#17476) 240 - Fix `--fixed-cidr` issue when gateway ip falls in ip-range and ip-range is 241 not the first block in the network (#17853) 242 - Restore deterministic `IPv6` generation from `MAC` address on default `bridge` network (#17890) 243 - Allow port-mapping only for endpoints created on docker run (#17858) 244 - Fixed an endpoint delete issue with a possible stale sbox (#18102) 245 246 ### Distribution 247 248 - Correct parent chain in v2 push when v1Compatibility files on the disk are inconsistent (#18047) 249 250 ## 1.9.0 (2015-11-03) 251 252 ### Runtime 253 254 + `docker stats` now returns block IO metrics (#15005) 255 + `docker stats` now details network stats per interface (#15786) 256 + Add `ancestor=<image>` filter to `docker ps --filter` flag to filter 257 containers based on their ancestor images (#14570) 258 + Add `label=<somelabel>` filter to `docker ps --filter` to filter containers 259 based on label (#16530) 260 + Add `--kernel-memory` flag to `docker run` (#14006) 261 + Add `--message` flag to `docker import` allowing to specify an optional 262 message (#15711) 263 + Add `--privileged` flag to `docker exec` (#14113) 264 + Add `--stop-signal` flag to `docker run` allowing to replace the container 265 process stopping signal (#15307) 266 + Add a new `unless-stopped` restart policy (#15348) 267 + Inspecting an image now returns tags (#13185) 268 + Add container size information to `docker inspect` (#15796) 269 + Add `RepoTags` and `RepoDigests` field to `/images/{name:.*}/json` (#17275) 270 - Remove the deprecated `/container/ps` endpoint from the API (#15972) 271 - Send and document correct HTTP codes for `/exec/<name>/start` (#16250) 272 - Share shm and mqueue between containers sharing IPC namespace (#15862) 273 - Event stream now shows OOM status when `--oom-kill-disable` is set (#16235) 274 - Ensure special network files (/etc/hosts etc.) are read-only if bind-mounted 275 with `ro` option (#14965) 276 - Improve `rmi` performance (#16890) 277 - Do not update /etc/hosts for the default bridge network, except for links (#17325) 278 - Fix conflict with duplicate container names (#17389) 279 - Fix an issue with incorrect template execution in `docker inspect` (#17284) 280 - DEPRECATE `-c` short flag variant for `--cpu-shares` in docker run (#16271) 281 282 ### Client 283 284 + Allow `docker import` to import from local files (#11907) 285 286 ### Builder 287 288 + Add a `STOPSIGNAL` Dockerfile instruction allowing to set a different 289 stop-signal for the container process (#15307) 290 + Add an `ARG` Dockerfile instruction and a `--build-arg` flag to `docker build` 291 that allows to add build-time environment variables (#15182) 292 - Improve cache miss performance (#16890) 293 294 ### Storage 295 296 - devicemapper: Implement deferred deletion capability (#16381) 297 298 ## Networking 299 300 + `docker network` exits experimental and is part of standard release (#16645) 301 + New network top-level concept, with associated subcommands and API (#16645) 302 WARNING: the API is different from the experimental API 303 + Support for multiple isolated/micro-segmented networks (#16645) 304 + Built-in multihost networking using VXLAN based overlay driver (#14071) 305 + Support for third-party network plugins (#13424) 306 + Ability to dynamically connect containers to multiple networks (#16645) 307 + Support for user-defined IP address management via pluggable IPAM drivers (#16910) 308 + Add daemon flags `--cluster-store` and `--cluster-advertise` for built-in nodes discovery (#16229) 309 + Add `--cluster-store-opt` for setting up TLS settings (#16644) 310 + Add `--dns-opt` to the daemon (#16031) 311 - DEPRECATE following container `NetworkSettings` fields in API v1.21: `EndpointID`, `Gateway`, 312 `GlobalIPv6Address`, `GlobalIPv6PrefixLen`, `IPAddress`, `IPPrefixLen`, `IPv6Gateway` and `MacAddress`. 313 Those are now specific to the `bridge` network. Use `NetworkSettings.Networks` to inspect 314 the networking settings of a container per network. 315 316 ### Volumes 317 318 + New top-level `volume` subcommand and API (#14242) 319 - Move API volume driver settings to host-specific config (#15798) 320 - Print an error message if volume name is not unique (#16009) 321 - Ensure volumes created from Dockerfiles always use the local volume driver 322 (#15507) 323 - DEPRECATE auto-creating missing host paths for bind mounts (#16349) 324 325 ### Logging 326 327 + Add `awslogs` logging driver for Amazon CloudWatch (#15495) 328 + Add generic `tag` log option to allow customizing container/image 329 information passed to driver (e.g. show container names) (#15384) 330 - Implement the `docker logs` endpoint for the journald driver (#13707) 331 - DEPRECATE driver-specific log tags (e.g. `syslog-tag`, etc.) (#15384) 332 333 ### Distribution 334 335 + `docker search` now works with partial names (#16509) 336 - Push optimization: avoid buffering to file (#15493) 337 - The daemon will display progress for images that were already being pulled 338 by another client (#15489) 339 - Only permissions required for the current action being performed are requested (#) 340 + Renaming trust keys (and respective environment variables) from `offline` to 341 `root` and `tagging` to `repository` (#16894) 342 - DEPRECATE trust key environment variables 343 `DOCKER_CONTENT_TRUST_OFFLINE_PASSPHRASE` and 344 `DOCKER_CONTENT_TRUST_TAGGING_PASSPHRASE` (#16894) 345 346 ### Security 347 348 + Add SELinux profiles to the rpm package (#15832) 349 - Fix various issues with AppArmor profiles provided in the deb package 350 (#14609) 351 - Add AppArmor policy that prevents writing to /proc (#15571) 352 353 ## 1.8.3 (2015-10-12) 354 355 ### Distribution 356 357 - Fix layer IDs lead to local graph poisoning (CVE-2014-8178) 358 - Fix manifest validation and parsing logic errors allow pull-by-digest validation bypass (CVE-2014-8179) 359 + Add `--disable-legacy-registry` to prevent a daemon from using a v1 registry 360 361 ## 1.8.2 (2015-09-10) 362 363 ### Distribution 364 365 - Fixes rare edge case of handling GNU LongLink and LongName entries. 366 - Fix ^C on docker pull. 367 - Fix docker pull issues on client disconnection. 368 - Fix issue that caused the daemon to panic when loggers weren't configured properly. 369 - Fix goroutine leak pulling images from registry V2. 370 371 ### Runtime 372 373 - Fix a bug mounting cgroups for docker daemons running inside docker containers. 374 - Initialize log configuration properly. 375 376 ### Client: 377 378 - Handle `-q` flag in `docker ps` properly when there is a default format. 379 380 ### Networking 381 382 - Fix several corner cases with netlink. 383 384 ### Contrib 385 386 - Fix several issues with bash completion. 387 388 ## 1.8.1 (2015-08-12) 389 390 ### Distribution 391 392 * Fix a bug where pushing multiple tags would result in invalid images 393 394 ## 1.8.0 (2015-08-11) 395 396 ### Distribution 397 398 + Trusted pull, push and build, disabled by default 399 * Make tar layers deterministic between registries 400 * Don't allow deleting the image of running containers 401 * Check if a tag name to load is a valid digest 402 * Allow one character repository names 403 * Add a more accurate error description for invalid tag name 404 * Make build cache ignore mtime 405 406 ### Cli 407 408 + Add support for DOCKER_CONFIG/--config to specify config file dir 409 + Add --type flag for docker inspect command 410 + Add formatting options to `docker ps` with `--format` 411 + Replace `docker -d` with new subcommand `docker daemon` 412 * Zsh completion updates and improvements 413 * Add some missing events to bash completion 414 * Support daemon urls with base paths in `docker -H` 415 * Validate status= filter to docker ps 416 * Display when a container is in --net=host in docker ps 417 * Extend docker inspect to export image metadata related to graph driver 418 * Restore --default-gateway{,-v6} daemon options 419 * Add missing unpublished ports in docker ps 420 * Allow duration strings in `docker events` as --since/--until 421 * Expose more mounts information in `docker inspect` 422 423 ### Runtime 424 425 + Add new Fluentd logging driver 426 + Allow `docker import` to load from local files 427 + Add logging driver for GELF via UDP 428 + Allow to copy files from host to containers with `docker cp` 429 + Promote volume drivers from experimental to master 430 + Add rollover options to json-file log driver, and --log-driver-opts flag 431 + Add memory swappiness tuning options 432 * Remove cgroup read-only flag when privileged 433 * Make /proc, /sys, & /dev readonly for readonly containers 434 * Add cgroup bind mount by default 435 * Overlay: Export metadata for container and image in `docker inspect` 436 * Devicemapper: external device activation 437 * Devicemapper: Compare uuid of base device on startup 438 * Remove RC4 from the list of registry cipher suites 439 * Add syslog-facility option 440 * LXC execdriver compatibility with recent LXC versions 441 * Mark LXC execriver as deprecated (to be removed with the migration to runc) 442 443 ### Plugins 444 445 * Separate plugin sockets and specs locations 446 * Allow TLS connections to plugins 447 448 ### Bug fixes 449 450 - Add missing 'Names' field to /containers/json API output 451 - Make `docker rmi` of dangling images safe while pulling 452 - Devicemapper: Change default basesize to 100G 453 - Go Scheduler issue with sync.Mutex and gcc 454 - Fix issue where Search API endpoint would panic due to empty AuthConfig 455 - Set image canonical names correctly 456 - Check dockerinit only if lxc driver is used 457 - Fix ulimit usage of nproc 458 - Always attach STDIN if -i,--interactive is specified 459 - Show error messages when saving container state fails 460 - Fixed incorrect assumption on --bridge=none treated as disable network 461 - Check for invalid port specifications in host configuration 462 - Fix endpoint leave failure for --net=host mode 463 - Fix goroutine leak in the stats API if the container is not running 464 - Check for apparmor file before reading it 465 - Fix DOCKER_TLS_VERIFY being ignored 466 - Set umask to the default on startup 467 - Correct the message of pause and unpause a non-running container 468 - Adjust disallowed CpuShares in container creation 469 - ZFS: correctly apply selinux context 470 - Display empty string instead of <nil> when IP opt is nil 471 - `docker kill` returns error when container is not running 472 - Fix COPY/ADD quoted/json form 473 - Fix goroutine leak on logs -f with no output 474 - Remove panic in nat package on invalid hostport 475 - Fix container linking in Fedora 22 476 - Fix error caused using default gateways outside of the allocated range 477 - Format times in inspect command with a template as RFC3339Nano 478 - Make registry client to accept 2xx and 3xx http status responses as successful 479 - Fix race issue that caused the daemon to crash with certain layer downloads failed in a specific order. 480 - Fix error when the docker ps format was not valid. 481 - Remove redundant ip forward check. 482 - Fix issue trying to push images to repository mirrors. 483 - Fix error cleaning up network entrypoints when there is an initialization issue. 484 485 ## 1.7.1 (2015-07-14) 486 487 #### Runtime 488 489 - Fix default user spawning exec process with `docker exec` 490 - Make `--bridge=none` not to configure the network bridge 491 - Publish networking stats properly 492 - Fix implicit devicemapper selection with static binaries 493 - Fix socket connections that hung intermittently 494 - Fix bridge interface creation on CentOS/RHEL 6.6 495 - Fix local dns lookups added to resolv.conf 496 - Fix copy command mounting volumes 497 - Fix read/write privileges in volumes mounted with --volumes-from 498 499 #### Remote API 500 501 - Fix unmarshalling of Command and Entrypoint 502 - Set limit for minimum client version supported 503 - Validate port specification 504 - Return proper errors when attach/reattach fail 505 506 #### Distribution 507 508 - Fix pulling private images 509 - Fix fallback between registry V2 and V1 510 511 ## 1.7.0 (2015-06-16) 512 513 #### Runtime 514 + Experimental feature: support for out-of-process volume plugins 515 * The userland proxy can be disabled in favor of hairpin NAT using the daemon’s `--userland-proxy=false` flag 516 * The `exec` command supports the `-u|--user` flag to specify the new process owner 517 + Default gateway for containers can be specified daemon-wide using the `--default-gateway` and `--default-gateway-v6` flags 518 + The CPU CFS (Completely Fair Scheduler) quota can be set in `docker run` using `--cpu-quota` 519 + Container block IO can be controlled in `docker run` using`--blkio-weight` 520 + ZFS support 521 + The `docker logs` command supports a `--since` argument 522 + UTS namespace can be shared with the host with `docker run --uts=host` 523 524 #### Quality 525 * Networking stack was entirely rewritten as part of the libnetwork effort 526 * Engine internals refactoring 527 * Volumes code was entirely rewritten to support the plugins effort 528 + Sending SIGUSR1 to a daemon will dump all goroutines stacks without exiting 529 530 #### Build 531 + Support ${variable:-value} and ${variable:+value} syntax for environment variables 532 + Support resource management flags `--cgroup-parent`, `--cpu-period`, `--cpu-quota`, `--cpuset-cpus`, `--cpuset-mems` 533 + git context changes with branches and directories 534 * The .dockerignore file support exclusion rules 535 536 #### Distribution 537 + Client support for v2 mirroring support for the official registry 538 539 #### Bugfixes 540 * Firewalld is now supported and will automatically be used when available 541 * mounting --device recursively 542 543 ## 1.6.2 (2015-05-13) 544 545 #### Runtime 546 - Revert change prohibiting mounting into /sys 547 548 ## 1.6.1 (2015-05-07) 549 550 #### Security 551 - Fix read/write /proc paths (CVE-2015-3630) 552 - Prohibit VOLUME /proc and VOLUME / (CVE-2015-3631) 553 - Fix opening of file-descriptor 1 (CVE-2015-3627) 554 - Fix symlink traversal on container respawn allowing local privilege escalation (CVE-2015-3629) 555 - Prohibit mount of /sys 556 557 #### Runtime 558 - Update AppArmor policy to not allow mounts 559 560 ## 1.6.0 (2015-04-07) 561 562 #### Builder 563 + Building images from an image ID 564 + Build containers with resource constraints, ie `docker build --cpu-shares=100 --memory=1024m...` 565 + `commit --change` to apply specified Dockerfile instructions while committing the image 566 + `import --change` to apply specified Dockerfile instructions while importing the image 567 + Builds no longer continue in the background when canceled with CTRL-C 568 569 #### Client 570 + Windows Support 571 572 #### Runtime 573 + Container and image Labels 574 + `--cgroup-parent` for specifying a parent cgroup to place container cgroup within 575 + Logging drivers, `json-file`, `syslog`, or `none` 576 + Pulling images by ID 577 + `--ulimit` to set the ulimit on a container 578 + `--default-ulimit` option on the daemon which applies to all created containers (and overwritten by `--ulimit` on run) 579 580 ## 1.5.0 (2015-02-10) 581 582 #### Builder 583 + Dockerfile to use for a given `docker build` can be specified with the `-f` flag 584 * Dockerfile and .dockerignore files can be themselves excluded as part of the .dockerignore file, thus preventing modifications to these files invalidating ADD or COPY instructions cache 585 * ADD and COPY instructions accept relative paths 586 * Dockerfile `FROM scratch` instruction is now interpreted as a no-base specifier 587 * Improve performance when exposing a large number of ports 588 589 #### Hack 590 + Allow client-side only integration tests for Windows 591 * Include docker-py integration tests against Docker daemon as part of our test suites 592 593 #### Packaging 594 + Support for the new version of the registry HTTP API 595 * Speed up `docker push` for images with a majority of already existing layers 596 - Fixed contacting a private registry through a proxy 597 598 #### Remote API 599 + A new endpoint will stream live container resource metrics and can be accessed with the `docker stats` command 600 + Containers can be renamed using the new `rename` endpoint and the associated `docker rename` command 601 * Container `inspect` endpoint show the ID of `exec` commands running in this container 602 * Container `inspect` endpoint show the number of times Docker auto-restarted the container 603 * New types of event can be streamed by the `events` endpoint: ‘OOM’ (container died with out of memory), ‘exec_create’, and ‘exec_start' 604 - Fixed returned string fields which hold numeric characters incorrectly omitting surrounding double quotes 605 606 #### Runtime 607 + Docker daemon has full IPv6 support 608 + The `docker run` command can take the `--pid=host` flag to use the host PID namespace, which makes it possible for example to debug host processes using containerized debugging tools 609 + The `docker run` command can take the `--read-only` flag to make the container’s root filesystem mounted as readonly, which can be used in combination with volumes to force a container’s processes to only write to locations that will be persisted 610 + Container total memory usage can be limited for `docker run` using the `--memory-swap` flag 611 * Major stability improvements for devicemapper storage driver 612 * Better integration with host system: containers will reflect changes to the host's `/etc/resolv.conf` file when restarted 613 * Better integration with host system: per-container iptable rules are moved to the DOCKER chain 614 - Fixed container exiting on out of memory to return an invalid exit code 615 616 #### Other 617 * The HTTP_PROXY, HTTPS_PROXY, and NO_PROXY environment variables are properly taken into account by the client when connecting to the Docker daemon 618 619 ## 1.4.1 (2014-12-15) 620 621 #### Runtime 622 - Fix issue with volumes-from and bind mounts not being honored after create 623 624 ## 1.4.0 (2014-12-11) 625 626 #### Notable Features since 1.3.0 627 + Set key=value labels to the daemon (displayed in `docker info`), applied with 628 new `-label` daemon flag 629 + Add support for `ENV` in Dockerfile of the form: 630 `ENV name=value name2=value2...` 631 + New Overlayfs Storage Driver 632 + `docker info` now returns an `ID` and `Name` field 633 + Filter events by event name, container, or image 634 + `docker cp` now supports copying from container volumes 635 - Fixed `docker tag`, so it honors `--force` when overriding a tag for existing 636 image. 637 638 ## 1.3.3 (2014-12-11) 639 640 #### Security 641 - Fix path traversal vulnerability in processing of absolute symbolic links (CVE-2014-9356) 642 - Fix decompression of xz image archives, preventing privilege escalation (CVE-2014-9357) 643 - Validate image IDs (CVE-2014-9358) 644 645 #### Runtime 646 - Fix an issue when image archives are being read slowly 647 648 #### Client 649 - Fix a regression related to stdin redirection 650 - Fix a regression with `docker cp` when destination is the current directory 651 652 ## 1.3.2 (2014-11-20) 653 654 #### Security 655 - Fix tar breakout vulnerability 656 * Extractions are now sandboxed chroot 657 - Security options are no longer committed to images 658 659 #### Runtime 660 - Fix deadlock in `docker ps -f exited=1` 661 - Fix a bug when `--volumes-from` references a container that failed to start 662 663 #### Registry 664 + `--insecure-registry` now accepts CIDR notation such as 10.1.0.0/16 665 * Private registries whose IPs fall in the 127.0.0.0/8 range do no need the `--insecure-registry` flag 666 - Skip the experimental registry v2 API when mirroring is enabled 667 668 ## 1.3.1 (2014-10-28) 669 670 #### Security 671 * Prevent fallback to SSL protocols < TLS 1.0 for client, daemon and registry 672 + Secure HTTPS connection to registries with certificate verification and without HTTP fallback unless `--insecure-registry` is specified 673 674 #### Runtime 675 - Fix issue where volumes would not be shared 676 677 #### Client 678 - Fix issue with `--iptables=false` not automatically setting `--ip-masq=false` 679 - Fix docker run output to non-TTY stdout 680 681 #### Builder 682 - Fix escaping `$` for environment variables 683 - Fix issue with lowercase `onbuild` Dockerfile instruction 684 - Restrict environment variable expansion to `ENV`, `ADD`, `COPY`, `WORKDIR`, `EXPOSE`, `VOLUME` and `USER` 685 686 ## 1.3.0 (2014-10-14) 687 688 #### Notable features since 1.2.0 689 + Docker `exec` allows you to run additional processes inside existing containers 690 + Docker `create` gives you the ability to create a container via the CLI without executing a process 691 + `--security-opts` options to allow user to customize container labels and apparmor profiles 692 + Docker `ps` filters 693 - Wildcard support to COPY/ADD 694 + Move production URLs to get.docker.com from get.docker.io 695 + Allocate IP address on the bridge inside a valid CIDR 696 + Use drone.io for PR and CI testing 697 + Ability to setup an official registry mirror 698 + Ability to save multiple images with docker `save` 699 700 ## 1.2.0 (2014-08-20) 701 702 #### Runtime 703 + Make /etc/hosts /etc/resolv.conf and /etc/hostname editable at runtime 704 + Auto-restart containers using policies 705 + Use /var/lib/docker/tmp for large temporary files 706 + `--cap-add` and `--cap-drop` to tweak what linux capability you want 707 + `--device` to use devices in containers 708 709 #### Client 710 + `docker search` on private registries 711 + Add `exited` filter to `docker ps --filter` 712 * `docker rm -f` now kills instead of stop 713 + Support for IPv6 addresses in `--dns` flag 714 715 #### Proxy 716 + Proxy instances in separate processes 717 * Small bug fix on UDP proxy 718 719 ## 1.1.2 (2014-07-23) 720 721 #### Runtime 722 + Fix port allocation for existing containers 723 + Fix containers restart on daemon restart 724 725 #### Packaging 726 + Fix /etc/init.d/docker issue on Debian 727 728 ## 1.1.1 (2014-07-09) 729 730 #### Builder 731 * Fix issue with ADD 732 733 ## 1.1.0 (2014-07-03) 734 735 #### Notable features since 1.0.1 736 + Add `.dockerignore` support 737 + Pause containers during `docker commit` 738 + Add `--tail` to `docker logs` 739 740 #### Builder 741 + Allow a tar file as context for `docker build` 742 * Fix issue with white-spaces and multi-lines in `Dockerfiles` 743 744 #### Runtime 745 * Overall performance improvements 746 * Allow `/` as source of `docker run -v` 747 * Fix port allocation 748 * Fix bug in `docker save` 749 * Add links information to `docker inspect` 750 751 #### Client 752 * Improve command line parsing for `docker commit` 753 754 #### Remote API 755 * Improve status code for the `start` and `stop` endpoints 756 757 ## 1.0.1 (2014-06-19) 758 759 #### Notable features since 1.0.0 760 * Enhance security for the LXC driver 761 762 #### Builder 763 * Fix `ONBUILD` instruction passed to grandchildren 764 765 #### Runtime 766 * Fix events subscription 767 * Fix /etc/hostname file with host networking 768 * Allow `-h` and `--net=none` 769 * Fix issue with hotplug devices in `--privileged` 770 771 #### Client 772 * Fix artifacts with events 773 * Fix a panic with empty flags 774 * Fix `docker cp` on Mac OS X 775 776 #### Miscellaneous 777 * Fix compilation on Mac OS X 778 * Fix several races 779 780 ## 1.0.0 (2014-06-09) 781 782 #### Notable features since 0.12.0 783 * Production support 784 785 ## 0.12.0 (2014-06-05) 786 787 #### Notable features since 0.11.0 788 * 40+ various improvements to stability, performance and usability 789 * New `COPY` Dockerfile instruction to allow copying a local file from the context into the container without ever extracting if the file is a tar file 790 * Inherit file permissions from the host on `ADD` 791 * New `pause` and `unpause` commands to allow pausing and unpausing of containers using cgroup freezer 792 * The `images` command has a `-f`/`--filter` option to filter the list of images 793 * Add `--force-rm` to clean up after a failed build 794 * Standardize JSON keys in Remote API to CamelCase 795 * Pull from a docker run now assumes `latest` tag if not specified 796 * Enhance security on Linux capabilities and device nodes 797 798 ## 0.11.1 (2014-05-07) 799 800 #### Registry 801 - Fix push and pull to private registry 802 803 ## 0.11.0 (2014-05-07) 804 805 #### Notable features since 0.10.0 806 807 * SELinux support for mount and process labels 808 * Linked containers can be accessed by hostname 809 * Use the net `--net` flag to allow advanced network configuration such as host networking so that containers can use the host's network interfaces 810 * Add a ping endpoint to the Remote API to do healthchecks of your docker daemon 811 * Logs can now be returned with an optional timestamp 812 * Docker now works with registries that support SHA-512 813 * Multiple registry endpoints are supported to allow registry mirrors 814 815 ## 0.10.0 (2014-04-08) 816 817 #### Builder 818 - Fix printing multiple messages on a single line. Fixes broken output during builds. 819 - Follow symlinks inside container's root for ADD build instructions. 820 - Fix EXPOSE caching. 821 822 #### Documentation 823 - Add the new options of `docker ps` to the documentation. 824 - Add the options of `docker restart` to the documentation. 825 - Update daemon docs and help messages for --iptables and --ip-forward. 826 - Updated apt-cacher-ng docs example. 827 - Remove duplicate description of --mtu from docs. 828 - Add missing -t and -v for `docker images` to the docs. 829 - Add fixes to the cli docs. 830 - Update libcontainer docs. 831 - Update images in docs to remove references to AUFS and LXC. 832 - Update the nodejs_web_app in the docs to use the new epel RPM address. 833 - Fix external link on security of containers. 834 - Update remote API docs. 835 - Add image size to history docs. 836 - Be explicit about binding to all interfaces in redis example. 837 - Document DisableNetwork flag in the 1.10 remote api. 838 - Document that `--lxc-conf` is lxc only. 839 - Add chef usage documentation. 840 - Add example for an image with multiple for `docker load`. 841 - Explain what `docker run -a` does in the docs. 842 843 #### Contrib 844 - Add variable for DOCKER_LOGFILE to sysvinit and use append instead of overwrite in opening the logfile. 845 - Fix init script cgroup mounting workarounds to be more similar to cgroupfs-mount and thus work properly. 846 - Remove inotifywait hack from the upstart host-integration example because it's not necessary any more. 847 - Add check-config script to contrib. 848 - Fix fish shell completion. 849 850 #### Hack 851 * Clean up "go test" output from "make test" to be much more readable/scannable. 852 * Exclude more "definitely not unit tested Go source code" directories from hack/make/test. 853 + Generate md5 and sha256 hashes when building, and upload them via hack/release.sh. 854 - Include contributed completions in Ubuntu PPA. 855 + Add cli integration tests. 856 * Add tweaks to the hack scripts to make them simpler. 857 858 #### Remote API 859 + Add TLS auth support for API. 860 * Move git clone from daemon to client. 861 - Fix content-type detection in docker cp. 862 * Split API into 2 go packages. 863 864 #### Runtime 865 * Support hairpin NAT without going through Docker server. 866 - devicemapper: succeed immediately when removing non-existing devices. 867 - devicemapper: improve handling of devicemapper devices (add per device lock, increase sleep time and unlock while sleeping). 868 - devicemapper: increase timeout in waitClose to 10 seconds. 869 - devicemapper: ensure we shut down thin pool cleanly. 870 - devicemapper: pass info, rather than hash to activateDeviceIfNeeded, deactivateDevice, setInitialized, deleteDevice. 871 - devicemapper: avoid AB-BA deadlock. 872 - devicemapper: make shutdown better/faster. 873 - improve alpha sorting in mflag. 874 - Remove manual http cookie management because the cookiejar is being used. 875 - Use BSD raw mode on Darwin. Fixes nano, tmux and others. 876 - Add FreeBSD support for the client. 877 - Merge auth package into registry. 878 - Add deprecation warning for -t on `docker pull`. 879 - Remove goroutine leak on error. 880 - Update parseLxcInfo to comply with new lxc1.0 format. 881 - Fix attach exit on darwin. 882 - Improve deprecation message. 883 - Retry to retrieve the layer metadata up to 5 times for `docker pull`. 884 - Only unshare the mount namespace for execin. 885 - Merge existing config when committing. 886 - Disable daemon startup timeout. 887 - Fix issue #4681: add loopback interface when networking is disabled. 888 - Add failing test case for issue #4681. 889 - Send SIGTERM to child, instead of SIGKILL. 890 - Show the driver and the kernel version in `docker info` even when not in debug mode. 891 - Always symlink /dev/ptmx for libcontainer. This fixes console related problems. 892 - Fix issue caused by the absence of /etc/apparmor.d. 893 - Don't leave empty cidFile behind when failing to create the container. 894 - Mount cgroups automatically if they're not mounted already. 895 - Use mock for search tests. 896 - Update to double-dash everywhere. 897 - Move .dockerenv parsing to lxc driver. 898 - Move all bind-mounts in the container inside the namespace. 899 - Don't use separate bind mount for container. 900 - Always symlink /dev/ptmx for libcontainer. 901 - Don't kill by pid for other drivers. 902 - Add initial logging to libcontainer. 903 * Sort by port in `docker ps`. 904 - Move networking drivers into runtime top level package. 905 + Add --no-prune to `docker rmi`. 906 + Add time since exit in `docker ps`. 907 - graphdriver: add build tags. 908 - Prevent allocation of previously allocated ports & prevent improve port allocation. 909 * Add support for --since/--before in `docker ps`. 910 - Clean up container stop. 911 + Add support for configurable dns search domains. 912 - Add support for relative WORKDIR instructions. 913 - Add --output flag for docker save. 914 - Remove duplication of DNS entries in config merging. 915 - Add cpuset.cpus to cgroups and native driver options. 916 - Remove docker-ci. 917 - Promote btrfs. btrfs is no longer considered experimental. 918 - Add --input flag to `docker load`. 919 - Return error when existing bridge doesn't match IP address. 920 - Strip comments before parsing line continuations to avoid interpreting instructions as comments. 921 - Fix TestOnlyLoopbackExistsWhenUsingDisableNetworkOption to ignore "DOWN" interfaces. 922 - Add systemd implementation of cgroups and make containers show up as systemd units. 923 - Fix commit and import when no repository is specified. 924 - Remount /var/lib/docker as --private to fix scaling issue. 925 - Use the environment's proxy when pinging the remote registry. 926 - Reduce error level from harmless errors. 927 * Allow --volumes-from to be individual files. 928 - Fix expanding buffer in StdCopy. 929 - Set error regardless of attach or stdin. This fixes #3364. 930 - Add support for --env-file to load environment variables from files. 931 - Symlink /etc/mtab and /proc/mounts. 932 - Allow pushing a single tag. 933 - Shut down containers cleanly at shutdown and wait forever for the containers to shut down. This makes container shutdown on daemon shutdown work properly via SIGTERM. 934 - Don't throw error when starting an already running container. 935 - Fix dynamic port allocation limit. 936 - remove setupDev from libcontainer. 937 - Add API version to `docker version`. 938 - Return correct exit code when receiving signal and make SIGQUIT quit without cleanup. 939 - Fix --volumes-from mount failure. 940 - Allow non-privileged containers to create device nodes. 941 - Skip login tests because of external dependency on a hosted service. 942 - Deprecate `docker images --tree` and `docker images --viz`. 943 - Deprecate `docker insert`. 944 - Include base abstraction for apparmor. This fixes some apparmor related problems on Ubuntu 14.04. 945 - Add specific error message when hitting 401 over HTTP on push. 946 - Fix absolute volume check. 947 - Remove volumes-from from the config. 948 - Move DNS options to hostconfig. 949 - Update the apparmor profile for libcontainer. 950 - Add deprecation notice for `docker commit -run`. 951 952 ## 0.9.1 (2014-03-24) 953 954 #### Builder 955 - Fix printing multiple messages on a single line. Fixes broken output during builds. 956 957 #### Documentation 958 - Fix external link on security of containers. 959 960 #### Contrib 961 - Fix init script cgroup mounting workarounds to be more similar to cgroupfs-mount and thus work properly. 962 - Add variable for DOCKER_LOGFILE to sysvinit and use append instead of overwrite in opening the logfile. 963 964 #### Hack 965 - Generate md5 and sha256 hashes when building, and upload them via hack/release.sh. 966 967 #### Remote API 968 - Fix content-type detection in `docker cp`. 969 970 #### Runtime 971 - Use BSD raw mode on Darwin. Fixes nano, tmux and others. 972 - Only unshare the mount namespace for execin. 973 - Retry to retrieve the layer metadata up to 5 times for `docker pull`. 974 - Merge existing config when committing. 975 - Fix panic in monitor. 976 - Disable daemon startup timeout. 977 - Fix issue #4681: add loopback interface when networking is disabled. 978 - Add failing test case for issue #4681. 979 - Send SIGTERM to child, instead of SIGKILL. 980 - Show the driver and the kernel version in `docker info` even when not in debug mode. 981 - Always symlink /dev/ptmx for libcontainer. This fixes console related problems. 982 - Fix issue caused by the absence of /etc/apparmor.d. 983 - Don't leave empty cidFile behind when failing to create the container. 984 - Improve deprecation message. 985 - Fix attach exit on darwin. 986 - devicemapper: improve handling of devicemapper devices (add per device lock, increase sleep time, unlock while sleeping). 987 - devicemapper: succeed immediately when removing non-existing devices. 988 - devicemapper: increase timeout in waitClose to 10 seconds. 989 - Remove goroutine leak on error. 990 - Update parseLxcInfo to comply with new lxc1.0 format. 991 992 ## 0.9.0 (2014-03-10) 993 994 #### Builder 995 - Avoid extra mount/unmount during build. This fixes mount/unmount related errors during build. 996 - Add error to docker build --rm. This adds missing error handling. 997 - Forbid chained onbuild, `onbuild from` and `onbuild maintainer` triggers. 998 - Make `--rm` the default for `docker build`. 999 1000 #### Documentation 1001 - Download the docker client binary for Mac over https. 1002 - Update the titles of the install instructions & descriptions. 1003 * Add instructions for upgrading boot2docker. 1004 * Add port forwarding example in OS X install docs. 1005 - Attempt to disentangle repository and registry. 1006 - Update docs to explain more about `docker ps`. 1007 - Update sshd example to use a Dockerfile. 1008 - Rework some examples, including the Python examples. 1009 - Update docs to include instructions for a container's lifecycle. 1010 - Update docs documentation to discuss the docs branch. 1011 - Don't skip cert check for an example & use HTTPS. 1012 - Bring back the memory and swap accounting section which was lost when the kernel page was removed. 1013 - Explain DNS warnings and how to fix them on systems running and using a local nameserver. 1014 1015 #### Contrib 1016 - Add Tanglu support for mkimage-debootstrap. 1017 - Add SteamOS support for mkimage-debootstrap. 1018 1019 #### Hack 1020 - Get package coverage when running integration tests. 1021 - Remove the Vagrantfile. This is being replaced with boot2docker. 1022 - Fix tests on systems where aufs isn't available. 1023 - Update packaging instructions and remove the dependency on lxc. 1024 1025 #### Remote API 1026 * Move code specific to the API to the api package. 1027 - Fix header content type for the API. Makes all endpoints use proper content type. 1028 - Fix registry auth & remove ping calls from CmdPush and CmdPull. 1029 - Add newlines to the JSON stream functions. 1030 1031 #### Runtime 1032 * Do not ping the registry from the CLI. All requests to registries flow through the daemon. 1033 - Check for nil information return in the lxc driver. This fixes panics with older lxc versions. 1034 - Devicemapper: cleanups and fix for unmount. Fixes two problems which were causing unmount to fail intermittently. 1035 - Devicemapper: remove directory when removing device. Directories don't get left behind when removing the device. 1036 * Devicemapper: enable skip_block_zeroing. Improves performance by not zeroing blocks. 1037 - Devicemapper: fix shutdown warnings. Fixes shutdown warnings concerning pool device removal. 1038 - Ensure docker cp stream is closed properly. Fixes problems with files not being copied by `docker cp`. 1039 - Stop making `tcp://` default to `127.0.0.1:4243` and remove the default port for tcp. 1040 - Fix `--run` in `docker commit`. This makes `docker commit --run` work again. 1041 - Fix custom bridge related options. This makes custom bridges work again. 1042 + Mount-bind the PTY as container console. This allows tmux/screen to run. 1043 + Add the pure Go libcontainer library to make it possible to run containers using only features of the Linux kernel. 1044 + Add native exec driver which uses libcontainer and make it the default exec driver. 1045 - Add support for handling extended attributes in archives. 1046 * Set the container MTU to be the same as the host MTU. 1047 + Add simple sha256 checksums for layers to speed up `docker push`. 1048 * Improve kernel version parsing. 1049 * Allow flag grouping (`docker run -it`). 1050 - Remove chroot exec driver. 1051 - Fix divide by zero to fix panic. 1052 - Rewrite `docker rmi`. 1053 - Fix docker info with lxc 1.0.0. 1054 - Fix fedora tty with apparmor. 1055 * Don't always append env vars, replace defaults with vars from config. 1056 * Fix a goroutine leak. 1057 * Switch to Go 1.2.1. 1058 - Fix unique constraint error checks. 1059 * Handle symlinks for Docker's data directory and for TMPDIR. 1060 - Add deprecation warnings for flags (-flag is deprecated in favor of --flag) 1061 - Add apparmor profile for the native execution driver. 1062 * Move system specific code from archive to pkg/system. 1063 - Fix duplicate signal for `docker run -i -t` (issue #3336). 1064 - Return correct process pid for lxc. 1065 - Add a -G option to specify the group which unix sockets belong to. 1066 + Add `-f` flag to `docker rm` to force removal of running containers. 1067 + Kill ghost containers and restart all ghost containers when the docker daemon restarts. 1068 + Add `DOCKER_RAMDISK` environment variable to make Docker work when the root is on a ramdisk. 1069 1070 ## 0.8.1 (2014-02-18) 1071 1072 #### Builder 1073 1074 - Avoid extra mount/unmount during build. This removes an unneeded mount/unmount operation which was causing problems with devicemapper 1075 - Fix regression with ADD of tar files. This stops Docker from decompressing tarballs added via ADD from the local file system 1076 - Add error to `docker build --rm`. This adds a missing error check to ensure failures to remove containers are detected and reported 1077 1078 #### Documentation 1079 1080 * Update issue filing instructions 1081 * Warn against the use of symlinks for Docker's storage folder 1082 * Replace the Firefox example with an IceWeasel example 1083 * Rewrite the PostgresSQL example using a Dockerfile and add more details to it 1084 * Improve the OS X documentation 1085 1086 #### Remote API 1087 1088 - Fix broken images API for version less than 1.7 1089 - Use the right encoding for all API endpoints which return JSON 1090 - Move remote api client to api/ 1091 - Queue calls to the API using generic socket wait 1092 1093 #### Runtime 1094 1095 - Fix the use of custom settings for bridges and custom bridges 1096 - Refactor the devicemapper code to avoid many mount/unmount race conditions and failures 1097 - Remove two panics which could make Docker crash in some situations 1098 - Don't ping registry from the CLI client 1099 - Enable skip_block_zeroing for devicemapper. This stops devicemapper from always zeroing entire blocks 1100 - Fix --run in `docker commit`. This makes docker commit store `--run` in the image configuration 1101 - Remove directory when removing devicemapper device. This cleans up leftover mount directories 1102 - Drop NET_ADMIN capability for non-privileged containers. Unprivileged containers can't change their network configuration 1103 - Ensure `docker cp` stream is closed properly 1104 - Avoid extra mount/unmount during container registration. This removes an unneeded mount/unmount operation which was causing problems with devicemapper 1105 - Stop allowing tcp:// as a default tcp bin address which binds to 127.0.0.1:4243 and remove the default port 1106 + Mount-bind the PTY as container console. This allows tmux and screen to run in a container 1107 - Clean up archive closing. This fixes and improves archive handling 1108 - Fix engine tests on systems where temp directories are symlinked 1109 - Add test methods for save and load 1110 - Avoid temporarily unmounting the container when restarting it. This fixes a race for devicemapper during restart 1111 - Support submodules when building from a GitHub repository 1112 - Quote volume path to allow spaces 1113 - Fix remote tar ADD behavior. This fixes a regression which was causing Docker to extract tarballs 1114 1115 ## 0.8.0 (2014-02-04) 1116 1117 #### Notable features since 0.7.0 1118 1119 * Images and containers can be removed much faster 1120 * Building an image from source with docker build is now much faster 1121 * The Docker daemon starts and stops much faster 1122 * The memory footprint of many common operations has been reduced, by streaming files instead of buffering them in memory, fixing memory leaks, and fixing various suboptimal memory allocations 1123 * Several race conditions were fixed, making Docker more stable under very high concurrency load. This makes Docker more stable and less likely to crash and reduces the memory footprint of many common operations 1124 * All packaging operations are now built on the Go language’s standard tar implementation, which is bundled with Docker itself. This makes packaging more portable across host distributions, and solves several issues caused by quirks and incompatibilities between different distributions of tar 1125 * Docker can now create, remove and modify larger numbers of containers and images graciously thanks to more aggressive releasing of system resources. For example the storage driver API now allows Docker to do reference counting on mounts created by the drivers 1126 With the ongoing changes to the networking and execution subsystems of docker testing these areas have been a focus of the refactoring. By moving these subsystems into separate packages we can test, analyze, and monitor coverage and quality of these packages 1127 * Many components have been separated into smaller sub-packages, each with a dedicated test suite. As a result the code is better-tested, more readable and easier to change 1128 1129 * The ADD instruction now supports caching, which avoids unnecessarily re-uploading the same source content again and again when it hasn’t changed 1130 * The new ONBUILD instruction adds to your image a “trigger” instruction to be executed at a later time, when the image is used as the base for another build 1131 * Docker now ships with an experimental storage driver which uses the BTRFS filesystem for copy-on-write 1132 * Docker is officially supported on Mac OS X 1133 * The Docker daemon supports systemd socket activation 1134 1135 ## 0.7.6 (2014-01-14) 1136 1137 #### Builder 1138 1139 * Do not follow symlink outside of build context 1140 1141 #### Runtime 1142 1143 - Remount bind mounts when ro is specified 1144 * Use https for fetching docker version 1145 1146 #### Other 1147 1148 * Inline the test.docker.io fingerprint 1149 * Add ca-certificates to packaging documentation 1150 1151 ## 0.7.5 (2014-01-09) 1152 1153 #### Builder 1154 1155 * Disable compression for build. More space usage but a much faster upload 1156 - Fix ADD caching for certain paths 1157 - Do not compress archive from git build 1158 1159 #### Documentation 1160 1161 - Fix error in GROUP add example 1162 * Make sure the GPG fingerprint is inline in the documentation 1163 * Give more specific advice on setting up signing of commits for DCO 1164 1165 #### Runtime 1166 1167 - Fix misspelled container names 1168 - Do not add hostname when networking is disabled 1169 * Return most recent image from the cache by date 1170 - Return all errors from docker wait 1171 * Add Content-Type Header "application/json" to GET /version and /info responses 1172 1173 #### Other 1174 1175 * Update DCO to version 1.1 1176 + Update Makefile to use "docker:GIT_BRANCH" as the generated image name 1177 * Update Travis to check for new 1.1 DCO version 1178 1179 ## 0.7.4 (2014-01-07) 1180 1181 #### Builder 1182 1183 - Fix ADD caching issue with . prefixed path 1184 - Fix docker build on devicemapper by reverting sparse file tar option 1185 - Fix issue with file caching and prevent wrong cache hit 1186 * Use same error handling while unmarshalling CMD and ENTRYPOINT 1187 1188 #### Documentation 1189 1190 * Simplify and streamline Amazon Quickstart 1191 * Install instructions use unprefixed Fedora image 1192 * Update instructions for mtu flag for Docker on GCE 1193 + Add Ubuntu Saucy to installation 1194 - Fix for wrong version warning on master instead of latest 1195 1196 #### Runtime 1197 1198 - Only get the image's rootfs when we need to calculate the image size 1199 - Correctly handle unmapping UDP ports 1200 * Make CopyFileWithTar use a pipe instead of a buffer to save memory on docker build 1201 - Fix login message to say pull instead of push 1202 - Fix "docker load" help by removing "SOURCE" prompt and mentioning STDIN 1203 * Make blank -H option default to the same as no -H was sent 1204 * Extract cgroups utilities to own submodule 1205 1206 #### Other 1207 1208 + Add Travis CI configuration to validate DCO and gofmt requirements 1209 + Add Developer Certificate of Origin Text 1210 * Upgrade VBox Guest Additions 1211 * Check standalone header when pinging a registry server 1212 1213 ## 0.7.3 (2014-01-02) 1214 1215 #### Builder 1216 1217 + Update ADD to use the image cache, based on a hash of the added content 1218 * Add error message for empty Dockerfile 1219 1220 #### Documentation 1221 1222 - Fix outdated link to the "Introduction" on www.docker.io 1223 + Update the docs to get wider when the screen does 1224 - Add information about needing to install LXC when using raw binaries 1225 * Update Fedora documentation to disentangle the docker and docker.io conflict 1226 * Add a note about using the new `-mtu` flag in several GCE zones 1227 + Add FrugalWare installation instructions 1228 + Add a more complete example of `docker run` 1229 - Fix API documentation for creating and starting Privileged containers 1230 - Add missing "name" parameter documentation on "/containers/create" 1231 * Add a mention of `lxc-checkconfig` as a way to check for some of the necessary kernel configuration 1232 - Update the 1.8 API documentation with some additions that were added to the docs for 1.7 1233 1234 #### Hack 1235 1236 - Add missing libdevmapper dependency to the packagers documentation 1237 * Update minimum Go requirement to a hard line at Go 1.2+ 1238 * Many minor improvements to the Vagrantfile 1239 + Add ability to customize dockerinit search locations when compiling (to be used very sparingly only by packagers of platforms who require a nonstandard location) 1240 + Add coverprofile generation reporting 1241 - Add `-a` to our Go build flags, removing the need for recompiling the stdlib manually 1242 * Update Dockerfile to be more canonical and have less spurious warnings during build 1243 - Fix some miscellaneous `docker pull` progress bar display issues 1244 * Migrate more miscellaneous packages under the "pkg" folder 1245 * Update TextMate highlighting to automatically be enabled for files named "Dockerfile" 1246 * Reorganize syntax highlighting files under a common "contrib/syntax" directory 1247 * Update install.sh script (https://get.docker.io/) to not fail if busybox fails to download or run at the end of the Ubuntu/Debian installation 1248 * Add support for container names in bash completion 1249 1250 #### Packaging 1251 1252 + Add an official Docker client binary for Darwin (Mac OS X) 1253 * Remove empty "Vendor" string and added "License" on deb package 1254 + Add a stubbed version of "/etc/default/docker" in the deb package 1255 1256 #### Runtime 1257 1258 * Update layer application to extract tars in place, avoiding file churn while handling whiteouts 1259 - Fix permissiveness of mtime comparisons in tar handling (since GNU tar and Go tar do not yet support sub-second mtime precision) 1260 * Reimplement `docker top` in pure Go to work more consistently, and even inside Docker-in-Docker (thus removing the shell injection vulnerability present in some versions of `lxc-ps`) 1261 + Update `-H unix://` to work similarly to `-H tcp://` by inserting the default values for missing portions 1262 - Fix more edge cases regarding dockerinit and deleted or replaced docker or dockerinit files 1263 * Update container name validation to include '.' 1264 - Fix use of a symlink or non-absolute path as the argument to `-g` to work as expected 1265 * Update to handle external mounts outside of LXC, fixing many small mounting quirks and making future execution backends and other features simpler 1266 * Update to use proper box-drawing characters everywhere in `docker images -tree` 1267 * Move MTU setting from LXC configuration to directly use netlink 1268 * Add `-S` option to external tar invocation for more efficient spare file handling 1269 + Add arch/os info to User-Agent string, especially for registry requests 1270 + Add `-mtu` option to Docker daemon for configuring MTU 1271 - Fix `docker build` to exit with a non-zero exit code on error 1272 + Add `DOCKER_HOST` environment variable to configure the client `-H` flag without specifying it manually for every invocation 1273 1274 ## 0.7.2 (2013-12-16) 1275 1276 #### Runtime 1277 1278 + Validate container names on creation with standard regex 1279 * Increase maximum image depth to 127 from 42 1280 * Continue to move api endpoints to the job api 1281 + Add -bip flag to allow specification of dynamic bridge IP via CIDR 1282 - Allow bridge creation when ipv6 is not enabled on certain systems 1283 * Set hostname and IP address from within dockerinit 1284 * Drop capabilities from within dockerinit 1285 - Fix volumes on host when symlink is present the image 1286 - Prevent deletion of image if ANY container is depending on it even if the container is not running 1287 * Update docker push to use new progress display 1288 * Use os.Lstat to allow mounting unix sockets when inspecting volumes 1289 - Adjust handling of inactive user login 1290 - Add missing defines in devicemapper for older kernels 1291 - Allow untag operations with no container validation 1292 - Add auth config to docker build 1293 1294 #### Documentation 1295 1296 * Add more information about Docker logging 1297 + Add RHEL documentation 1298 * Add a direct example for changing the CMD that is run in a container 1299 * Update Arch installation documentation 1300 + Add section on Trusted Builds 1301 + Add Network documentation page 1302 1303 #### Other 1304 1305 + Add new cover bundle for providing code coverage reporting 1306 * Separate integration tests in bundles 1307 * Make Tianon the hack maintainer 1308 * Update mkimage-debootstrap with more tweaks for keeping images small 1309 * Use https to get the install script 1310 * Remove vendored dotcloud/tar now that Go 1.2 has been released 1311 1312 ## 0.7.1 (2013-12-05) 1313 1314 #### Documentation 1315 1316 + Add @SvenDowideit as documentation maintainer 1317 + Add links example 1318 + Add documentation regarding ambassador pattern 1319 + Add Google Cloud Platform docs 1320 + Add dockerfile best practices 1321 * Update doc for RHEL 1322 * Update doc for registry 1323 * Update Postgres examples 1324 * Update doc for Ubuntu install 1325 * Improve remote api doc 1326 1327 #### Runtime 1328 1329 + Add hostconfig to docker inspect 1330 + Implement `docker log -f` to stream logs 1331 + Add env variable to disable kernel version warning 1332 + Add -format to `docker inspect` 1333 + Support bind-mount for files 1334 - Fix bridge creation on RHEL 1335 - Fix image size calculation 1336 - Make sure iptables are called even if the bridge already exists 1337 - Fix issue with stderr only attach 1338 - Remove init layer when destroying a container 1339 - Fix same port binding on different interfaces 1340 - `docker build` now returns the correct exit code 1341 - Fix `docker port` to display correct port 1342 - `docker build` now check that the dockerfile exists client side 1343 - `docker attach` now returns the correct exit code 1344 - Remove the name entry when the container does not exist 1345 1346 #### Registry 1347 1348 * Improve progress bars, add ETA for downloads 1349 * Simultaneous pulls now waits for the first to finish instead of failing 1350 - Tag only the top-layer image when pushing to registry 1351 - Fix issue with offline image transfer 1352 - Fix issue preventing using ':' in password for registry 1353 1354 #### Other 1355 1356 + Add pprof handler for debug 1357 + Create a Makefile 1358 * Use stdlib tar that now includes fix 1359 * Improve make.sh test script 1360 * Handle SIGQUIT on the daemon 1361 * Disable verbose during tests 1362 * Upgrade to go1.2 for official build 1363 * Improve unit tests 1364 * The test suite now runs all tests even if one fails 1365 * Refactor C in Go (Devmapper) 1366 - Fix OS X compilation 1367 1368 ## 0.7.0 (2013-11-25) 1369 1370 #### Notable features since 0.6.0 1371 1372 * Storage drivers: choose from aufs, device-mapper, or vfs. 1373 * Standard Linux support: docker now runs on unmodified Linux kernels and all major distributions. 1374 * Links: compose complex software stacks by connecting containers to each other. 1375 * Container naming: organize your containers by giving them memorable names. 1376 * Advanced port redirects: specify port redirects per interface, or keep sensitive ports private. 1377 * Offline transfer: push and pull images to the filesystem without losing information. 1378 * Quality: numerous bugfixes and small usability improvements. Significant increase in test coverage. 1379 1380 ## 0.6.7 (2013-11-21) 1381 1382 #### Runtime 1383 1384 * Improve stability, fixes some race conditions 1385 * Skip the volumes mounted when deleting the volumes of container. 1386 * Fix layer size computation: handle hard links correctly 1387 * Use the work Path for docker cp CONTAINER:PATH 1388 * Fix tmp dir never cleanup 1389 * Speedup docker ps 1390 * More informative error message on name collisions 1391 * Fix nameserver regex 1392 * Always return long id's 1393 * Fix container restart race condition 1394 * Keep published ports on docker stop;docker start 1395 * Fix container networking on Fedora 1396 * Correctly express "any address" to iptables 1397 * Fix network setup when reconnecting to ghost container 1398 * Prevent deletion if image is used by a running container 1399 * Lock around read operations in graph 1400 1401 #### RemoteAPI 1402 1403 * Return full ID on docker rmi 1404 1405 #### Client 1406 1407 + Add -tree option to images 1408 + Offline image transfer 1409 * Exit with status 2 on usage error and display usage on stderr 1410 * Do not forward SIGCHLD to container 1411 * Use string timestamp for docker events -since 1412 1413 #### Other 1414 1415 * Update to go 1.2rc5 1416 + Add /etc/default/docker support to upstart 1417 1418 ## 0.6.6 (2013-11-06) 1419 1420 #### Runtime 1421 1422 * Ensure container name on register 1423 * Fix regression in /etc/hosts 1424 + Add lock around write operations in graph 1425 * Check if port is valid 1426 * Fix restart runtime error with ghost container networking 1427 + Add some more colors and animals to increase the pool of generated names 1428 * Fix issues in docker inspect 1429 + Escape apparmor confinement 1430 + Set environment variables using a file. 1431 * Prevent docker insert to erase something 1432 + Prevent DNS server conflicts in CreateBridgeIface 1433 + Validate bind mounts on the server side 1434 + Use parent image config in docker build 1435 * Fix regression in /etc/hosts 1436 1437 #### Client 1438 1439 + Add -P flag to publish all exposed ports 1440 + Add -notrunc and -q flags to docker history 1441 * Fix docker commit, tag and import usage 1442 + Add stars, trusted builds and library flags in docker search 1443 * Fix docker logs with tty 1444 1445 #### RemoteAPI 1446 1447 * Make /events API send headers immediately 1448 * Do not split last column docker top 1449 + Add size to history 1450 1451 #### Other 1452 1453 + Contrib: Desktop integration. Firefox usecase. 1454 + Dockerfile: bump to go1.2rc3 1455 1456 ## 0.6.5 (2013-10-29) 1457 1458 #### Runtime 1459 1460 + Containers can now be named 1461 + Containers can now be linked together for service discovery 1462 + 'run -a', 'start -a' and 'attach' can forward signals to the container for better integration with process supervisors 1463 + Automatically start crashed containers after a reboot 1464 + Expose IP, port, and proto as separate environment vars for container links 1465 * Allow ports to be published to specific ips 1466 * Prohibit inter-container communication by default 1467 - Ignore ErrClosedPipe for stdin in Container.Attach 1468 - Remove unused field kernelVersion 1469 * Fix issue when mounting subdirectories of /mnt in container 1470 - Fix untag during removal of images 1471 * Check return value of syscall.Chdir when changing working directory inside dockerinit 1472 1473 #### Client 1474 1475 - Only pass stdin to hijack when needed to avoid closed pipe errors 1476 * Use less reflection in command-line method invocation 1477 - Monitor the tty size after starting the container, not prior 1478 - Remove useless os.Exit() calls after log.Fatal 1479 1480 #### Hack 1481 1482 + Add initial init scripts library and a safer Ubuntu packaging script that works for Debian 1483 * Add -p option to invoke debootstrap with http_proxy 1484 - Update install.sh with $sh_c to get sudo/su for modprobe 1485 * Update all the mkimage scripts to use --numeric-owner as a tar argument 1486 * Update hack/release.sh process to automatically invoke hack/make.sh and bail on build and test issues 1487 1488 #### Other 1489 1490 * Documentation: Fix the flags for nc in example 1491 * Testing: Remove warnings and prevent mount issues 1492 - Testing: Change logic for tty resize to avoid warning in tests 1493 - Builder: Fix race condition in docker build with verbose output 1494 - Registry: Fix content-type for PushImageJSONIndex method 1495 * Contrib: Improve helper tools to generate debian and Arch linux server images 1496 1497 ## 0.6.4 (2013-10-16) 1498 1499 #### Runtime 1500 1501 - Add cleanup of container when Start() fails 1502 * Add better comments to utils/stdcopy.go 1503 * Add utils.Errorf for error logging 1504 + Add -rm to docker run for removing a container on exit 1505 - Remove error messages which are not actually errors 1506 - Fix `docker rm` with volumes 1507 - Fix some error cases where a HTTP body might not be closed 1508 - Fix panic with wrong dockercfg file 1509 - Fix the attach behavior with -i 1510 * Record termination time in state. 1511 - Use empty string so TempDir uses the OS's temp dir automatically 1512 - Make sure to close the network allocators 1513 + Autorestart containers by default 1514 * Bump vendor kr/pty to commit 3b1f6487b `(syscall.O_NOCTTY)` 1515 * lxc: Allow set_file_cap capability in container 1516 - Move run -rm to the cli only 1517 * Split stdout stderr 1518 * Always create a new session for the container 1519 1520 #### Testing 1521 1522 - Add aggregated docker-ci email report 1523 - Add cleanup to remove leftover containers 1524 * Add nightly release to docker-ci 1525 * Add more tests around auth.ResolveAuthConfig 1526 - Remove a few errors in tests 1527 - Catch errClosing error when TCP and UDP proxies are terminated 1528 * Only run certain tests with TESTFLAGS='-run TestName' make.sh 1529 * Prevent docker-ci to test closing PRs 1530 * Replace panic by log.Fatal in tests 1531 - Increase TestRunDetach timeout 1532 1533 #### Documentation 1534 1535 * Add initial draft of the Docker infrastructure doc 1536 * Add devenvironment link to CONTRIBUTING.md 1537 * Add `apt-get install curl` to Ubuntu docs 1538 * Add explanation for export restrictions 1539 * Add .dockercfg doc 1540 * Remove Gentoo install notes about #1422 workaround 1541 * Fix help text for -v option 1542 * Fix Ping endpoint documentation 1543 - Fix parameter names in docs for ADD command 1544 - Fix ironic typo in changelog 1545 * Various command fixes in postgres example 1546 * Document how to edit and release docs 1547 - Minor updates to `postgresql_service.rst` 1548 * Clarify LGTM process to contributors 1549 - Corrected error in the package name 1550 * Document what `vagrant up` is actually doing 1551 + improve doc search results 1552 * Cleanup whitespace in API 1.5 docs 1553 * use angle brackets in MAINTAINER example email 1554 * Update archlinux.rst 1555 + Changes to a new style for the docs. Includes version switcher. 1556 * Formatting, add information about multiline json 1557 * Improve registry and index REST API documentation 1558 - Replace deprecated upgrading reference to docker-latest.tgz, which hasn't been updated since 0.5.3 1559 * Update Gentoo installation documentation now that we're in the portage tree proper 1560 * Cleanup and reorganize docs and tooling for contributors and maintainers 1561 - Minor spelling correction of protocoll -> protocol 1562 1563 #### Contrib 1564 1565 * Add vim syntax highlighting for Dockerfiles from @honza 1566 * Add mkimage-arch.sh 1567 * Reorganize contributed completion scripts to add zsh completion 1568 1569 #### Hack 1570 1571 * Add vagrant user to the docker group 1572 * Add proper bash completion for "docker push" 1573 * Add xz utils as a runtime dep 1574 * Add cleanup/refactor portion of #2010 for hack and Dockerfile updates 1575 + Add contrib/mkimage-centos.sh back (from #1621), and associated documentation link 1576 * Add several of the small make.sh fixes from #1920, and make the output more consistent and contributor-friendly 1577 + Add @tianon to hack/MAINTAINERS 1578 * Improve network performance for VirtualBox 1579 * Revamp install.sh to be usable by more people, and to use official install methods whenever possible (apt repo, portage tree, etc.) 1580 - Fix contrib/mkimage-debian.sh apt caching prevention 1581 + Add Dockerfile.tmLanguage to contrib 1582 * Configured FPM to make /etc/init/docker.conf a config file 1583 * Enable SSH Agent forwarding in Vagrant VM 1584 * Several small tweaks/fixes for contrib/mkimage-debian.sh 1585 1586 #### Other 1587 1588 - Builder: Abort build if mergeConfig returns an error and fix duplicate error message 1589 - Packaging: Remove deprecated packaging directory 1590 - Registry: Use correct auth config when logging in. 1591 - Registry: Fix the error message so it is the same as the regex 1592 1593 ## 0.6.3 (2013-09-23) 1594 1595 #### Packaging 1596 1597 * Add 'docker' group on install for ubuntu package 1598 * Update tar vendor dependency 1599 * Download apt key over HTTPS 1600 1601 #### Runtime 1602 1603 - Only copy and change permissions on non-bindmount volumes 1604 * Allow multiple volumes-from 1605 - Fix HTTP imports from STDIN 1606 1607 #### Documentation 1608 1609 * Update section on extracting the docker binary after build 1610 * Update development environment docs for new build process 1611 * Remove 'base' image from documentation 1612 1613 #### Other 1614 1615 - Client: Fix detach issue 1616 - Registry: Update regular expression to match index 1617 1618 ## 0.6.2 (2013-09-17) 1619 1620 #### Runtime 1621 1622 + Add domainname support 1623 + Implement image filtering with path.Match 1624 * Remove unnecessary warnings 1625 * Remove os/user dependency 1626 * Only mount the hostname file when the config exists 1627 * Handle signals within the `docker login` command 1628 - UID and GID are now also applied to volumes 1629 - `docker start` set error code upon error 1630 - `docker run` set the same error code as the process started 1631 1632 #### Builder 1633 1634 + Add -rm option in order to remove intermediate containers 1635 * Allow multiline for the RUN instruction 1636 1637 #### Registry 1638 1639 * Implement login with private registry 1640 - Fix push issues 1641 1642 #### Other 1643 1644 + Hack: Vendor all dependencies 1645 * Remote API: Bump to v1.5 1646 * Packaging: Break down hack/make.sh into small scripts, one per 'bundle': test, binary, ubuntu etc. 1647 * Documentation: General improvements 1648 1649 ## 0.6.1 (2013-08-23) 1650 1651 #### Registry 1652 1653 * Pass "meta" headers in API calls to the registry 1654 1655 #### Packaging 1656 1657 - Use correct upstart script with new build tool 1658 - Use libffi-dev, don`t build it from sources 1659 - Remove duplicate mercurial install command 1660 1661 ## 0.6.0 (2013-08-22) 1662 1663 #### Runtime 1664 1665 + Add lxc-conf flag to allow custom lxc options 1666 + Add an option to set the working directory 1667 * Add Image name to LogEvent tests 1668 + Add -privileged flag and relevant tests, docs, and examples 1669 * Add websocket support to /container/<name>/attach/ws 1670 * Add warning when net.ipv4.ip_forwarding = 0 1671 * Add hostname to environment 1672 * Add last stable version in `docker version` 1673 - Fix race conditions in parallel pull 1674 - Fix Graph ByParent() to generate list of child images per parent image. 1675 - Fix typo: fmt.Sprint -> fmt.Sprintf 1676 - Fix small \n error un docker build 1677 * Fix to "Inject dockerinit at /.dockerinit" 1678 * Fix #910. print user name to docker info output 1679 * Use Go 1.1.2 for dockerbuilder 1680 * Use ranged for loop on channels 1681 - Use utils.ParseRepositoryTag instead of strings.Split(name, ":") in server.ImageDelete 1682 - Improve CMD, ENTRYPOINT, and attach docs. 1683 - Improve connect message with socket error 1684 - Load authConfig only when needed and fix useless WARNING 1685 - Show tag used when image is missing 1686 * Apply volumes-from before creating volumes 1687 - Make docker run handle SIGINT/SIGTERM 1688 - Prevent crash when .dockercfg not readable 1689 - Install script should be fetched over https, not http. 1690 * API, issue 1471: Use groups for socket permissions 1691 - Correctly detect IPv4 forwarding 1692 * Mount /dev/shm as a tmpfs 1693 - Switch from http to https for get.docker.io 1694 * Let userland proxy handle container-bound traffic 1695 * Update the Docker CLI to specify a value for the "Host" header. 1696 - Change network range to avoid conflict with EC2 DNS 1697 - Reduce connect and read timeout when pinging the registry 1698 * Parallel pull 1699 - Handle ip route showing mask-less IP addresses 1700 * Allow ENTRYPOINT without CMD 1701 - Always consider localhost as a domain name when parsing the FQN repos name 1702 * Refactor checksum 1703 1704 #### Documentation 1705 1706 * Add MongoDB image example 1707 * Add instructions for creating and using the docker group 1708 * Add sudo to examples and installation to documentation 1709 * Add ufw doc 1710 * Add a reference to ps -a 1711 * Add information about Docker`s high level tools over LXC. 1712 * Fix typo in docs for docker run -dns 1713 * Fix a typo in the ubuntu installation guide 1714 * Fix to docs regarding adding docker groups 1715 * Update default -H docs 1716 * Update readme with dependencies for building 1717 * Update amazon.rst to explain that Vagrant is not necessary for running Docker on ec2 1718 * PostgreSQL service example in documentation 1719 * Suggest installing linux-headers by default. 1720 * Change the twitter handle 1721 * Clarify Amazon EC2 installation 1722 * 'Base' image is deprecated and should no longer be referenced in the docs. 1723 * Move note about officially supported kernel 1724 - Solved the logo being squished in Safari 1725 1726 #### Builder 1727 1728 + Add USER instruction do Dockerfile 1729 + Add workdir support for the Buildfile 1730 * Add no cache for docker build 1731 - Fix docker build and docker events output 1732 - Only count known instructions as build steps 1733 - Make sure ENV instruction within build perform a commit each time 1734 - Forbid certain paths within docker build ADD 1735 - Repository name (and optionally a tag) in build usage 1736 - Make sure ADD will create everything in 0755 1737 1738 #### Remote API 1739 1740 * Sort Images by most recent creation date. 1741 * Reworking opaque requests in registry module 1742 * Add image name in /events 1743 * Use mime pkg to parse Content-Type 1744 * 650 http utils and user agent field 1745 1746 #### Hack 1747 1748 + Bash Completion: Limit commands to containers of a relevant state 1749 * Add docker dependencies coverage testing into docker-ci 1750 1751 #### Packaging 1752 1753 + Docker-brew 0.5.2 support and memory footprint reduction 1754 * Add new docker dependencies into docker-ci 1755 - Revert "docker.upstart: avoid spawning a `sh` process" 1756 + Docker-brew and Docker standard library 1757 + Release docker with docker 1758 * Fix the upstart script generated by get.docker.io 1759 * Enabled the docs to generate manpages. 1760 * Revert Bind daemon to 0.0.0.0 in Vagrant. 1761 1762 #### Register 1763 1764 * Improve auth push 1765 * Registry unit tests + mock registry 1766 1767 #### Tests 1768 1769 * Improve TestKillDifferentUser to prevent timeout on buildbot 1770 - Fix typo in TestBindMounts (runContainer called without image) 1771 * Improve TestGetContainersTop so it does not rely on sleep 1772 * Relax the lo interface test to allow iface index != 1 1773 * Add registry functional test to docker-ci 1774 * Add some tests in server and utils 1775 1776 #### Other 1777 1778 * Contrib: bash completion script 1779 * Client: Add docker cp command and copy api endpoint to copy container files/folders to the host 1780 * Don`t read from stdout when only attached to stdin 1781 1782 ## 0.5.3 (2013-08-13) 1783 1784 #### Runtime 1785 1786 * Use docker group for socket permissions 1787 - Spawn shell within upstart script 1788 - Handle ip route showing mask-less IP addresses 1789 - Add hostname to environment 1790 1791 #### Builder 1792 1793 - Make sure ENV instruction within build perform a commit each time 1794 1795 ## 0.5.2 (2013-08-08) 1796 1797 * Builder: Forbid certain paths within docker build ADD 1798 - Runtime: Change network range to avoid conflict with EC2 DNS 1799 * API: Change daemon to listen on unix socket by default 1800 1801 ## 0.5.1 (2013-07-30) 1802 1803 #### Runtime 1804 1805 + Add `ps` args to `docker top` 1806 + Add support for container ID files (pidfile like) 1807 + Add container=lxc in default env 1808 + Support networkless containers with `docker run -n` and `docker -d -b=none` 1809 * Stdout/stderr logs are now stored in the same file as JSON 1810 * Allocate a /16 IP range by default, with fallback to /24. Try 12 ranges instead of 3. 1811 * Change .dockercfg format to json and support multiple auth remote 1812 - Do not override volumes from config 1813 - Fix issue with EXPOSE override 1814 1815 #### API 1816 1817 + Docker client now sets useragent (RFC 2616) 1818 + Add /events endpoint 1819 1820 #### Builder 1821 1822 + ADD command now understands URLs 1823 + CmdAdd and CmdEnv now respect Dockerfile-set ENV variables 1824 - Create directories with 755 instead of 700 within ADD instruction 1825 1826 #### Hack 1827 1828 * Simplify unit tests with helpers 1829 * Improve docker.upstart event 1830 * Add coverage testing into docker-ci 1831 1832 ## 0.5.0 (2013-07-17) 1833 1834 #### Runtime 1835 1836 + List all processes running inside a container with 'docker top' 1837 + Host directories can be mounted as volumes with 'docker run -v' 1838 + Containers can expose public UDP ports (eg, '-p 123/udp') 1839 + Optionally specify an exact public port (eg. '-p 80:4500') 1840 * 'docker login' supports additional options 1841 - Don't save a container`s hostname when committing an image. 1842 1843 #### Registry 1844 1845 + New image naming scheme inspired by Go packaging convention allows arbitrary combinations of registries 1846 - Fix issues when uploading images to a private registry 1847 1848 #### Builder 1849 1850 + ENTRYPOINT instruction sets a default binary entry point to a container 1851 + VOLUME instruction marks a part of the container as persistent data 1852 * 'docker build' displays the full output of a build by default 1853 1854 ## 0.4.8 (2013-07-01) 1855 1856 + Builder: New build operation ENTRYPOINT adds an executable entry point to the container. - Runtime: Fix a bug which caused 'docker run -d' to no longer print the container ID. 1857 - Tests: Fix issues in the test suite 1858 1859 ## 0.4.7 (2013-06-28) 1860 1861 #### Remote API 1862 1863 * The progress bar updates faster when downloading and uploading large files 1864 - Fix a bug in the optional unix socket transport 1865 1866 #### Runtime 1867 1868 * Improve detection of kernel version 1869 + Host directories can be mounted as volumes with 'docker run -b' 1870 - fix an issue when only attaching to stdin 1871 * Use 'tar --numeric-owner' to avoid uid mismatch across multiple hosts 1872 1873 #### Hack 1874 1875 * Improve test suite and dev environment 1876 * Remove dependency on unit tests on 'os/user' 1877 1878 #### Other 1879 1880 * Registry: easier push/pull to a custom registry 1881 + Documentation: add terminology section 1882 1883 ## 0.4.6 (2013-06-22) 1884 1885 - Runtime: fix a bug which caused creation of empty images (and volumes) to crash. 1886 1887 ## 0.4.5 (2013-06-21) 1888 1889 + Builder: 'docker build git://URL' fetches and builds a remote git repository 1890 * Runtime: 'docker ps -s' optionally prints container size 1891 * Tests: improved and simplified 1892 - Runtime: fix a regression introduced in 0.4.3 which caused the logs command to fail. 1893 - Builder: fix a regression when using ADD with single regular file. 1894 1895 ## 0.4.4 (2013-06-19) 1896 1897 - Builder: fix a regression introduced in 0.4.3 which caused builds to fail on new clients. 1898 1899 ## 0.4.3 (2013-06-19) 1900 1901 #### Builder 1902 1903 + ADD of a local file will detect tar archives and unpack them 1904 * ADD improvements: use tar for copy + automatically unpack local archives 1905 * ADD uses tar/untar for copies instead of calling 'cp -ar' 1906 * Fix the behavior of ADD to be (mostly) reverse-compatible, predictable and well-documented. 1907 - Fix a bug which caused builds to fail if ADD was the first command 1908 * Nicer output for 'docker build' 1909 1910 #### Runtime 1911 1912 * Remove bsdtar dependency 1913 * Add unix socket and multiple -H support 1914 * Prevent rm of running containers 1915 * Use go1.1 cookiejar 1916 - Fix issue detaching from running TTY container 1917 - Forbid parallel push/pull for a single image/repo. Fixes #311 1918 - Fix race condition within Run command when attaching. 1919 1920 #### Client 1921 1922 * HumanReadable ProgressBar sizes in pull 1923 * Fix docker version`s git commit output 1924 1925 #### API 1926 1927 * Send all tags on History API call 1928 * Add tag lookup to history command. Fixes #882 1929 1930 #### Documentation 1931 1932 - Fix missing command in irc bouncer example 1933 1934 ## 0.4.2 (2013-06-17) 1935 1936 - Packaging: Bumped version to work around an Ubuntu bug 1937 1938 ## 0.4.1 (2013-06-17) 1939 1940 #### Remote Api 1941 1942 + Add flag to enable cross domain requests 1943 + Add images and containers sizes in docker ps and docker images 1944 1945 #### Runtime 1946 1947 + Configure dns configuration host-wide with 'docker -d -dns' 1948 + Detect faulty DNS configuration and replace it with a public default 1949 + Allow docker run <name>:<id> 1950 + You can now specify public port (ex: -p 80:4500) 1951 * Improve image removal to garbage-collect unreferenced parents 1952 1953 #### Client 1954 1955 * Allow multiple params in inspect 1956 * Print the container id before the hijack in `docker run` 1957 1958 #### Registry 1959 1960 * Add regexp check on repo`s name 1961 * Move auth to the client 1962 - Remove login check on pull 1963 1964 #### Other 1965 1966 * Vagrantfile: Add the rest api port to vagrantfile`s port_forward 1967 * Upgrade to Go 1.1 1968 - Builder: don`t ignore last line in Dockerfile when it doesn`t end with \n 1969 1970 ## 0.4.0 (2013-06-03) 1971 1972 #### Builder 1973 1974 + Introducing Builder 1975 + 'docker build' builds a container, layer by layer, from a source repository containing a Dockerfile 1976 1977 #### Remote API 1978 1979 + Introducing Remote API 1980 + control Docker programmatically using a simple HTTP/json API 1981 1982 #### Runtime 1983 1984 * Various reliability and usability improvements 1985 1986 ## 0.3.4 (2013-05-30) 1987 1988 #### Builder 1989 1990 + 'docker build' builds a container, layer by layer, from a source repository containing a Dockerfile 1991 + 'docker build -t FOO' applies the tag FOO to the newly built container. 1992 1993 #### Runtime 1994 1995 + Interactive TTYs correctly handle window resize 1996 * Fix how configuration is merged between layers 1997 1998 #### Remote API 1999 2000 + Split stdout and stderr on 'docker run' 2001 + Optionally listen on a different IP and port (use at your own risk) 2002 2003 #### Documentation 2004 2005 * Improve install instructions. 2006 2007 ## 0.3.3 (2013-05-23) 2008 2009 - Registry: Fix push regression 2010 - Various bugfixes 2011 2012 ## 0.3.2 (2013-05-09) 2013 2014 #### Registry 2015 2016 * Improve the checksum process 2017 * Use the size to have a good progress bar while pushing 2018 * Use the actual archive if it exists in order to speed up the push 2019 - Fix error 400 on push 2020 2021 #### Runtime 2022 2023 * Store the actual archive on commit 2024 2025 ## 0.3.1 (2013-05-08) 2026 2027 #### Builder 2028 2029 + Implement the autorun capability within docker builder 2030 + Add caching to docker builder 2031 + Add support for docker builder with native API as top level command 2032 + Implement ENV within docker builder 2033 - Check the command existence prior create and add Unit tests for the case 2034 * use any whitespaces instead of tabs 2035 2036 #### Runtime 2037 2038 + Add go version to debug infos 2039 * Kernel version - don`t show the dash if flavor is empty 2040 2041 #### Registry 2042 2043 + Add docker search top level command in order to search a repository 2044 - Fix pull for official images with specific tag 2045 - Fix issue when login in with a different user and trying to push 2046 * Improve checksum - async calculation 2047 2048 #### Images 2049 2050 + Output graph of images to dot (graphviz) 2051 - Fix ByParent function 2052 2053 #### Documentation 2054 2055 + New introduction and high-level overview 2056 + Add the documentation for docker builder 2057 - CSS fix for docker documentation to make REST API docs look better. 2058 - Fix CouchDB example page header mistake 2059 - Fix README formatting 2060 * Update www.docker.io website. 2061 2062 #### Other 2063 2064 + Website: new high-level overview 2065 - Makefile: Swap "go get" for "go get -d", especially to compile on go1.1rc 2066 * Packaging: packaging ubuntu; issue #510: Use goland-stable PPA package to build docker 2067 2068 ## 0.3.0 (2013-05-06) 2069 2070 #### Runtime 2071 2072 - Fix the command existence check 2073 - strings.Split may return an empty string on no match 2074 - Fix an index out of range crash if cgroup memory is not 2075 2076 #### Documentation 2077 2078 * Various improvements 2079 + New example: sharing data between 2 couchdb databases 2080 2081 #### Other 2082 2083 * Vagrant: Use only one deb line in /etc/apt 2084 + Registry: Implement the new registry 2085 2086 ## 0.2.2 (2013-05-03) 2087 2088 + Support for data volumes ('docker run -v=PATH') 2089 + Share data volumes between containers ('docker run -volumes-from') 2090 + Improve documentation 2091 * Upgrade to Go 1.0.3 2092 * Various upgrades to the dev environment for contributors 2093 2094 ## 0.2.1 (2013-05-01) 2095 2096 + 'docker commit -run' bundles a layer with default runtime options: command, ports etc. 2097 * Improve install process on Vagrant 2098 + New Dockerfile operation: "maintainer" 2099 + New Dockerfile operation: "expose" 2100 + New Dockerfile operation: "cmd" 2101 + Contrib script to build a Debian base layer 2102 + 'docker -d -r': restart crashed containers at daemon startup 2103 * Runtime: improve test coverage 2104 2105 ## 0.2.0 (2013-04-23) 2106 2107 - Runtime: ghost containers can be killed and waited for 2108 * Documentation: update install instructions 2109 - Packaging: fix Vagrantfile 2110 - Development: automate releasing binaries and ubuntu packages 2111 + Add a changelog 2112 - Various bugfixes 2113 2114 ## 0.1.8 (2013-04-22) 2115 2116 - Dynamically detect cgroup capabilities 2117 - Issue stability warning on kernels <3.8 2118 - 'docker push' buffers on disk instead of memory 2119 - Fix 'docker diff' for removed files 2120 - Fix 'docker stop' for ghost containers 2121 - Fix handling of pidfile 2122 - Various bugfixes and stability improvements 2123 2124 ## 0.1.7 (2013-04-18) 2125 2126 - Container ports are available on localhost 2127 - 'docker ps' shows allocated TCP ports 2128 - Contributors can run 'make hack' to start a continuous integration VM 2129 - Streamline ubuntu packaging & uploading 2130 - Various bugfixes and stability improvements 2131 2132 ## 0.1.6 (2013-04-17) 2133 2134 - Record the author an image with 'docker commit -author' 2135 2136 ## 0.1.5 (2013-04-17) 2137 2138 - Disable standalone mode 2139 - Use a custom DNS resolver with 'docker -d -dns' 2140 - Detect ghost containers 2141 - Improve diagnosis of missing system capabilities 2142 - Allow disabling memory limits at compile time 2143 - Add debian packaging 2144 - Documentation: installing on Arch Linux 2145 - Documentation: running Redis on docker 2146 - Fix lxc 0.9 compatibility 2147 - Automatically load aufs module 2148 - Various bugfixes and stability improvements 2149 2150 ## 0.1.4 (2013-04-09) 2151 2152 - Full support for TTY emulation 2153 - Detach from a TTY session with the escape sequence `C-p C-q` 2154 - Various bugfixes and stability improvements 2155 - Minor UI improvements 2156 - Automatically create our own bridge interface 'docker0' 2157 2158 ## 0.1.3 (2013-04-04) 2159 2160 - Choose TCP frontend port with '-p :PORT' 2161 - Layer format is versioned 2162 - Major reliability improvements to the process manager 2163 - Various bugfixes and stability improvements 2164 2165 ## 0.1.2 (2013-04-03) 2166 2167 - Set container hostname with 'docker run -h' 2168 - Selective attach at run with 'docker run -a [stdin[,stdout[,stderr]]]' 2169 - Various bugfixes and stability improvements 2170 - UI polish 2171 - Progress bar on push/pull 2172 - Use XZ compression by default 2173 - Make IP allocator lazy 2174 2175 ## 0.1.1 (2013-03-31) 2176 2177 - Display shorthand IDs for convenience 2178 - Stabilize process management 2179 - Layers can include a commit message 2180 - Simplified 'docker attach' 2181 - Fix support for re-attaching 2182 - Various bugfixes and stability improvements 2183 - Auto-download at run 2184 - Auto-login on push 2185 - Beefed up documentation 2186 2187 ## 0.1.0 (2013-03-23) 2188 2189 Initial public release 2190 2191 - Implement registry in order to push/pull images 2192 - TCP port allocation 2193 - Fix termcaps on Linux 2194 - Add documentation 2195 - Add Vagrant support with Vagrantfile 2196 - Add unit tests 2197 - Add repository/tags to ease image management 2198 - Improve the layer implementation