添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
break; }" class="flex-grow px-2 bg-transparent min-w-0 text-white placeholder:text-white outline-none" placeholder=Search tabindex=0>
  • docker config
  • docker debug
  • docker init
  • docker inspect
  • docker login
  • docker logout
  • docker manifest
  • docker search
  • docker version
  • dockerd
  • Build checks
  • Dockerfile reference
  • Glossary
  • docker container exec

    Description Execute a command in a running container
    Usage docker container exec [OPTIONS] CONTAINER COMMAND [ARG...]
    Aliases
    docker exec

    Introducing Docker Debug

    To easily get a debug shell into any container, use docker debug . Docker Debug is a replacement for debugging with docker exec . With it, you can get a shell into any container or image, even slim ones, without modifications. Plus, you can bring along your favorite debugging tools in its customizable toolbox.

    Explore Docker Debug now.

    Description

    The docker exec command runs a new command in a running container.

    The command you specify with docker exec only runs while the container's primary process ( PID 1 ) is running, and it isn't restarted if the container is restarted.

    The command runs in the default working directory of the container.

    The command must be an executable. A chained or a quoted command doesn't work.

    • This works: docker exec -it my_container sh -c "echo a && echo b"
    • This doesn't work: docker exec -it my_container "echo a && echo b"

    Options

    Option Default Description
    -d, --detach Detached mode: run command in the background
    --detach-keys Override the key sequence for detaching a container
    -e, --env API 1.25+ Set environment variables
    --env-file API 1.25+ Read in a file of environment variables
    -i, --interactive Keep STDIN open even if not attached
    --privileged Give extended privileges to the command
    -t, --tty Allocate a pseudo-TTY
    -u, --user Username or UID (format: <name|uid>[:<group|gid>] )
    -w, --workdir API 1.35+ Working directory inside the container

    Examples

    Run docker exec on a running container

    First, start a container.

    $ docker run --name mycontainer -d -i -t alpine /bin/sh
    

    This creates and starts a container named mycontainer from an alpine image with an sh shell as its main process. The -d option (shorthand for --detach ) sets the container to run in the background, in detached mode, with a pseudo-TTY attached ( -t ). The -i option is set to keep STDIN attached ( -i ), which prevents the sh process from exiting immediately.

    Next, execute a command on the container.

    $ docker exec -d mycontainer touch /tmp/execWorks
    

    This creates a new file /tmp/execWorks inside the running container mycontainer , in the background.

    Next, execute an interactive sh shell on the container.

    $ docker exec -it mycontainer sh
    

    This starts a new shell session in the container mycontainer .

    Set environment variables for the exec process (--env, -e)

    Next, set environment variables in the current bash session.

    The docker exec command inherits the environment variables that are set at the time the container is created. Use the --env (or the -e shorthand) to override global environment variables, or to set additional environment variables for the process started by docker exec .

    The following example creates a new shell session in the container mycontainer , with environment variables $VAR_A set to 1 , and $VAR_B set to 2 . These environment variables are only valid for the sh process started by that docker exec command, and aren't available to other processes running inside the container.

    $ 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
    

    Escalate container privileges (--privileged)

    See docker run --privileged .

    Set the working directory for the exec process (--workdir, -w)

    By default docker exec command runs in the same working directory set when the container was created.

    $ docker exec -it mycontainer pwd
    

    You can specify an alternative working directory for the command to execute using the --workdir option (or the -w shorthand):

    $ docker exec -it -w /root mycontainer pwd
    /root
    

    Try to run docker exec on a paused container

    If the container is paused, then the docker exec command fails with an error:

    $ 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 $?