mirror of
				https://github.com/docker/compose.git
				synced 2025-10-26 16:53:53 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			296 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			296 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| command: docker compose run
 | ||
| short: 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 compose
 | ||
| plink: docker_compose.yaml
 | ||
| options:
 | ||
|     - 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: cap-add
 | ||
|       value_type: list
 | ||
|       description: Add Linux capabilities
 | ||
|       deprecated: false
 | ||
|       hidden: false
 | ||
|       experimental: false
 | ||
|       experimentalcli: false
 | ||
|       kubernetes: false
 | ||
|       swarm: false
 | ||
|     - option: cap-drop
 | ||
|       value_type: list
 | ||
|       description: Drop Linux capabilities
 | ||
|       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
 | ||
|       shorthand: P
 | ||
|       value_type: bool
 | ||
|       default_value: "false"
 | ||
|       description: |
 | ||
|         Run command with all 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: false
 | ||
| inherited_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: false
 | ||
| deprecated: false
 | ||
| hidden: false
 | ||
| experimental: false
 | ||
| experimentalcli: false
 | ||
| kubernetes: false
 | ||
| swarm: false
 | ||
| 
 |