github.com/sijibomii/docker@v0.0.0-20231230191044-5cf6ca554647/docs/reference/commandline/cli.md (about) 1 <!--[metadata]> 2 +++ 3 title = "Use the Docker command line" 4 description = "Docker's CLI command description and usage" 5 keywords = ["Docker, Docker documentation, CLI, command line"] 6 [menu.main] 7 parent = "smn_cli" 8 weight = -2 9 +++ 10 <![end-metadata]--> 11 12 # Use the Docker command line 13 14 To list available commands, either run `docker` with no parameters 15 or execute `docker help`: 16 17 $ docker 18 Usage: docker [OPTIONS] COMMAND [arg...] 19 docker daemon [ --help | ... ] 20 docker [ --help | -v | --version ] 21 22 -H, --host=[]: The socket(s) to talk to the Docker daemon in the format of tcp://host:port/path, unix:///path/to/socket, fd://* or fd://socketfd. 23 24 A self-sufficient runtime for Linux containers. 25 26 ... 27 28 Depending on your Docker system configuration, you may be required to preface 29 each `docker` command with `sudo`. To avoid having to use `sudo` with the 30 `docker` command, your system administrator can create a Unix group called 31 `docker` and add users to it. 32 33 For more information about installing Docker or `sudo` configuration, refer to 34 the [installation](../../installation/index.md) instructions for your operating system. 35 36 ## Environment variables 37 38 For easy reference, the following list of environment variables are supported 39 by the `docker` command line: 40 41 * `DOCKER_API_VERSION` The API version to use (e.g. `1.19`) 42 * `DOCKER_CONFIG` The location of your client configuration files. 43 * `DOCKER_CERT_PATH` The location of your authentication keys. 44 * `DOCKER_DRIVER` The graph driver to use. 45 * `DOCKER_HOST` Daemon socket to connect to. 46 * `DOCKER_NOWARN_KERNEL_VERSION` Prevent warnings that your Linux kernel is 47 unsuitable for Docker. 48 * `DOCKER_RAMDISK` If set this will disable 'pivot_root'. 49 * `DOCKER_TLS_VERIFY` When set Docker uses TLS and verifies the remote. 50 * `DOCKER_CONTENT_TRUST` When set Docker uses notary to sign and verify images. 51 Equates to `--disable-content-trust=false` for build, create, pull, push, run. 52 * `DOCKER_CONTENT_TRUST_SERVER` The URL of the Notary server to use. This defaults 53 to the same URL as the registry. 54 * `DOCKER_TMPDIR` Location for temporary Docker files. 55 56 Because Docker is developed using 'Go', you can also use any environment 57 variables used by the 'Go' runtime. In particular, you may find these useful: 58 59 * `HTTP_PROXY` 60 * `HTTPS_PROXY` 61 * `NO_PROXY` 62 63 These Go environment variables are case-insensitive. See the 64 [Go specification](http://golang.org/pkg/net/http/) for details on these 65 variables. 66 67 ## Configuration files 68 69 By default, the Docker command line stores its configuration files in a 70 directory called `.docker` within your `$HOME` directory. However, you can 71 specify a different location via the `DOCKER_CONFIG` environment variable 72 or the `--config` command line option. If both are specified, then the 73 `--config` option overrides the `DOCKER_CONFIG` environment variable. 74 For example: 75 76 docker --config ~/testconfigs/ ps 77 78 Instructs Docker to use the configuration files in your `~/testconfigs/` 79 directory when running the `ps` command. 80 81 Docker manages most of the files in the configuration directory 82 and you should not modify them. However, you *can modify* the 83 `config.json` file to control certain aspects of how the `docker` 84 command behaves. 85 86 Currently, you can modify the `docker` command behavior using environment 87 variables or command-line options. You can also use options within 88 `config.json` to modify some of the same behavior. When using these 89 mechanisms, you must keep in mind the order of precedence among them. Command 90 line options override environment variables and environment variables override 91 properties you specify in a `config.json` file. 92 93 The `config.json` file stores a JSON encoding of several properties: 94 95 The property `HttpHeaders` specifies a set of headers to include in all messages 96 sent from the Docker client to the daemon. Docker does not try to interpret or 97 understand these header; it simply puts them into the messages. Docker does 98 not allow these headers to change any headers it sets for itself. 99 100 The property `psFormat` specifies the default format for `docker ps` output. 101 When the `--format` flag is not provided with the `docker ps` command, 102 Docker's client uses this property. If this property is not set, the client 103 falls back to the default table format. For a list of supported formatting 104 directives, see the 105 [**Formatting** section in the `docker ps` documentation](ps.md) 106 107 Once attached to a container, users detach from it and leave it running using 108 the using `CTRL-p CTRL-q` key sequence. This detach key sequence is customizable 109 using the `detachKeys` property. Specify a `<sequence>` value for the 110 property. The format of the `<sequence>` is a comma-separated list of either 111 a letter [a-Z], or the `ctrl-` combined with any of the following: 112 113 * `a-z` (a single lowercase alpha character ) 114 * `@` (at sign) 115 * `[` (left bracket) 116 * `\\` (two backward slashes) 117 * `_` (underscore) 118 * `^` (caret) 119 120 Your customization applies to all containers started in with your Docker client. 121 Users can override your custom or the default key sequence on a per-container 122 basis. To do this, the user specifies the `--detach-keys` flag with the `docker 123 attach`, `docker exec`, `docker run` or `docker start` command. 124 125 The property `imagesFormat` specifies the default format for `docker images` output. 126 When the `--format` flag is not provided with the `docker images` command, 127 Docker's client uses this property. If this property is not set, the client 128 falls back to the default table format. For a list of supported formatting 129 directives, see the [**Formatting** section in the `docker images` documentation](images.md) 130 131 Following is a sample `config.json` file: 132 133 { 134 "HttpHeaders": { 135 "MyHeader": "MyValue" 136 }, 137 "psFormat": "table {{.ID}}\\t{{.Image}}\\t{{.Command}}\\t{{.Labels}}", 138 "imagesFormat": "table {{.ID}}\\t{{.Repository}}\\t{{.Tag}}\\t{{.CreatedAt}}", 139 "detachKeys": "ctrl-e,e" 140 } 141 142 ### Notary 143 144 If using your own notary server and a self-signed certificate or an internal 145 Certificate Authority, you need to place the certificate at 146 `tls/<registry_url>/ca.crt` in your docker config directory. 147 148 Alternatively you can trust the certificate globally by adding it to your system's 149 list of root Certificate Authorities. 150 151 ## Help 152 153 To list the help on any command just execute the command, followed by the 154 `--help` option. 155 156 $ docker run --help 157 158 Usage: docker run [OPTIONS] IMAGE [COMMAND] [ARG...] 159 160 Run a command in a new container 161 162 -a, --attach=[] Attach to STDIN, STDOUT or STDERR 163 --cpu-shares=0 CPU shares (relative weight) 164 ... 165 166 ## Option types 167 168 Single character command line options can be combined, so rather than 169 typing `docker run -i -t --name test busybox sh`, 170 you can write `docker run -it --name test busybox sh`. 171 172 ### Boolean 173 174 Boolean options take the form `-d=false`. The value you see in the help text is 175 the default value which is set if you do **not** specify that flag. If you 176 specify a Boolean flag without a value, this will set the flag to `true`, 177 irrespective of the default value. 178 179 For example, running `docker run -d` will set the value to `true`, so your 180 container **will** run in "detached" mode, in the background. 181 182 Options which default to `true` (e.g., `docker build --rm=true`) can only be 183 set to the non-default value by explicitly setting them to `false`: 184 185 $ docker build --rm=false . 186 187 ### Multi 188 189 You can specify options like `-a=[]` multiple times in a single command line, 190 for example in these commands: 191 192 $ docker run -a stdin -a stdout -i -t ubuntu /bin/bash 193 $ docker run -a stdin -a stdout -a stderr ubuntu /bin/ls 194 195 Sometimes, multiple options can call for a more complex value string as for 196 `-v`: 197 198 $ docker run -v /host:/container example/mysql 199 200 > **Note:** 201 > Do not use the `-t` and `-a stderr` options together due to 202 > limitations in the `pty` implementation. All `stderr` in `pty` mode 203 > simply goes to `stdout`. 204 205 ### Strings and Integers 206 207 Options like `--name=""` expect a string, and they 208 can only be specified once. Options like `-c=0` 209 expect an integer, and they can only be specified once.