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.