docker container exec
描述 | 在正在运行的容器中执行命令 |
---|---|
用法 | docker container exec [OPTIONS] CONTAINER COMMAND [ARG...] |
别名 | docker exec |
介绍 Docker Debug
要轻松地进入任何容器的调试 shell,请使用
docker debug
。Docker Debug 是使用docker exec
进行调试的替代方案。使用它,您可以进入任何容器或镜像的 shell,即使是精简的容器或镜像,也无需修改。此外,您可以在其可自定义的工具箱中携带您最喜欢的调试工具。立即探索Docker Debug。
描述
docker exec
命令在正在运行的容器中运行一个新命令。
使用docker exec
指定的命令仅在容器的主进程(PID 1
)运行时运行,并且如果容器重新启动,则不会重新启动。
该命令在容器的默认工作目录中运行。
该命令必须是可执行文件。链式命令或带引号的命令无效。
- 此方法有效:
docker exec -it my_container sh -c "echo a && echo b"
- 此方法无效:
docker exec -it my_container "echo a && echo b"
选项
选项 | 默认值 | 描述 |
---|---|---|
-d, --detach | 分离模式:在后台运行命令 | |
--detach-keys | 覆盖分离容器的键序列 | |
-e, --env | API 1.25+ 设置环境变量 | |
--env-file | API 1.25+ 读取环境变量文件 | |
-i, --interactive | 即使未附加,也保持 STDIN 打开 | |
--privileged | 向命令授予扩展权限 | |
-t, --tty | 分配伪 TTY | |
-u, --user | 用户名或 UID(格式:<name|uid>[:<group|gid>] ) | |
-w, --workdir | API 1.35+ 容器内的工作目录 |
示例
在正在运行的容器上运行docker exec
首先,启动一个容器。
$ docker run --name mycontainer -d -i -t alpine /bin/sh
这将创建一个名为mycontainer
的容器,并从alpine
镜像启动,其主进程为sh
shell。-d
选项(--detach
的简写)将容器设置为在后台运行,处于分离模式,并附加伪TTY(-t
)。设置-i
选项以保持STDIN
附加(-i
),这可以防止sh
进程立即退出。
接下来,在容器上执行命令。
$ docker exec -d mycontainer touch /tmp/execWorks
这将在后台的运行容器mycontainer
内创建一个新的文件/tmp/execWorks
。
接下来,在容器上执行交互式sh
shell。
$ docker exec -it mycontainer sh
这将在容器mycontainer
中启动一个新的 shell 会话。
为 exec 进程设置环境变量(--env,-e)
接下来,在当前的 bash 会话中设置环境变量。
docker exec
命令继承在创建容器时设置的环境变量。使用--env
(或-e
简写)可以覆盖全局环境变量,或者为docker exec
启动的进程设置其他环境变量。
以下示例在容器mycontainer
中创建一个新的 shell 会话,其中环境变量$VAR_A
设置为1
,$VAR_B
设置为2
。这些环境变量仅对该docker exec
命令启动的sh
进程有效,而对容器内运行的其他进程不可用。
$ docker exec -e VAR_A=1 -e VAR_B=2 mycontainer env
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=f64a4851eb71
VAR_A=1
VAR_B=2
HOME=/root
提升容器权限(--privileged)
为 exec 进程设置工作目录(--workdir,-w)
默认情况下,docker exec
命令在创建容器时设置的同一工作目录中运行。
$ docker exec -it mycontainer pwd
/
您可以使用--workdir
选项(或-w
简写)指定要执行命令的替代工作目录。
$ docker exec -it -w /root mycontainer pwd
/root
尝试在已暂停的容器上运行docker exec
如果容器已暂停,则docker exec
命令将失败并显示错误。
$ docker pause mycontainer
mycontainer
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
482efdf39fac alpine "/bin/sh" 17 seconds ago Up 16 seconds (Paused) mycontainer
$ docker exec mycontainer sh
Error response from daemon: Container mycontainer is paused, unpause the container before exec
$ echo $?
1