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