2022-03-09 12:57:07 +01:00
|
|
|
|
# docker compose run
|
|
|
|
|
|
|
|
|
|
<!---MARKER_GEN_START-->
|
2024-02-14 20:02:37 +01:00
|
|
|
|
Run a one-off command on a service
|
2022-03-09 12:57:07 +01:00
|
|
|
|
|
|
|
|
|
### Options
|
|
|
|
|
|
2024-02-14 20:02:37 +01:00
|
|
|
|
| Name | Type | Default | Description |
|
|
|
|
|
|:------------------------|:--------------|:--------|:---------------------------------------------------------------------------------|
|
|
|
|
|
| `--build` | | | Build image before starting container |
|
|
|
|
|
| `--cap-add` | `list` | | Add Linux capabilities |
|
|
|
|
|
| `--cap-drop` | `list` | | Drop Linux capabilities |
|
|
|
|
|
| `-d`, `--detach` | | | Run container in background and print container ID |
|
|
|
|
|
| `--dry-run` | | | Execute command in dry run mode |
|
|
|
|
|
| `--entrypoint` | `string` | | Override the entrypoint of the image |
|
|
|
|
|
| `-e`, `--env` | `stringArray` | | Set environment variables |
|
2024-03-22 11:42:35 +01:00
|
|
|
|
| `-i`, `--interactive` | `bool` | `true` | Keep STDIN open even if not attached |
|
2024-02-14 20:02:37 +01:00
|
|
|
|
| `-l`, `--label` | `stringArray` | | Add or override a label |
|
|
|
|
|
| `--name` | `string` | | Assign a name to the container |
|
2024-03-22 11:42:35 +01:00
|
|
|
|
| `-T`, `--no-TTY` | `bool` | `true` | Disable pseudo-TTY allocation (default: auto-detected) |
|
2024-02-14 20:02:37 +01:00
|
|
|
|
| `--no-deps` | | | Don't start linked services |
|
|
|
|
|
| `-p`, `--publish` | `stringArray` | | Publish a container's port(s) to the host |
|
|
|
|
|
| `--quiet-pull` | | | Pull without printing progress information |
|
|
|
|
|
| `--remove-orphans` | | | Remove containers for services not defined in the Compose file |
|
|
|
|
|
| `--rm` | | | Automatically remove the container when it exits |
|
|
|
|
|
| `-P`, `--service-ports` | | | Run command with all service's ports enabled and mapped to the host |
|
|
|
|
|
| `--use-aliases` | | | Use the service's network useAliases in the network(s) the container connects to |
|
|
|
|
|
| `-u`, `--user` | `string` | | Run as specified username or uid |
|
|
|
|
|
| `-v`, `--volume` | `stringArray` | | Bind mount a volume |
|
|
|
|
|
| `-w`, `--workdir` | `string` | | Working directory inside the container |
|
2022-03-09 12:57:07 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<!---MARKER_GEN_END-->
|
2021-03-11 16:20:30 +01:00
|
|
|
|
|
2021-06-08 09:39:49 +02:00
|
|
|
|
## Description
|
2021-03-11 16:20:30 +01:00
|
|
|
|
|
2022-03-09 13:24:09 +01:00
|
|
|
|
Runs a one-time command against a service.
|
2021-03-11 16:20:30 +01:00
|
|
|
|
|
2023-06-19 07:55:23 +02:00
|
|
|
|
The following command starts the `web` service and runs `bash` as its command:
|
2021-09-13 17:14:32 +02:00
|
|
|
|
|
|
|
|
|
```console
|
|
|
|
|
$ docker compose run web bash
|
|
|
|
|
```
|
2021-03-11 16:20:30 +01:00
|
|
|
|
|
|
|
|
|
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:
|
|
|
|
|
|
2022-03-09 13:24:09 +01:00
|
|
|
|
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
|
2021-03-11 16:20:30 +01:00
|
|
|
|
`python app.py`.
|
|
|
|
|
|
2022-03-09 13:24:09 +01:00
|
|
|
|
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
|
2021-03-11 16:20:30 +01:00
|
|
|
|
to be created and mapped to the host, specify the `--service-ports`
|
|
|
|
|
|
2021-09-13 17:14:32 +02:00
|
|
|
|
```console
|
|
|
|
|
$ docker compose run --service-ports web python manage.py shell
|
2021-03-11 16:20:30 +01:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Alternatively, manual port mapping can be specified with the `--publish` or `-p` options, just as when using docker run:
|
|
|
|
|
|
2021-09-13 17:14:32 +02:00
|
|
|
|
```console
|
|
|
|
|
$ docker compose run --publish 8080:80 -p 2022:22 -p 127.0.0.1:2021:21 web python manage.py shell
|
2021-03-11 16:20:30 +01:00
|
|
|
|
```
|
|
|
|
|
|
2022-03-09 13:24:09 +01:00
|
|
|
|
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
|
2021-03-11 16:20:30 +01:00
|
|
|
|
passed it. For example, you could run:
|
|
|
|
|
|
2021-09-13 17:14:32 +02:00
|
|
|
|
```console
|
|
|
|
|
$ docker compose run db psql -h db -U docker
|
2021-03-11 16:20:30 +01:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
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:
|
|
|
|
|
|
2021-09-13 17:14:32 +02:00
|
|
|
|
```console
|
|
|
|
|
$ docker compose run --no-deps web python manage.py shell
|
2021-03-11 16:20:30 +01:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
If you want to remove the container after running while overriding the container’s restart policy, use the `--rm` flag:
|
|
|
|
|
|
2021-09-13 17:14:32 +02:00
|
|
|
|
```console
|
|
|
|
|
$ docker compose run --rm web python manage.py db upgrade
|
2021-03-11 16:20:30 +01:00
|
|
|
|
```
|
|
|
|
|
|
2022-03-09 13:24:09 +01:00
|
|
|
|
This runs a database upgrade script, and removes the container when finished running, even if a restart policy is
|
2021-09-13 17:14:32 +02:00
|
|
|
|
specified in the service configuration.
|