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.