| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 | command: docker compose runshort: Run a one-off command on a service.long: |-    Runs a one-time command against a service.    the following command starts the `web` service and runs `bash` as its command:    ```console    $ docker compose run web bash    ```    Commands you use with run start in new containers with configuration defined by that of the service,    including volumes, links, and other details. However, there are two important differences:    First, the command passed by `run` overrides the command defined in the service configuration. For example, if the    `web` service configuration is started with `bash`, then `docker compose run web python app.py` overrides it with    `python app.py`.    The second difference is that the `docker compose run` command does not create any of the ports specified in the    service configuration. This prevents port collisions with already-open ports. If you do want the service’s ports    to be created and mapped to the host, specify the `--service-ports`    ```console    $ docker compose run --service-ports web python manage.py shell    ```    Alternatively, manual port mapping can be specified with the `--publish` or `-p` options, just as when using docker run:    ```console    $ docker compose run --publish 8080:80 -p 2022:22 -p 127.0.0.1:2021:21 web python manage.py shell    ```    If you start a service configured with links, the run command first checks to see if the linked service is running    and starts the service if it is stopped. Once all the linked services are running, the run executes the command you    passed it. For example, you could run:    ```console    $ docker compose run db psql -h db -U docker    ```    This opens an interactive PostgreSQL shell for the linked `db` container.    If you do not want the run command to start linked containers, use the `--no-deps` flag:    ```console    $ docker compose run --no-deps web python manage.py shell    ```    If you want to remove the container after running while overriding the container’s restart policy, use the `--rm` flag:    ```console    $ docker compose run --rm web python manage.py db upgrade    ```    This runs a database upgrade script, and removes the container when finished running, even if a restart policy is    specified in the service configuration.usage: docker compose run [OPTIONS] SERVICE [COMMAND] [ARGS...]pname: docker composeplink: docker_compose.yamloptions:    - option: build      value_type: bool      default_value: "false"      description: Build image before starting container.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: detach      shorthand: d      value_type: bool      default_value: "false"      description: Run container in background and print container ID      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: entrypoint      value_type: string      description: Override the entrypoint of the image      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: env      shorthand: e      value_type: stringArray      default_value: '[]'      description: Set environment variables      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: interactive      shorthand: i      value_type: bool      default_value: "true"      description: Keep STDIN open even if not attached.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: label      shorthand: l      value_type: stringArray      default_value: '[]'      description: Add or override a label      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: name      value_type: string      description: Assign a name to the container      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: no-TTY      shorthand: T      value_type: bool      default_value: "true"      description: 'Disable pseudo-TTY allocation (default: auto-detected).'      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: no-deps      value_type: bool      default_value: "false"      description: Don't start linked services.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: publish      shorthand: p      value_type: stringArray      default_value: '[]'      description: Publish a container's port(s) to the host.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: quiet-pull      value_type: bool      default_value: "false"      description: Pull without printing progress information.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: remove-orphans      value_type: bool      default_value: "false"      description: Remove containers for services not defined in the Compose file.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: rm      value_type: bool      default_value: "false"      description: Automatically remove the container when it exits      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: service-ports      value_type: bool      default_value: "false"      description: |        Run command with the service's ports enabled and mapped to the host.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: tty      shorthand: t      value_type: bool      default_value: "true"      description: Allocate a pseudo-TTY.      deprecated: false      hidden: true      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: use-aliases      value_type: bool      default_value: "false"      description: |        Use the service's network useAliases in the network(s) the container connects to.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: user      shorthand: u      value_type: string      description: Run as specified username or uid      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: volume      shorthand: v      value_type: stringArray      default_value: '[]'      description: Bind mount a volume.      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: false    - option: workdir      shorthand: w      value_type: string      description: Working directory inside the container      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: falseinherited_options:    - option: dry-run      value_type: bool      default_value: "false"      description: Execute command in dry run mode      deprecated: false      hidden: false      experimental: false      experimentalcli: false      kubernetes: false      swarm: falsedeprecated: falseexperimental: falseexperimentalcli: falsekubernetes: falseswarm: false
 |