# docker.el
**Repository Path**: mirrors_Silex/docker.el
## Basic Information
- **Project Name**: docker.el
- **Description**: Manage docker from Emacs.
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2022-01-06
- **Last Updated**: 2026-05-10
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
[](http://melpa.org/#/docker)
[](http://stable.melpa.org/#/docker)

# docker.el
Emacs integration for [Docker](https://www.docker.com)!
Supports docker containers, images, volumes, networks, contexts and docker-compose.
## Screenshots
### List images

### Image run

## Installation
The recommended way to install docker.el is through [MELPA](https://github.com/milkypostman/melpa).
Here is a example [use-package](https://github.com/jwiegley/use-package) configuration:
``` elisp
(use-package docker
:ensure t
:bind ("C-c d" . docker))
```
## Quickstart
Use M-x docker, select a resource then mark or unmark items using the following keybindings (for more
marking possibilities, check out https://github.com/politza/tablist):
| Binding | Description |
|--------------------|----------------------|
| ? | List actions |
| l | Configure listing |
| m | Mark item |
| u | Unmark item |
| t | Toggle marks |
| U | Unmark all |
| s | Sort |
| * r | Mark items by regexp |
| < | Shrink column |
| > | Enlarge column |
| C-c C-e | Export to csv |
Then select an action and follow the instructions.
## Supported commands
- docker container: attach, cp, diff, inspect, kill, logs, pause, rename, restart, rm, start, stop, unpause
- docker image: history, inspect, pull, push, rm, run, tag
- docker network: rm
- docker volume: rm
- docker context: ls, use
- docker-compose: build, config, create, down, exec, logs, pause, pull, push, remove, restart, run, start, stop, unpause, up
You can also enter `dired` or open a file inside a container or volume.
## Customizations
Thanks to [transient](https://github.com/magit/transient), all the transients arguments can be set temporarily or
permanently. See https://magit.vc/manual/transient/Saving-Values.html#Saving-Values for more information.
There are also hidden items (e.g on `M-x docker` where you could specify the host or TLS settings), see
https://magit.vc/manual/transient/Enabling-and-Disabling-Suffixes.html for more information.
Here is a list of other customizations you can set:
| Variable | Description | Default |
|---------------------------------------|--------------------------------------------|----------------------|
| docker-command | The docker binary to use | `docker` |
| docker-compose-command | The docker-compose binary to use | `docker-compose` |
| docker-container-columns | Columns definition for containers | `/bin/sh` |
| docker-container-default-sort-key | Sort key for containers | `("Image")` |
| docker-container-shell-file-name | Shell to use when entering containers | `/bin/sh` |
| docker-container-tramp-method | Tramp prefix when connecting to containers | `docker` |
| docker-image-columns | Columns definition for images | Too complex to show |
| docker-image-default-sort-key | Sort key for images | `("Repository")` |
| docker-image-history-columns | Columns definition for image history | Too complex to show |
| docker-image-history-default-sort-key | Sort key for image history | `("Created" . t)` |
| docker-image-run-default-args | Base arguments to use for docker run | `("-i" "-t" "--rm")` |
| docker-inspect-view-mode | Mode used in `docker inspect` buffers | Too complex to show |
| docker-network-columns | Columns definition for networks | Too complex to show |
| docker-network-default-sort-key | Sort key for networks | `("Name")` |
| docker-pop-to-buffer-action | Action for `docker-utils-pop-to-buffer` | `nil` |
| docker-run-as-root | Runs docker as root when enabled | `nil` |
| docker-terminal-backend | Terminal backend for live buffers | `auto` |
| docker-show-messages | If non-nil message docker commands | `t` |
| docker-show-status | When to compute status | `local-only` |
| docker-volume-columns | Columns definition for volumes | Too complex to show |
| docker-volume-default-sort-key | Sort key for volumes | `("Driver")` |
### Changing the default arguments for `docker run`
You can match on the repository name for an image to customize the initial infix arguments via `docker-image-run-custom-args`:
```elisp
(add-to-list
'docker-image-run-custom-args
`("^postgres" ("-e POSTGRES_PASSWORD=postgres" . ,docker-image-run-default-args)))
```
So when `docker run` is called on an image whose repository name matches the regular expression `^postgres`, the option
`"-e POSTGRES_PASSWORD=postgres"` will appear as set along with the defaults specified by `docker-image-run-default-args`.
## Terminal support
Commands that need a running buffer (for example `docker run`, `docker logs`, etc) use the backend selected by
`docker-terminal-backend`. When set to `auto`, it prefers [eat](https://codeberg.org/akib/emacs-eat),
then [vterm](https://github.com/akermu/emacs-libvterm), then shell.
Non-interactive streaming buffers (for example `docker logs -f`) always use a shell buffer so output can be
rendered with ANSI color and kept read-only.
## Contributions
They are very welcome, either as suggestions or as pull requests by opening tickets
on the [issue tracker](https://github.com/Silex/docker.el/issues).