github.com/jiasir/docker@v1.3.3-0.20170609024000-252e610103e7/docs/reference/commandline/cli.md (about) 1 --- 2 title: "Use the Docker command line" 3 description: "Docker's CLI command description and usage" 4 keywords: "Docker, Docker documentation, CLI, command line" 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 # docker 17 18 To list available commands, either run `docker` with no parameters 19 or execute `docker help`: 20 21 ```bash 22 $ docker 23 Usage: docker [OPTIONS] COMMAND [ARG...] 24 docker [ --help | -v | --version ] 25 26 A self-sufficient runtime for containers. 27 28 Options: 29 --config string Location of client config files (default "/root/.docker") 30 -D, --debug Enable debug mode 31 --help Print usage 32 -H, --host value Daemon socket(s) to connect to (default []) 33 -l, --log-level string Set the logging level ("debug"|"info"|"warn"|"error"|"fatal") (default "info") 34 --tls Use TLS; implied by --tlsverify 35 --tlscacert string Trust certs signed only by this CA (default "/root/.docker/ca.pem") 36 --tlscert string Path to TLS certificate file (default "/root/.docker/cert.pem") 37 --tlskey string Path to TLS key file (default "/root/.docker/key.pem") 38 --tlsverify Use TLS and verify the remote 39 -v, --version Print version information and quit 40 41 Commands: 42 attach Attach to a running container 43 # […] 44 ``` 45 46 ## Description 47 48 Depending on your Docker system configuration, you may be required to preface 49 each `docker` command with `sudo`. To avoid having to use `sudo` with the 50 `docker` command, your system administrator can create a Unix group called 51 `docker` and add users to it. 52 53 For more information about installing Docker or `sudo` configuration, refer to 54 the [installation](https://docs.docker.com/engine/installation/) instructions for your operating system. 55 56 ### Environment variables 57 58 For easy reference, the following list of environment variables are supported 59 by the `docker` command line: 60 61 * `DOCKER_API_VERSION` The API version to use (e.g. `1.19`) 62 * `DOCKER_CONFIG` The location of your client configuration files. 63 * `DOCKER_CERT_PATH` The location of your authentication keys. 64 * `DOCKER_DRIVER` The graph driver to use. 65 * `DOCKER_HOST` Daemon socket to connect to. 66 * `DOCKER_NOWARN_KERNEL_VERSION` Prevent warnings that your Linux kernel is 67 unsuitable for Docker. 68 * `DOCKER_RAMDISK` If set this will disable 'pivot_root'. 69 * `DOCKER_TLS_VERIFY` When set Docker uses TLS and verifies the remote. 70 * `DOCKER_CONTENT_TRUST` When set Docker uses notary to sign and verify images. 71 Equates to `--disable-content-trust=false` for build, create, pull, push, run. 72 * `DOCKER_CONTENT_TRUST_SERVER` The URL of the Notary server to use. This defaults 73 to the same URL as the registry. 74 * `DOCKER_HIDE_LEGACY_COMMANDS` When set, Docker hides "legacy" top-level commands (such as `docker rm`, and 75 `docker pull`) in `docker help` output, and only `Management commands` per object-type (e.g., `docker container`) are 76 printed. This may become the default in a future release, at which point this environment-variable is removed. 77 * `DOCKER_TMPDIR` Location for temporary Docker files. 78 79 Because Docker is developed using Go, you can also use any environment 80 variables used by the Go runtime. In particular, you may find these useful: 81 82 * `HTTP_PROXY` 83 * `HTTPS_PROXY` 84 * `NO_PROXY` 85 86 These Go environment variables are case-insensitive. See the 87 [Go specification](http://golang.org/pkg/net/http/) for details on these 88 variables. 89 90 ### Configuration files 91 92 By default, the Docker command line stores its configuration files in a 93 directory called `.docker` within your `$HOME` directory. However, you can 94 specify a different location via the `DOCKER_CONFIG` environment variable 95 or the `--config` command line option. If both are specified, then the 96 `--config` option overrides the `DOCKER_CONFIG` environment variable. 97 For example: 98 99 docker --config ~/testconfigs/ ps 100 101 Instructs Docker to use the configuration files in your `~/testconfigs/` 102 directory when running the `ps` command. 103 104 Docker manages most of the files in the configuration directory 105 and you should not modify them. However, you *can modify* the 106 `config.json` file to control certain aspects of how the `docker` 107 command behaves. 108 109 Currently, you can modify the `docker` command behavior using environment 110 variables or command-line options. You can also use options within 111 `config.json` to modify some of the same behavior. When using these 112 mechanisms, you must keep in mind the order of precedence among them. Command 113 line options override environment variables and environment variables override 114 properties you specify in a `config.json` file. 115 116 The `config.json` file stores a JSON encoding of several properties: 117 118 The property `HttpHeaders` specifies a set of headers to include in all messages 119 sent from the Docker client to the daemon. Docker does not try to interpret or 120 understand these header; it simply puts them into the messages. Docker does 121 not allow these headers to change any headers it sets for itself. 122 123 The property `psFormat` specifies the default format for `docker ps` output. 124 When the `--format` flag is not provided with the `docker ps` command, 125 Docker's client uses this property. If this property is not set, the client 126 falls back to the default table format. For a list of supported formatting 127 directives, see the 128 [**Formatting** section in the `docker ps` documentation](ps.md) 129 130 The property `imagesFormat` specifies the default format for `docker images` output. 131 When the `--format` flag is not provided with the `docker images` command, 132 Docker's client uses this property. If this property is not set, the client 133 falls back to the default table format. For a list of supported formatting 134 directives, see the [**Formatting** section in the `docker images` documentation](images.md) 135 136 The property `pluginsFormat` specifies the default format for `docker plugin ls` output. 137 When the `--format` flag is not provided with the `docker plugin ls` command, 138 Docker's client uses this property. If this property is not set, the client 139 falls back to the default table format. For a list of supported formatting 140 directives, see the [**Formatting** section in the `docker plugin ls` documentation](plugin_ls.md) 141 142 The property `servicesFormat` specifies the default format for `docker 143 service ls` output. When the `--format` flag is not provided with the 144 `docker service ls` command, Docker's client uses this property. If this 145 property is not set, the client falls back to the default json format. For a 146 list of supported formatting directives, see the 147 [**Formatting** section in the `docker service ls` documentation](service_ls.md) 148 149 The property `serviceInspectFormat` specifies the default format for `docker 150 service inspect` output. When the `--format` flag is not provided with the 151 `docker service inspect` command, Docker's client uses this property. If this 152 property is not set, the client falls back to the default json format. For a 153 list of supported formatting directives, see the 154 [**Formatting** section in the `docker service inspect` documentation](service_inspect.md) 155 156 The property `statsFormat` specifies the default format for `docker 157 stats` output. When the `--format` flag is not provided with the 158 `docker stats` command, Docker's client uses this property. If this 159 property is not set, the client falls back to the default table 160 format. For a list of supported formatting directives, see 161 [**Formatting** section in the `docker stats` documentation](stats.md) 162 163 The property `secretFormat` specifies the default format for `docker 164 secret ls` output. When the `--format` flag is not provided with the 165 `docker secret ls` command, Docker's client uses this property. If this 166 property is not set, the client falls back to the default table 167 format. For a list of supported formatting directives, see 168 [**Formatting** section in the `docker secret ls` documentation](secret_ls.md) 169 170 171 The property `nodesFormat` specifies the default format for `docker node ls` output. 172 When the `--format` flag is not provided with the `docker node ls` command, 173 Docker's client uses the value of `nodesFormat`. If the value of `nodesFormat` is not set, 174 the client uses the default table format. For a list of supported formatting 175 directives, see the [**Formatting** section in the `docker node ls` documentation](node_ls.md) 176 177 The property `configFormat` specifies the default format for `docker 178 config ls` output. When the `--format` flag is not provided with the 179 `docker config ls` command, Docker's client uses this property. If this 180 property is not set, the client falls back to the default table 181 format. For a list of supported formatting directives, see 182 [**Formatting** section in the `docker config ls` documentation](config_ls.md) 183 184 The property `credsStore` specifies an external binary to serve as the default 185 credential store. When this property is set, `docker login` will attempt to 186 store credentials in the binary specified by `docker-credential-<value>` which 187 is visible on `$PATH`. If this property is not set, credentials will be stored 188 in the `auths` property of the config. For more information, see the 189 [**Credentials store** section in the `docker login` documentation](login.md#credentials-store) 190 191 The property `credHelpers` specifies a set of credential helpers to use 192 preferentially over `credsStore` or `auths` when storing and retrieving 193 credentials for specific registries. If this property is set, the binary 194 `docker-credential-<value>` will be used when storing or retrieving credentials 195 for a specific registry. For more information, see the 196 [**Credential helpers** section in the `docker login` documentation](login.md#credential-helpers) 197 198 Once attached to a container, users detach from it and leave it running using 199 the using `CTRL-p CTRL-q` key sequence. This detach key sequence is customizable 200 using the `detachKeys` property. Specify a `<sequence>` value for the 201 property. The format of the `<sequence>` is a comma-separated list of either 202 a letter [a-Z], or the `ctrl-` combined with any of the following: 203 204 * `a-z` (a single lowercase alpha character ) 205 * `@` (at sign) 206 * `[` (left bracket) 207 * `\\` (two backward slashes) 208 * `_` (underscore) 209 * `^` (caret) 210 211 Your customization applies to all containers started in with your Docker client. 212 Users can override your custom or the default key sequence on a per-container 213 basis. To do this, the user specifies the `--detach-keys` flag with the `docker 214 attach`, `docker exec`, `docker run` or `docker start` command. 215 216 Following is a sample `config.json` file: 217 218 ```json 219 { 220 "HttpHeaders": { 221 "MyHeader": "MyValue" 222 }, 223 "psFormat": "table {{.ID}}\\t{{.Image}}\\t{{.Command}}\\t{{.Labels}}", 224 "imagesFormat": "table {{.ID}}\\t{{.Repository}}\\t{{.Tag}}\\t{{.CreatedAt}}", 225 "pluginsFormat": "table {{.ID}}\t{{.Name}}\t{{.Enabled}}", 226 "statsFormat": "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}", 227 "servicesFormat": "table {{.ID}}\t{{.Name}}\t{{.Mode}}", 228 "secretFormat": "table {{.ID}}\t{{.Name}}\t{{.CreatedAt}}\t{{.UpdatedAt}}", 229 "configFormat": "table {{.ID}}\t{{.Name}}\t{{.CreatedAt}}\t{{.UpdatedAt}}", 230 "serviceInspectFormat": "pretty", 231 "nodesFormat": "table {{.ID}}\t{{.Hostname}}\t{{.Availability}}", 232 "detachKeys": "ctrl-e,e", 233 "credsStore": "secretservice", 234 "credHelpers": { 235 "awesomereg.example.org": "hip-star", 236 "unicorn.example.com": "vcbait" 237 } 238 } 239 ``` 240 241 ### Notary 242 243 If using your own notary server and a self-signed certificate or an internal 244 Certificate Authority, you need to place the certificate at 245 `tls/<registry_url>/ca.crt` in your docker config directory. 246 247 Alternatively you can trust the certificate globally by adding it to your system's 248 list of root Certificate Authorities. 249 250 ## Examples 251 252 ### Display help text 253 254 To list the help on any command just execute the command, followed by the 255 `--help` option. 256 257 $ docker run --help 258 259 Usage: docker run [OPTIONS] IMAGE [COMMAND] [ARG...] 260 261 Run a command in a new container 262 263 Options: 264 --add-host value Add a custom host-to-IP mapping (host:ip) (default []) 265 -a, --attach value Attach to STDIN, STDOUT or STDERR (default []) 266 ... 267 268 ### Option types 269 270 Single character command line options can be combined, so rather than 271 typing `docker run -i -t --name test busybox sh`, 272 you can write `docker run -it --name test busybox sh`. 273 274 #### Boolean 275 276 Boolean options take the form `-d=false`. The value you see in the help text is 277 the default value which is set if you do **not** specify that flag. If you 278 specify a Boolean flag without a value, this will set the flag to `true`, 279 irrespective of the default value. 280 281 For example, running `docker run -d` will set the value to `true`, so your 282 container **will** run in "detached" mode, in the background. 283 284 Options which default to `true` (e.g., `docker build --rm=true`) can only be 285 set to the non-default value by explicitly setting them to `false`: 286 287 ```bash 288 $ docker build --rm=false . 289 ``` 290 291 #### Multi 292 293 You can specify options like `-a=[]` multiple times in a single command line, 294 for example in these commands: 295 296 ```bash 297 $ docker run -a stdin -a stdout -i -t ubuntu /bin/bash 298 299 $ docker run -a stdin -a stdout -a stderr ubuntu /bin/ls 300 ``` 301 302 Sometimes, multiple options can call for a more complex value string as for 303 `-v`: 304 305 ```bash 306 $ docker run -v /host:/container example/mysql 307 ``` 308 309 > **Note**: Do not use the `-t` and `-a stderr` options together due to 310 > limitations in the `pty` implementation. All `stderr` in `pty` mode 311 > simply goes to `stdout`. 312 313 #### Strings and Integers 314 315 Options like `--name=""` expect a string, and they 316 can only be specified once. Options like `-c=0` 317 expect an integer, and they can only be specified once.