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