docker
To list available commands, either run
docker with no parameters or execute docker help:$ docker
Usage: docker [OPTIONS] COMMAND [ARG...]
docker [ --help | -v | --version ]
A self-sufficient runtime for containers.
Options:
--config string Location of client config files (default "/root/.docker")
-D, --debug Enable debug mode
--help Print usage
-H, --host value Daemon socket(s) to connect to (default [])
-l, --log-level string Set the logging level ("debug", "info", "warn", "error", "fatal") (default "info")
--tls Use TLS; implied by --tlsverify
--tlscacert string Trust certs signed only by this CA (default "/root/.docker/ca.pem")
--tlscert string Path to TLS certificate file (default "/root/.docker/cert.pem")
--tlskey string Path to TLS key file (default "/root/.docker/key.pem")
--tlsverify Use TLS and verify the remote
-v, --version Print version information and quit
Commands:
attach Attach to a running container
# […]
Description
Depending on your Docker system configuration, you may be required to preface each
docker command with sudo. To avoid having to use sudo with the docker command, your system administrator can create a Unix group called docker and add users to it.
For more information about installing Docker or
sudo configuration, refer to the installation instructions for your operating system.Environment variables
For easy reference, the following list of environment variables are supported by the
docker command line:DOCKER_API_VERSIONThe API version to use (e.g.1.19)DOCKER_CONFIGThe location of your client configuration files.DOCKER_CERT_PATHThe location of your authentication keys.DOCKER_DRIVERThe graph driver to use.DOCKER_HOSTDaemon socket to connect to.DOCKER_NOWARN_KERNEL_VERSIONPrevent warnings that your Linux kernel is unsuitable for Docker.DOCKER_RAMDISKIf set this will disable ‘pivot_root’.DOCKER_TLS_VERIFYWhen set Docker uses TLS and verifies the remote.DOCKER_CONTENT_TRUSTWhen set Docker uses notary to sign and verify images. Equates to--disable-content-trust=falsefor build, create, pull, push, run.DOCKER_CONTENT_TRUST_SERVERThe URL of the Notary server to use. This defaults to the same URL as the registry.DOCKER_HIDE_LEGACY_COMMANDSWhen set, Docker hides “legacy” top-level commands (such asdocker rm, anddocker pull) indocker helpoutput, and onlyManagement commandsper object-type (e.g.,docker container) are printed. This may become the default in a future release, at which point this environment-variable is removed.DOCKER_TMPDIRLocation for temporary Docker files.
Because Docker is developed using Go, you can also use any environment variables used by the Go runtime. In particular, you may find these useful:
HTTP_PROXYHTTPS_PROXYNO_PROXY
These Go environment variables are case-insensitive. See the Go specification for details on these variables.
Configuration files
By default, the Docker command line stores its configuration files in a directory called
.docker within your $HOME directory. However, you can specify a different location via the DOCKER_CONFIG environment variable or the --config command line option. If both are specified, then the --config option overrides the DOCKER_CONFIG environment variable. For example:docker --config ~/testconfigs/ ps
Instructs Docker to use the configuration files in your
~/testconfigs/ directory when running the commandps.
Docker manages most of the files in the configuration directory and you should not modify them. However, you can modify the
config.json file to control certain aspects of how the docker command behaves.
Currently, you can modify the
docker command behavior using environment variables or command-line options. You can also use options within config.json to modify some of the same behavior. When using these mechanisms, you must keep in mind the order of precedence among them. Command line options override environment variables and environment variables override properties you specify in a config.json file.
The
config.json file stores a JSON encoding of several properties:
The property
HttpHeaders specifies a set of headers to include in all messages sent from the Docker client to the daemon. Docker does not try to interpret or understand these header; it simply puts them into the messages. Docker does not allow these headers to change any headers it sets for itself.
The property
psFormat specifies the default format for docker ps output. When the --format flag is not provided with the docker ps command, Docker’s client uses this property. If this property is not set, the client falls back to the default table format. For a list of supported formatting directives, see the Formatting section in the docker ps documentation
The property
imagesFormat specifies the default format for docker images output. When the --format flag is not provided with the docker images command, Docker’s client uses this property. If this property is not set, the client falls back to the default table format. For a list of supported formatting directives, see the Formatting section in the docker images documentation
The property
serviceInspectFormat specifies the default format for docker service inspect output. When the --format flag is not provided with the docker service inspect command, Docker’s client uses this property. If this property is not set, the client falls back to the default json format. For a list of supported formatting directives, see the Formatting section in the docker service inspect documentation
The property
statsFormat specifies the default format for docker stats output. When the --format flag is not provided with thedocker stats command, Docker’s client uses this property. If this property is not set, the client falls back to the default table format. For a list of supported formatting directives, see Formatting section in the docker stats documentation
Once attached to a container, users detach from it and leave it running using the using
CTRL-p CTRL-q key sequence. This detach key sequence is customizable using the detachKeys property. Specify a <sequence> value for the property. The format of the <sequence> is a comma-separated list of either a letter [a-Z], or the ctrl- combined with any of the following:a-z(a single lowercase alpha character )@(at sign)[(left bracket)\\(two backward slashes)_(underscore)^(caret)
Your customization applies to all containers started in with your Docker client. Users can override your custom or the default key sequence on a per-container basis. To do this, the user specifies the
--detach-keys flag with the docker attach, docker exec, docker run or docker start command.
Following is a sample
config.json file:{
"HttpHeaders": {
"MyHeader": "MyValue"
},
"psFormat": "table \\t\\t\\t",
"imagesFormat": "table \\t\\t\\t",
"statsFormat": "table \t\t",
"serviceInspectFormat": "pretty",
"detachKeys": "ctrl-e,e",
"credsStore": "secretservice",
"credHelpers": {
"awesomereg.example.org": "hip-star",
"unicorn.example.com": "vcbait"
}
}
Notary
If using your own notary server and a self-signed certificate or an internal Certificate Authority, you need to place the certificate at
tls/<registry_url>/ca.crt in your docker config directory.
Alternatively you can trust the certificate globally by adding it to your system’s list of root Certificate Authorities.
Examples
Display help text
To list the help on any command just execute the command, followed by the
--help option.$ docker run --help
Usage: docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
Run a command in a new container
Options:
--add-host value Add a custom host-to-IP mapping (host:ip) (default [])
-a, --attach value Attach to STDIN, STDOUT or STDERR (default [])
...
Option types
Single character command line options can be combined, so rather than typing,
docker run -i -t --name test busybox sh you can write docker run -it --name test busybox sh.BOOLEAN
Boolean options take the form
-d=false. The value you see in the help text is the default value which is set if you do not specify that flag. If you specify a Boolean flag without a value, this will set the flag to true, irrespective of the default value.
For example, running
docker run -d will set the value to true, so your container will run in “detached” mode, in the background.
Options which default to
true (e.g., docker build --rm=true) can only be set to the non-default value by explicitly setting them to false:$ docker build --rm=false .
MULTI
You can specify options like
-a=[] multiple times in a single command line, for example in these commands:$ docker run -a stdin -a stdout -i -t ubuntu /bin/bash
$ docker run -a stdin -a stdout -a stderr ubuntu /bin/ls
Sometimes, multiple options can call for a more complex value string as for
-v:$ docker run -v /host:/container example/mysql
Note: Do not use the-tand-a stderroptions together due to limitations in theptyimplementation. Allstderrinptymode simply goes tostdout.
STRINGS AND INTEGERS
Options like
--name="" expect a string, and they can only be specified once. Options like -c=0 expect an integer, and they can only be specified once.
No comments:
Post a Comment