github.com/jingleWang/moby@v1.13.1/docs/api/version-history.md (about)

     1  ---
     2  title: "Engine API version history"
     3  description: "Documentation of changes that have been made to Engine API."
     4  keywords: "API, Docker, rcli, REST, documentation"
     5  ---
     6  
     7  <!-- This file is maintained within the docker/docker Github
     8       repository at https://github.com/docker/docker/. Make all
     9       pull requests against that repo. If you see this file in
    10       another repository, consider it read-only there, as it will
    11       periodically be overwritten by the definitive file. Pull
    12       requests which include edits to this file in other repositories
    13       will be rejected.
    14  -->
    15  
    16  ## v1.26 API changes
    17  
    18  [Docker Engine API v1.26](https://docs.docker.com/engine/api/v1.26/) documentation
    19  
    20  * `POST /plugins/(plugin name)/upgrade` upgrade a plugin.
    21  
    22  ## v1.25 API changes
    23  
    24  [Docker Engine API v1.25](https://docs.docker.com/engine/api/v1.25/) documentation
    25  
    26  * The API version is now required in all API calls. Instead of just requesting, for example, the URL `/containers/json`, you must now request `/v1.25/containers/json`.
    27  * `GET /version` now returns `MinAPIVersion`.
    28  * `POST /build` accepts `networkmode` parameter to specify network used during build.
    29  * `GET /images/(name)/json` now returns `OsVersion` if populated
    30  * `GET /info` now returns `Isolation`.
    31  * `POST /containers/create` now takes `AutoRemove` in HostConfig, to enable auto-removal of the container on daemon side when the container's process exits.
    32  * `GET /containers/json` and `GET /containers/(id or name)/json` now return `"removing"` as a value for the `State.Status` field if the container is being removed. Previously, "exited" was returned as status.
    33  * `GET /containers/json` now accepts `removing` as a valid value for the `status` filter.
    34  * `GET /containers/json` now supports filtering containers by `health` status.
    35  * `DELETE /volumes/(name)` now accepts a `force` query parameter to force removal of volumes that were already removed out of band by the volume driver plugin.
    36  * `POST /containers/create/` and `POST /containers/(name)/update` now validates restart policies.
    37  * `POST /containers/create` now validates IPAMConfig in NetworkingConfig, and returns error for invalid IPv4 and IPv6 addresses (`--ip` and `--ip6` in `docker create/run`).
    38  * `POST /containers/create` now takes a `Mounts` field in `HostConfig` which replaces `Binds`, `Volumes`, and `Tmpfs`. *note*: `Binds`, `Volumes`, and `Tmpfs` are still available and can be combined with `Mounts`.
    39  * `POST /build` now performs a preliminary validation of the `Dockerfile` before starting the build, and returns an error if the syntax is incorrect. Note that this change is _unversioned_ and applied to all API versions.
    40  * `POST /build` accepts `cachefrom` parameter to specify images used for build cache.
    41  * `GET /networks/` endpoint now correctly returns a list of *all* networks,
    42    instead of the default network if a trailing slash is provided, but no `name`
    43    or `id`.
    44  * `DELETE /containers/(name)` endpoint now returns an error of `removal of container name is already in progress` with status code of 400, when container name is in a state of removal in progress.
    45  * `GET /containers/json` now supports a `is-task` filter to filter
    46    containers that are tasks (part of a service in swarm mode).
    47  * `POST /containers/create` now takes `StopTimeout` field.
    48  * `POST /services/create` and `POST /services/(id or name)/update` now accept `Monitor` and `MaxFailureRatio` parameters, which control the response to failures during service updates.
    49  * `POST /services/(id or name)/update` now accepts a `ForceUpdate` parameter inside the `TaskTemplate`, which causes the service to be updated even if there are no changes which would ordinarily trigger an update.
    50  * `POST /services/create` and `POST /services/(id or name)/update` now return a `Warnings` array.
    51  * `GET /networks/(name)` now returns field `Created` in response to show network created time.
    52  * `POST /containers/(id or name)/exec` now accepts an `Env` field, which holds a list of environment variables to be set in the context of the command execution.
    53  * `GET /volumes`, `GET /volumes/(name)`, and `POST /volumes/create` now return the `Options` field which holds the driver specific options to use for when creating the volume.
    54  * `GET /exec/(id)/json` now returns `Pid`, which is the system pid for the exec'd process.
    55  * `POST /containers/prune` prunes stopped containers.
    56  * `POST /images/prune` prunes unused images.
    57  * `POST /volumes/prune` prunes unused volumes.
    58  * `POST /networks/prune` prunes unused networks.
    59  * Every API response now includes a `Docker-Experimental` header specifying if experimental features are enabled (value can be `true` or `false`).
    60  * Every API response now includes a `API-Version` header specifying the default API version of the server.
    61  * The `hostConfig` option now accepts the fields `CpuRealtimePeriod` and `CpuRtRuntime` to allocate cpu runtime to rt tasks when `CONFIG_RT_GROUP_SCHED` is enabled in the kernel.
    62  * The `SecurityOptions` field within the `GET /info` response now includes `userns` if user namespaces are enabled in the daemon.
    63  * `GET /nodes` and `GET /node/(id or name)` now return `Addr` as part of a node's `Status`, which is the address that that node connects to the manager from.
    64  * The `HostConfig` field now includes `NanoCPUs` that represents CPU quota in units of 10<sup>-9</sup> CPUs.
    65  * `GET /info` now returns more structured information about security options.
    66  * The `HostConfig` field now includes `CpuCount` that represents the number of CPUs available for execution by the container. Windows daemon only.
    67  * `POST /services/create` and `POST /services/(id or name)/update` now accept the `TTY` parameter, which allocate a pseudo-TTY in container.
    68  * `POST /services/create` and `POST /services/(id or name)/update` now accept the `DNSConfig` parameter, which specifies DNS related configurations in resolver configuration file (resolv.conf) through `Nameservers`, `Search`, and `Options`.
    69  * `GET /networks/(id or name)` now includes IP and name of all peers nodes for swarm mode overlay networks.
    70  * `GET /plugins` list plugins.
    71  * `POST /plugins/pull?name=<plugin name>` pulls a plugin.
    72  * `GET /plugins/(plugin name)` inspect a plugin.
    73  * `POST /plugins/(plugin name)/set` configure a plugin.
    74  * `POST /plugins/(plugin name)/enable` enable a plugin.
    75  * `POST /plugins/(plugin name)/disable` disable a plugin.
    76  * `POST /plugins/(plugin name)/push` push a plugin.
    77  * `POST /plugins/create?name=(plugin name)` create a plugin.
    78  * `DELETE /plugins/(plugin name)` delete a plugin.
    79  * `POST /node/(id or name)/update` now accepts both `id` or `name` to identify the node to update.
    80  * `GET /images/json` now support a `reference` filter.
    81  * `GET /secrets` returns information on the secrets.
    82  * `POST /secrets/create` creates a secret.
    83  * `DELETE /secrets/{id}` removes the secret `id`.
    84  * `GET /secrets/{id}` returns information on the secret `id`.
    85  * `POST /secrets/{id}/update` updates the secret `id`.
    86  
    87  ## v1.24 API changes
    88  
    89  [Docker Engine API v1.24](v1.24.md) documentation
    90  
    91  * `POST /containers/create` now takes `StorageOpt` field.
    92  * `GET /info` now returns `SecurityOptions` field, showing if `apparmor`, `seccomp`, or `selinux` is supported.
    93  * `GET /info` no longer returns the `ExecutionDriver` property. This property was no longer used after integration
    94    with ContainerD in Docker 1.11.
    95  * `GET /networks` now supports filtering by `label` and `driver`.
    96  * `GET /containers/json` now supports filtering containers by `network` name or id.
    97  * `POST /containers/create` now takes `IOMaximumBandwidth` and `IOMaximumIOps` fields. Windows daemon only.
    98  * `POST /containers/create` now returns an HTTP 400 "bad parameter" message
    99    if no command is specified (instead of an HTTP 500 "server error")
   100  * `GET /images/search` now takes a `filters` query parameter.
   101  * `GET /events` now supports a `reload` event that is emitted when the daemon configuration is reloaded.
   102  * `GET /events` now supports filtering by daemon name or ID.
   103  * `GET /events` now supports a `detach` event that is emitted on detaching from container process.
   104  * `GET /events` now supports an `exec_detach ` event that is emitted on detaching from exec process.
   105  * `GET /images/json` now supports filters `since` and `before`.
   106  * `POST /containers/(id or name)/start` no longer accepts a `HostConfig`.
   107  * `POST /images/(name)/tag` no longer has a `force` query parameter.
   108  * `GET /images/search` now supports maximum returned search results `limit`.
   109  * `POST /containers/{name:.*}/copy` is now removed and errors out starting from this API version.
   110  * API errors are now returned as JSON instead of plain text.
   111  * `POST /containers/create` and `POST /containers/(id)/start` allow you to configure kernel parameters (sysctls) for use in the container.
   112  * `POST /containers/<container ID>/exec` and `POST /exec/<exec ID>/start`
   113    no longer expects a "Container" field to be present. This property was not used
   114    and is no longer sent by the docker client.
   115  * `POST /containers/create/` now validates the hostname (should be a valid RFC 1123 hostname).
   116  * `POST /containers/create/` `HostConfig.PidMode` field now accepts `container:<name|id>`,
   117    to have the container join the PID namespace of an existing container.
   118  
   119  ## v1.23 API changes
   120  
   121  [Docker Engine API v1.23](v1.23.md) documentation
   122  
   123  * `GET /containers/json` returns the state of the container, one of `created`, `restarting`, `running`, `paused`, `exited` or `dead`.
   124  * `GET /containers/json` returns the mount points for the container.
   125  * `GET /networks/(name)` now returns an `Internal` field showing whether the network is internal or not.
   126  * `GET /networks/(name)` now returns an `EnableIPv6` field showing whether the network has ipv6 enabled or not.
   127  * `POST /containers/(name)/update` now supports updating container's restart policy.
   128  * `POST /networks/create` now supports enabling ipv6 on the network by setting the `EnableIPv6` field (doing this with a label will no longer work).
   129  * `GET /info` now returns `CgroupDriver` field showing what cgroup driver the daemon is using; `cgroupfs` or `systemd`.
   130  * `GET /info` now returns `KernelMemory` field, showing if "kernel memory limit" is supported.
   131  * `POST /containers/create` now takes `PidsLimit` field, if the kernel is >= 4.3 and the pids cgroup is supported.
   132  * `GET /containers/(id or name)/stats` now returns `pids_stats`, if the kernel is >= 4.3 and the pids cgroup is supported.
   133  * `POST /containers/create` now allows you to override usernamespaces remapping and use privileged options for the container.
   134  * `POST /containers/create` now allows specifying `nocopy` for named volumes, which disables automatic copying from the container path to the volume.
   135  * `POST /auth` now returns an `IdentityToken` when supported by a registry.
   136  * `POST /containers/create` with both `Hostname` and `Domainname` fields specified will result in the container's hostname being set to `Hostname`, rather than `Hostname.Domainname`.
   137  * `GET /volumes` now supports more filters, new added filters are `name` and `driver`.
   138  * `GET /containers/(id or name)/logs` now accepts a `details` query parameter to stream the extra attributes that were provided to the containers `LogOpts`, such as environment variables and labels, with the logs.
   139  * `POST /images/load` now returns progress information as a JSON stream, and has a `quiet` query parameter to suppress progress details.
   140  
   141  ## v1.22 API changes
   142  
   143  [Docker Engine API v1.22](v1.22.md) documentation
   144  
   145  * `POST /container/(name)/update` updates the resources of a container.
   146  * `GET /containers/json` supports filter `isolation` on Windows.
   147  * `GET /containers/json` now returns the list of networks of containers.
   148  * `GET /info` Now returns `Architecture` and `OSType` fields, providing information
   149    about the host architecture and operating system type that the daemon runs on.
   150  * `GET /networks/(name)` now returns a `Name` field for each container attached to the network.
   151  * `GET /version` now returns the `BuildTime` field in RFC3339Nano format to make it
   152    consistent with other date/time values returned by the API.
   153  * `AuthConfig` now supports a `registrytoken` for token based authentication
   154  * `POST /containers/create` now has a 4M minimum value limit for `HostConfig.KernelMemory`
   155  * Pushes initiated with `POST /images/(name)/push` and pulls initiated with `POST /images/create`
   156    will be cancelled if the HTTP connection making the API request is closed before
   157    the push or pull completes.
   158  * `POST /containers/create` now allows you to set a read/write rate limit for a
   159    device (in bytes per second or IO per second).
   160  * `GET /networks` now supports filtering by `name`, `id` and `type`.
   161  * `POST /containers/create` now allows you to set the static IPv4 and/or IPv6 address for the container.
   162  * `POST /networks/(id)/connect` now allows you to set the static IPv4 and/or IPv6 address for the container.
   163  * `GET /info` now includes the number of containers running, stopped, and paused.
   164  * `POST /networks/create` now supports restricting external access to the network by setting the `Internal` field.
   165  * `POST /networks/(id)/disconnect` now includes a `Force` option to forcefully disconnect a container from network
   166  * `GET /containers/(id)/json` now returns the `NetworkID` of containers.
   167  * `POST /networks/create` Now supports an options field in the IPAM config that provides options
   168    for custom IPAM plugins.
   169  * `GET /networks/{network-id}` Now returns IPAM config options for custom IPAM plugins if any
   170    are available.
   171  * `GET /networks/<network-id>` now returns subnets info for user-defined networks.
   172  * `GET /info` can now return a `SystemStatus` field useful for returning additional information about applications
   173    that are built on top of engine.
   174  
   175  ## v1.21 API changes
   176  
   177  [Docker Engine API v1.21](v1.21.md) documentation
   178  
   179  * `GET /volumes` lists volumes from all volume drivers.
   180  * `POST /volumes/create` to create a volume.
   181  * `GET /volumes/(name)` get low-level information about a volume.
   182  * `DELETE /volumes/(name)` remove a volume with the specified name.
   183  * `VolumeDriver` was moved from `config` to `HostConfig` to make the configuration portable.
   184  * `GET /images/(name)/json` now returns information about an image's `RepoTags` and `RepoDigests`.
   185  * The `config` option now accepts the field `StopSignal`, which specifies the signal to use to kill a container.
   186  * `GET /containers/(id)/stats` will return networking information respectively for each interface.
   187  * The `HostConfig` option now includes the `DnsOptions` field to configure the container's DNS options.
   188  * `POST /build` now optionally takes a serialized map of build-time variables.
   189  * `GET /events` now includes a `timenano` field, in addition to the existing `time` field.
   190  * `GET /events` now supports filtering by image and container labels.
   191  * `GET /info` now lists engine version information and return the information of `CPUShares` and `Cpuset`.
   192  * `GET /containers/json` will return `ImageID` of the image used by container.
   193  * `POST /exec/(name)/start` will now return an HTTP 409 when the container is either stopped or paused.
   194  * `POST /containers/create` now takes `KernelMemory` in HostConfig to specify kernel memory limit.
   195  * `GET /containers/(name)/json` now accepts a `size` parameter. Setting this parameter to '1' returns container size information in the `SizeRw` and `SizeRootFs` fields.
   196  * `GET /containers/(name)/json` now returns a `NetworkSettings.Networks` field,
   197    detailing network settings per network. This field deprecates the
   198    `NetworkSettings.Gateway`, `NetworkSettings.IPAddress`,
   199    `NetworkSettings.IPPrefixLen`, and `NetworkSettings.MacAddress` fields, which
   200    are still returned for backward-compatibility, but will be removed in a future version.
   201  * `GET /exec/(id)/json` now returns a `NetworkSettings.Networks` field,
   202    detailing networksettings per network. This field deprecates the
   203    `NetworkSettings.Gateway`, `NetworkSettings.IPAddress`,
   204    `NetworkSettings.IPPrefixLen`, and `NetworkSettings.MacAddress` fields, which
   205    are still returned for backward-compatibility, but will be removed in a future version.
   206  * The `HostConfig` option now includes the `OomScoreAdj` field for adjusting the
   207    badness heuristic. This heuristic selects which processes the OOM killer kills
   208    under out-of-memory conditions.
   209  
   210  ## v1.20 API changes
   211  
   212  [Docker Engine API v1.20](v1.20.md) documentation
   213  
   214  * `GET /containers/(id)/archive` get an archive of filesystem content from a container.
   215  * `PUT /containers/(id)/archive` upload an archive of content to be extracted to
   216  an existing directory inside a container's filesystem.
   217  * `POST /containers/(id)/copy` is deprecated in favor of the above `archive`
   218  endpoint which can be used to download files and directories from a container.
   219  * The `hostConfig` option now accepts the field `GroupAdd`, which specifies a
   220  list of additional groups that the container process will run as.
   221  
   222  ## v1.19 API changes
   223  
   224  [Docker Engine API v1.19](v1.19.md) documentation
   225  
   226  * When the daemon detects a version mismatch with the client, usually when
   227  the client is newer than the daemon, an HTTP 400 is now returned instead
   228  of a 404.
   229  * `GET /containers/(id)/stats` now accepts `stream` bool to get only one set of stats and disconnect.
   230  * `GET /containers/(id)/logs` now accepts a `since` timestamp parameter.
   231  * `GET /info` The fields `Debug`, `IPv4Forwarding`, `MemoryLimit`, and
   232  `SwapLimit` are now returned as boolean instead of as an int. In addition, the
   233  end point now returns the new boolean fields `CpuCfsPeriod`, `CpuCfsQuota`, and
   234  `OomKillDisable`.
   235  * The `hostConfig` option now accepts the fields `CpuPeriod` and `CpuQuota`
   236  * `POST /build` accepts `cpuperiod` and `cpuquota` options
   237  
   238  ## v1.18 API changes
   239  
   240  [Docker Engine API v1.18](v1.18.md) documentation
   241  
   242  * `GET /version` now returns `Os`, `Arch` and `KernelVersion`.
   243  * `POST /containers/create` and `POST /containers/(id)/start`allow you to  set ulimit settings for use in the container.
   244  * `GET /info` now returns `SystemTime`, `HttpProxy`,`HttpsProxy` and `NoProxy`.
   245  * `GET /images/json` added a `RepoDigests` field to include image digest information.
   246  * `POST /build` can now set resource constraints for all containers created for the build.
   247  * `CgroupParent` can be passed in the host config to setup container cgroups under a specific cgroup.
   248  * `POST /build` closing the HTTP request cancels the build
   249  * `POST /containers/(id)/exec` includes `Warnings` field to response.