compose/docs/cli/run.md

2.2 KiB

docker run

Run will create a new container and execute commands in the specified image. An image is a packaged up filesystem that you have built or that you pull from a registry such as Docker Hub.

You can either use run to create an interactive session, or run a container in the background and read the output or connect to it later.

To create an interactive container, use docker run --interactive --tty ... or in short form docker run -it ..., for example docker run -it ubuntu will give you an interactive session inside an Ubuntu image. To specify a command other than the default for the image (which is to run bash in the case of Ubuntu), specify the command after the image name, for example docker run ubuntu ls.

docker run [OPTIONS] _image_ [COMMAND] [ARG...]

Options

      --name string                    Assign a name to the container; a default will be given otherwise
  -d, --detach                         Run container in background and print container ID
  -i, --interactive                    Keep STDIN open even if not attached
  -e, --env list                       Set environment variables
  -l, --label list                     Set metadata on a container
      --rm                             Automatically remove the container when it exits

  -w, --workdir string                 Working directory inside the container
  -h, --hostname string                Container host name
  -m, --memory bytes                   Memory limit
      --cpus                           Number of CPUs to allocate, approximately
  -p, --publish list                   Publish a container's port(s) to the host
  -P, --publish-all                    Publish all exposed ports to random ports
      --restart string                 Restart policy to apply when a container exits (default "no")
      --entrypoint string              Overwrite the default ENTRYPOINT of the image

      --mount mount                    Attach a filesystem mount to the container
  -v, --volume list                    Bind mount a volume

TODO net, profile, logger (d2 options) need to align with d2 and clouds
TODO I think --cpus is perhaps the best measure for eg clouds etc, but would need converting to cgroups measures for Linux.