2014-01-13 16:50:10 -08:00
:title: Remote API v1.9
:description: API Documentation for Docker
:keywords: API, Docker, rcli, REST, documentation
:orphan:
======================
Docker Remote API v1.9
======================
.. contents :: Table of Contents
1. Brief introduction
=====================
- The Remote API has replaced rcli
- The daemon listens on `` unix:///var/run/docker.sock `` , but you can
:ref: `bind_docker` .
- The API tends to be REST, but for some complex commands, like
`` attach `` or `` pull `` , the HTTP connection is hijacked to transport
`` stdout, stdin `` and `` stderr ``
2. Endpoints
============
2.1 Containers
--------------
List containers
***** ***** *****
.. http:get :: /containers/json
2014-01-14 14:12:21 -08:00
List containers
**Example request** :
.. sourcecode :: http
GET /containers/json?all=1&before=8dfafdbc3a40&size=1 HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
[
{
"Id": "8dfafdbc3a40",
"Image": "base:latest",
"Command": "echo 1",
"Created": 1367854155,
"Status": "Exit 0",
"Ports":[{"PrivatePort": 2222, "PublicPort": 3333, "Type": "tcp"}],
"SizeRw":12288,
"SizeRootFs":0
},
{
"Id": "9cd87474be90",
"Image": "base:latest",
"Command": "echo 222222",
"Created": 1367854155,
"Status": "Exit 0",
"Ports":[],
"SizeRw":12288,
"SizeRootFs":0
},
{
"Id": "3176a2479c92",
"Image": "base:latest",
"Command": "echo 3333333333333333",
"Created": 1367854154,
"Status": "Exit 0",
"Ports":[],
"SizeRw":12288,
"SizeRootFs":0
},
{
"Id": "4cb07b47f9fb",
"Image": "base:latest",
"Command": "echo 444444444444444444444444444444444",
"Created": 1367854152,
"Status": "Exit 0",
"Ports":[],
"SizeRw":12288,
"SizeRootFs":0
}
]
:query all: 1/True/true or 0/False/false, Show all containers. Only running containers are shown by default
:query limit: Show ``limit`` last created containers, include non-running ones.
:query since: Show only containers created since Id, include non-running ones.
:query before: Show only containers created before Id, include non-running ones.
:query size: 1/True/true or 0/False/false, Show the containers sizes
:statuscode 200: no error
:statuscode 400: bad parameter
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Create a container
***** ***** ***** ***
.. http:post :: /containers/create
2014-01-14 14:12:21 -08:00
Create a container
**Example request** :
.. sourcecode :: http
POST /containers/create HTTP/1.1
Content-Type: application/json
{
"Hostname":"",
"User":"",
"Memory":0,
"MemorySwap":0,
2014-02-21 19:25:49 +01:00
"CpuShares":0,
2014-01-14 14:12:21 -08:00
"AttachStdin":false,
"AttachStdout":true,
"AttachStderr":true,
"PortSpecs":null,
"Tty":false,
"OpenStdin":false,
"StdinOnce":false,
"Env":null,
"Cmd":[
"date"
],
"Dns":null,
"Image":"base",
"Volumes":{
"/tmp": {}
},
"VolumesFrom":"",
"WorkingDir":"",
"ExposedPorts":{
"22/tcp": {}
}
}
**Example response** :
.. sourcecode :: http
HTTP/1.1 201 OK
Content-Type: application/json
{
"Id":"e90e34656806"
"Warnings":[]
}
2014-02-21 19:25:49 +01:00
:jsonparam Hostname: Container host name
:jsonparam User: Username or UID
:jsonparam Memory: Memory Limit in bytes
:jsonparam CpuShares: CPU shares (relative weight)
:jsonparam AttachStdin: 1/True/true or 0/False/false, attach to standard input. Default false
:jsonparam AttachStdout: 1/True/true or 0/False/false, attach to standard output. Default false
:jsonparam AttachStderr: 1/True/true or 0/False/false, attach to standard error. Default false
:jsonparam Tty: 1/True/true or 0/False/false, allocate a pseudo-tty. Default false
:jsonparam OpenStdin: 1/True/true or 0/False/false, keep stdin open even if not attached. Default false
2014-01-14 14:12:21 -08:00
:query name: Assign the specified name to the container. Must match ``/?[a-zA-Z0-9_-]+``.
:statuscode 201: no error
:statuscode 404: no such container
:statuscode 406: impossible to attach (container not running)
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Inspect a container
***** ***** ***** *** *
.. http:get :: /containers/(id)/json
2014-01-14 14:12:21 -08:00
Return low-level information on the container `` id ``
**Example request** :
.. sourcecode :: http
GET /containers/4fa6e0f0c678/json HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
{
"Id": "4fa6e0f0c6786287e131c3852c58a2e01cc697a68231826813597e4994f1d6e2",
"Created": "2013-05-07T14:51:42.041847+02:00",
"Path": "date",
"Args": [],
"Config": {
"Hostname": "4fa6e0f0c678",
"User": "",
"Memory": 0,
"MemorySwap": 0,
"AttachStdin": false,
"AttachStdout": true,
"AttachStderr": true,
"PortSpecs": null,
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": null,
"Cmd": [
"date"
],
"Dns": null,
"Image": "base",
"Volumes": {},
"VolumesFrom": "",
"WorkingDir":""
},
"State": {
"Running": false,
"Pid": 0,
"ExitCode": 0,
"StartedAt": "2013-05-07T14:51:42.087658+02:01360",
"Ghost": false
},
"Image": "b750fe79269d2ec9a3c593ef05b4332b1d1a02a62b4accb2c21d589ff2f5f2dc",
"NetworkSettings": {
"IpAddress": "",
"IpPrefixLen": 0,
"Gateway": "",
"Bridge": "",
"PortMapping": null
},
"SysInitPath": "/home/kitty/go/src/github.com/dotcloud/docker/bin/docker",
"ResolvConfPath": "/etc/resolv.conf",
"Volumes": {},
2014-01-13 16:50:10 -08:00
"HostConfig": {
"Binds": null,
"ContainerIDFile": "",
"LxcConf": [],
"Privileged": false,
"PortBindings": {
"80/tcp": [
{
"HostIp": "0.0.0.0",
"HostPort": "49153"
}
]
},
"Links": null,
"PublishAllPorts": false
}
2014-01-14 14:12:21 -08:00
}
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:statuscode 200: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
List processes running inside a container
***** ***** ***** ***** ***** ***** ***** ***** *
.. http:get :: /containers/(id)/top
2014-01-14 14:12:21 -08:00
List processes running inside the container `` id ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
GET /containers/4fa6e0f0c678/top HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{
"Titles":[
"USER",
"PID",
"%CPU",
"%MEM",
"VSZ",
"RSS",
"TTY",
"STAT",
"START",
"TIME",
"COMMAND"
],
"Processes":[
["root","20147","0.0","0.1","18060","1864","pts/4","S","10:06","0:00","bash"],
["root","20271","0.0","0.0","4312","352","pts/4","S+","10:07","0:00","sleep","10"]
]
}
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:query ps_args: ps arguments to use (eg. aux)
:statuscode 200: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Inspect changes on a container's filesystem
***** ***** ***** ***** ***** ***** ***** ***** ***
.. http:get :: /containers/(id)/changes
2014-01-14 14:12:21 -08:00
Inspect changes on container `` id `` 's filesystem
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
GET /containers/4fa6e0f0c678/changes HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-21 15:06:23 -08:00
[
{
2014-01-14 14:12:21 -08:00
"Path":"/dev",
"Kind":0
2014-01-21 15:06:23 -08:00
},
{
2014-01-14 14:12:21 -08:00
"Path":"/dev/kmsg",
"Kind":1
2014-01-21 15:06:23 -08:00
},
{
2014-01-14 14:12:21 -08:00
"Path":"/test",
"Kind":1
2014-01-21 15:06:23 -08:00
}
]
2014-01-14 14:12:21 -08:00
:statuscode 200: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Export a container
***** ***** ***** ***
.. http:get :: /containers/(id)/export
2014-01-14 14:12:21 -08:00
Export the contents of container `` id ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
GET /containers/4fa6e0f0c678/export HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
Content-Type: application/octet-stream
{{ STREAM }}
:statuscode 200: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Start a container
***** ***** ***** **
.. http:post :: /containers/(id)/start
Start the container `` id ``
**Example request** :
.. sourcecode :: http
POST /containers/(id)/start HTTP/1.1
Content-Type: application/json
{
"Binds":["/tmp:/tmp"],
"LxcConf":{"lxc.utsname":"docker"},
"PortBindings":{ "22/tcp": [{ "HostPort": "11022" }] },
"PublishAllPorts":false,
"Privileged":false
}
**Example response** :
.. sourcecode :: http
HTTP/1.1 204 No Content
Content-Type: text/plain
2014-02-21 19:25:49 +01:00
:jsonparam Binds: Create a bind mount to a directory or file with [host-path]:[container-path]:[rw|ro]. If a directory "container-path" is missing, then docker creates a new volume.
:jsonparam LxcConf: Map of custom lxc options
:jsonparam PortBindings: Expose ports from the container, optionally publishing them via the HostPort flag
:jsonparam PublishAllPorts: 1/True/true or 0/False/false, publish all exposed ports to the host interfaces. Default false
:jsonparam Privileged: 1/True/true or 0/False/false, give extended privileges to this container. Default false
2014-01-13 16:50:10 -08:00
:statuscode 204: no error
:statuscode 404: no such container
:statuscode 500: server error
Stop a container
***** ***** ***** *
.. http:post :: /containers/(id)/stop
2014-01-14 14:12:21 -08:00
Stop the container `` id ``
**Example request** :
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /containers/e90e34656806/stop?t=5 HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 204 OK
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:query t: number of seconds to wait before killing the container
:statuscode 204: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Restart a container
***** ***** ***** *** *
.. http:post :: /containers/(id)/restart
2014-01-14 14:12:21 -08:00
Restart the container `` id ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /containers/e90e34656806/restart?t=5 HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
HTTP/1.1 204 OK
:query t: number of seconds to wait before killing the container
:statuscode 204: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Kill a container
***** ***** ***** *
.. http:post :: /containers/(id)/kill
2014-01-14 14:12:21 -08:00
Kill the container `` id ``
**Example request** :
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /containers/e90e34656806/kill HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 204 OK
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:statuscode 204: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Attach to a container
***** ***** ***** ***** *
.. http:post :: /containers/(id)/attach
2014-01-14 14:12:21 -08:00
Attach to the container `` id ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /containers/16253994b7c4/attach?logs=1&stream=0&stdout=1 HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/vnd.docker.raw-stream
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{{ STREAM }}
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:query logs: 1/True/true or 0/False/false, return logs. Default false
:query stream: 1/True/true or 0/False/false, return stream. Default false
:query stdin: 1/True/true or 0/False/false, if stream=true, attach to stdin. Default false
:query stdout: 1/True/true or 0/False/false, if logs=true, return stdout log, if stream=true, attach to stdout. Default false
:query stderr: 1/True/true or 0/False/false, if logs=true, return stderr log, if stream=true, attach to stderr. Default false
:statuscode 200: no error
:statuscode 400: bad parameter
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Stream details** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
When using the TTY setting is enabled in
:http:post: `/containers/create` , the stream is the raw data
from the process PTY and client's stdin. When the TTY is
disabled, then the stream is multiplexed to separate stdout
and stderr.
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
The format is a **Header** and a **Payload** (frame).
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**HEADER**
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
The header will contain the information on which stream write
the stream (stdout or stderr). It also contain the size of
the associated frame encoded on the last 4 bytes (uint32).
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
It is encoded on the first 8 bytes like this::
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
header := [8]byte{STREAM_TYPE, 0, 0, 0, SIZE1, SIZE2, SIZE3, SIZE4}
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
`` STREAM_TYPE `` can be:
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
- 0: stdin (will be writen on stdout)
- 1: stdout
- 2: stderr
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
`` SIZE1, SIZE2, SIZE3, SIZE4 `` are the 4 bytes of the uint32 size encoded as big endian.
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**PAYLOAD**
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
The payload is the raw stream.
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**IMPLEMENTATION**
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
The simplest way to implement the Attach protocol is the following:
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
1) Read 8 bytes
2) chose stdout or stderr depending on the first byte
3) Extract the frame size from the last 4 byets
4) Read the extracted size and output it on the correct output
5) Goto 1)
2014-01-13 16:50:10 -08:00
Wait a container
***** ***** ***** *
.. http:post :: /containers/(id)/wait
2014-01-14 14:12:21 -08:00
Block until container `` id `` stops, then returns the exit code
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /containers/16253994b7c4/wait HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
Content-Type: application/json
{"StatusCode":0}
:statuscode 200: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Remove a container
***** ***** ***** *** *
.. http:delete :: /containers/(id)
2014-01-14 14:12:21 -08:00
Remove the container `` id `` from the filesystem
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
DELETE /containers/16253994b7c4?v=1 HTTP/1.1
**Example response** :
.. sourcecode :: http
2014-01-14 14:12:21 -08:00
HTTP/1.1 204 OK
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:query v: 1/True/true or 0/False/false, Remove the volumes associated to the container. Default false
2014-01-13 16:50:10 -08:00
:statuscode 204: no error
2014-01-14 14:12:21 -08:00
:statuscode 400: bad parameter
2014-01-13 16:50:10 -08:00
:statuscode 404: no such container
:statuscode 500: server error
Copy files or folders from a container
***** ***** ***** ***** ***** ***** ***** ***
.. http:post :: /containers/(id)/copy
2014-01-14 14:12:21 -08:00
Copy files or folders of container `` id ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /containers/4fa6e0f0c678/copy HTTP/1.1
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{
"Resource":"test.txt"
}
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
Content-Type: application/octet-stream
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{{ STREAM }}
:statuscode 200: no error
:statuscode 404: no such container
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
2.2 Images
----------
List Images
***** ***** *
.. http:get :: /images/json
2014-01-14 14:12:21 -08:00
**Example request** :
.. sourcecode :: http
GET /images/json?all=0 HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
2014-01-21 15:06:23 -08:00
[
{
2014-01-14 14:12:21 -08:00
"RepoTags": [
"ubuntu:12.04",
"ubuntu:precise",
"ubuntu:latest"
],
"Id": "8dbd9e392a964056420e5d58ca5cc376ef18e2de93b5cc90e868a1bbc8318c1c",
"Created": 1365714795,
"Size": 131506275,
"VirtualSize": 131506275
2014-01-21 15:06:23 -08:00
},
{
2014-01-14 14:12:21 -08:00
"RepoTags": [
"ubuntu:12.10",
"ubuntu:quantal"
],
"ParentId": "27cf784147099545",
"Id": "b750fe79269d2ec9a3c593ef05b4332b1d1a02a62b4accb2c21d589ff2f5f2dc",
"Created": 1364102658,
"Size": 24653,
"VirtualSize": 180116135
2014-01-21 15:06:23 -08:00
}
]
2014-01-13 16:50:10 -08:00
Create an image
***** ***** *****
.. http:post :: /images/create
2014-01-14 14:12:21 -08:00
Create an image, either by pull it from the registry or by importing it
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
POST /images/create?fromImage=base HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{"status":"Pulling..."}
{"status":"Pulling", "progress":"1 B/ 100 B", "progressDetail":{"current":1, "total":100}}
{"error":"Invalid..."}
...
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
When using this endpoint to pull an image from the registry,
the `` X-Registry-Auth `` header can be used to include a
base64-encoded AuthConfig object.
2014-01-13 16:50:10 -08:00
:query fromImage: name of the image to pull
2014-01-14 14:12:21 -08:00
:query fromSrc: source to import, - means stdin
2014-01-13 16:50:10 -08:00
:query repo: repository
2014-01-14 14:12:21 -08:00
:query tag: tag
:query registry: the registry to pull from
:reqheader X-Registry-Auth: base64-encoded AuthConfig object
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
:statuscode 500: server error
Insert a file in an image
***** ***** ***** ***** *****
.. http:post :: /images/(name)/insert
2014-01-14 14:12:21 -08:00
Insert a file from `` url `` in the image `` name `` at `` path ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
POST /images/test/insert?path=/usr&url=myurl HTTP/1.1
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{"status":"Inserting..."}
{"status":"Inserting", "progress":"1/? (n/a)", "progressDetail":{"current":1}}
{"error":"Invalid..."}
...
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:statuscode 200: no error
2014-01-13 16:50:10 -08:00
:statuscode 500: server error
Inspect an image
***** ***** ***** *
.. http:get :: /images/(name)/json
2014-01-14 14:12:21 -08:00
Return low-level information on the image `` name ``
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
GET /images/base/json HTTP/1.1
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
{
"id":"b750fe79269d2ec9a3c593ef05b4332b1d1a02a62b4accb2c21d589ff2f5f2dc",
"parent":"27cf784147099545",
"created":"2013-03-23T22:24:18.818426-07:00",
"container":"3d67245a8d72ecf13f33dffac9f79dcdf70f75acb84d308770391510e0c23ad0",
"container_config":
{
"Hostname":"",
"User":"",
"Memory":0,
"MemorySwap":0,
"AttachStdin":false,
"AttachStdout":false,
"AttachStderr":false,
"PortSpecs":null,
"Tty":true,
"OpenStdin":true,
"StdinOnce":false,
"Env":null,
"Cmd": ["/bin/bash"]
,"Dns":null,
"Image":"base",
"Volumes":null,
"VolumesFrom":"",
"WorkingDir":""
},
"Size": 6824592
}
:statuscode 200: no error
:statuscode 404: no such image
2014-01-13 16:50:10 -08:00
:statuscode 500: server error
Get the history of an image
***** ***** ***** ***** ***** **
.. http:get :: /images/(name)/history
Return the history of the image `` name ``
**Example request** :
.. sourcecode :: http
GET /images/base/history HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
2014-01-21 15:06:23 -08:00
[
{
2014-01-14 14:12:21 -08:00
"Id":"b750fe79269d",
"Created":1364102658,
"CreatedBy":"/bin/bash"
2014-01-21 15:06:23 -08:00
},
{
2014-01-14 14:12:21 -08:00
"Id":"27cf78414709",
"Created":1364068391,
"CreatedBy":""
2014-01-21 15:06:23 -08:00
}
]
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
:statuscode 404: no such image
:statuscode 500: server error
Push an image on the registry
***** ***** ***** ***** ***** *** *
.. http:post :: /images/(name)/push
Push the image `` name `` on the registry
**Example request** :
.. sourcecode :: http
POST /images/test/push HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
{"status":"Pushing..."}
{"status":"Pushing", "progress":"1/? (n/a)", "progressDetail":{"current":1}}}
{"error":"Invalid..."}
...
:query registry: the registry you wan to push, optional
:reqheader X-Registry-Auth: include a base64-encoded AuthConfig object.
:statuscode 200: no error
:statuscode 404: no such image
:statuscode 500: server error
Tag an image into a repository
***** ***** ***** ***** ***** *****
.. http:post :: /images/(name)/tag
2014-01-14 14:12:21 -08:00
Tag the image `` name `` into a repository
2014-01-13 16:50:10 -08:00
**Example request** :
.. sourcecode :: http
2014-01-14 14:12:21 -08:00
POST /images/test/tag?repo=myrepo&force=0 HTTP/1.1
**Example response** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
2014-02-13 13:34:04 +00:00
HTTP/1.1 201 OK
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:query repo: The repository to tag in
:query force: 1/True/true or 0/False/false, default false
2014-02-13 13:34:04 +00:00
:statuscode 201: no error
2014-01-14 14:12:21 -08:00
:statuscode 400: bad parameter
:statuscode 404: no such image
:statuscode 409: conflict
2014-01-13 16:50:10 -08:00
:statuscode 500: server error
Remove an image
***** ***** *****
.. http:delete :: /images/(name)
2014-01-14 14:12:21 -08:00
Remove the image `` name `` from the filesystem
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
DELETE /images/test HTTP/1.1
**Example response** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
Content-type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
[
{"Untagged":"3e2f21a89f"},
{"Deleted":"3e2f21a89f"},
{"Deleted":"53b4f83ac9"}
]
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:statuscode 200: no error
2014-01-13 16:50:10 -08:00
:statuscode 404: no such image
2014-01-14 14:12:21 -08:00
:statuscode 409: conflict
2014-01-13 16:50:10 -08:00
:statuscode 500: server error
Search images
***** ***** ***
.. http:get :: /images/search
2014-01-14 14:12:21 -08:00
Search for an image in the docker index.
.. note ::
The response keys have changed from API v1.6 to reflect the JSON
sent by the registry server to the docker daemon's request.
**Example request** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
GET /images/search?term=sshd HTTP/1.1
2014-01-14 14:12:21 -08:00
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
2014-01-21 15:06:23 -08:00
[
{
2014-01-14 14:12:21 -08:00
"description": "",
"is_official": false,
"is_trusted": false,
"name": "wma55/u1210sshd",
"star_count": 0
2014-01-21 15:06:23 -08:00
},
{
2014-01-14 14:12:21 -08:00
"description": "",
"is_official": false,
"is_trusted": false,
"name": "jdswinbank/sshd",
"star_count": 0
2014-01-21 15:06:23 -08:00
},
{
2014-01-14 14:12:21 -08:00
"description": "",
"is_official": false,
"is_trusted": false,
"name": "vgauthier/sshd",
"star_count": 0
2014-01-21 15:06:23 -08:00
}
2014-01-14 14:12:21 -08:00
...
2014-01-21 15:06:23 -08:00
]
2014-01-14 14:12:21 -08:00
:query term: term to search
:statuscode 200: no error
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
2.3 Misc
--------
2014-02-21 17:42:02 +10:00
Build an image from Dockerfile
***** ***** ***** ***** ***** *****
2014-01-13 16:50:10 -08:00
.. http:post :: /build
2014-02-21 17:42:02 +10:00
Build an image from Dockerfile using a POST body.
2014-01-13 16:50:10 -08:00
**Example request** :
.. sourcecode :: http
POST /build HTTP/1.1
{{ STREAM }}
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
Content-Type: application/json
{"stream":"Step 1..."}
{"stream":"..."}
{"error":"Error...", "errorDetail":{"code": 123, "message": "Error..."}}
The stream must be a tar archive compressed with one of the
following algorithms: identity (no compression), gzip, bzip2,
2014-01-14 14:12:21 -08:00
xz.
2014-01-13 16:50:10 -08:00
The archive must include a file called `` Dockerfile `` at its
root. It may include any number of other files, which will be
accessible in the build context (See the :ref:`ADD build command
<dockerbuilder>`).
:query t: repository name (and optionally a tag) to be applied to the resulting image in case of success
:query q: suppress verbose build output
:query nocache: do not use the cache when building the image
2014-02-21 17:42:02 +10:00
:query rm: Remove intermediate containers after a successful build
2014-01-13 16:50:10 -08:00
:reqheader Content-type: should be set to ``"application/tar"``.
2014-01-03 15:13:32 -05:00
:reqheader X-Registry-Config: base64-encoded ConfigFile object
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
:statuscode 500: server error
Check auth configuration
***** ***** ***** ***** *** *
.. http:post :: /auth
Get the default username and email
**Example request** :
.. sourcecode :: http
POST /auth HTTP/1.1
2014-01-14 14:12:21 -08:00
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{
"username":"hannibal",
"password:"xxxx",
"email":"hannibal@a-team.com",
"serveraddress":"https://index.docker.io/v1/"
}
2014-01-13 16:50:10 -08:00
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
:statuscode 200: no error
:statuscode 204: no error
:statuscode 500: server error
Display system-wide information
***** ***** ***** ***** ***** ***** *
.. http:get :: /info
2014-01-14 14:12:21 -08:00
Display system-wide information
**Example request** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
GET /info HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
{
"Containers":11,
"Images":16,
"Debug":false,
"NFd": 11,
"NGoroutines":21,
"MemoryLimit":true,
"SwapLimit":false,
"IPv4Forwarding":true
}
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
:statuscode 500: server error
Show the docker version information
***** ***** ***** ***** ***** ***** *****
.. http:get :: /version
2014-01-14 14:12:21 -08:00
Show the docker version information
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
.. sourcecode :: http
GET /version HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{
"Version":"0.2.2",
"GitCommit":"5a2a5cc+CHANGES",
"GoVersion":"go1.0.3"
}
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
2014-01-14 14:12:21 -08:00
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
Create a new image from a container's changes
***** ***** ***** ***** ***** ***** ***** ***** *****
.. http:post :: /commit
Create a new image from a container's changes
**Example request** :
.. sourcecode :: http
POST /commit?container=44c004db4b17&m=message&repo=myrepo HTTP/1.1
**Example response** :
.. sourcecode :: http
HTTP/1.1 201 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/vnd.docker.raw-stream
2014-01-13 16:50:10 -08:00
{"Id":"596069db4bf5"}
:query container: source container
:query repo: repository
:query tag: tag
:query m: commit message
:query author: author (eg. "John Hannibal Smith <hannibal@a-team.com>")
:query run: config automatically applied when the image is run. (ex: {"Cmd": ["cat", "/world"], "PortSpecs":["22"]})
:statuscode 201: no error
:statuscode 404: no such container
:statuscode 500: server error
Monitor Docker's events
***** ***** ***** ***** ***
.. http:get :: /events
2014-01-14 14:12:21 -08:00
Get events from docker, either in real time via streaming, or via polling (using `since` )
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
GET /events?since=1374067924
**Example response** :
.. sourcecode :: http
HTTP/1.1 200 OK
2014-01-14 14:12:21 -08:00
Content-Type: application/json
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
{"status":"create","id":"dfdf82bd3881","from":"base:latest","time":1374067924}
{"status":"start","id":"dfdf82bd3881","from":"base:latest","time":1374067924}
{"status":"stop","id":"dfdf82bd3881","from":"base:latest","time":1374067966}
{"status":"destroy","id":"dfdf82bd3881","from":"base:latest","time":1374067970}
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:query since: timestamp used for polling
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
:statuscode 500: server error
Get a tarball containing all images and tags in a repository
***** ***** ***** ***** ***** ***** ***** ***** ***** ***** ***** *****
.. http:get :: /images/(name)/get
2014-01-14 14:12:21 -08:00
Get a tarball containing all images and metadata for the repository specified by `` name `` .
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request**
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
GET /images/ubuntu/get
2014-01-14 14:12:21 -08:00
**Example response** :
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
Content-Type: application/x-tar
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
Binary data stream
2014-01-13 16:50:10 -08:00
:statuscode 200: no error
:statuscode 500: server error
Load a tarball with a set of images and tags into docker
***** ***** ***** ***** ***** ***** ***** ***** ***** ***** ***** *
.. http:post :: /images/load
2014-01-14 14:12:21 -08:00
Load a set of images and tags into the docker repository.
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example request**
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
POST /images/load
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
Tarball in body
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
**Example response** :
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
.. sourcecode :: http
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
HTTP/1.1 200 OK
2014-01-13 16:50:10 -08:00
2014-01-14 14:12:21 -08:00
:statuscode 200: no error
:statuscode 500: server error
2014-01-13 16:50:10 -08:00
3. Going further
================
3.1 Inside 'docker run'
-----------------------
Here are the steps of 'docker run' :
* Create the container
* If the status code is 404, it means the image doesn't exists:
* Try to pull it
* Then retry to create the container
* Start the container
* If you are not in detached mode:
* Attach to the container, using logs=1 (to have stdout and stderr from the container's start) and stream=1
* If in detached mode or only stdin is attached:
2014-01-14 14:12:21 -08:00
* Display the container's id
2014-01-13 16:50:10 -08:00
3.2 Hijacking
-------------
In this version of the API, /attach, uses hijacking to transport stdin, stdout and stderr on the same socket. This might change in the future.
3.3 CORS Requests
-----------------
To enable cross origin requests to the remote api add the flag "-api-enable-cors" when running docker in daemon mode.
.. code-block :: bash
docker -d -H="192.168.1.9:4243" -api-enable-cors