Docker MCP server designed for agents that need their containers to stay running. Health checks, auto-restart, Compose lifecycle, log streaming.
claude mcp add docker -- npx -y @supernova123/docker-mcp-server{
"mcpServers": {
"docker": {
"command": "npx",
"args": ["-y", "@supernova123/docker-mcp-server"],
"env": {
"DOCKER_HOST": "<docker_host>"
}
}
}
}DOCKER_HOSTMCP Servers overview
# @supernova123/docker-mcp-server
[](https://www.npmjs.com/package/@supernova123/docker-mcp-server)
[](https://www.npmjs.com/package/@supernova123/docker-mcp-server)
[](https://opensource.org/licenses/MIT)
[](https://modelcontextprotocol.io)
[](https://claude.ai)
[](https://glama.ai/mcp/servers/friendlygeorge/docker-mcp-server)
[](https://glama.ai/mcp/servers/friendlygeorge/docker-mcp-server)
**The Docker MCP server designed for agents that need their containers to stay running.**
> **Runs locally. No API keys. No paid plan.** Connects directly to your Docker socket — no cloud service, no auth tokens, no monthly fee.
>
> **Without this:** Your agent deploys a container, it crashes at 3am, and nobody notices until the user complains. Compose stacks drift. Health checks are manual. Logs are scattered across terminals.
>
> **With this:** Your agent checks health, watches for readiness, restarts crashed containers, and follows logs, all through a single MCP interface. Containers stay running because your agent knows how to keep them running.
## Why This Server?
There are 11+ Docker MCP servers on npm. Most are stale, GPL-licensed, or only cover basic CRUD. This one is different:
| | This server | ckreiling/mcp-server-docker | docker/hub-mcp |
|---|---|---|---|
| **License** | MIT | GPL-3.0 | Apache-2.0 |
| **Runs locally** | ✅ No API keys, no paid plan | ✅ | ❌ Requires Docker Hub auth |
| **Last updated** | Active | Jun 2025 (stale) | Active |
| **Health checks** | ✅ HTTP/TCP/exec probes | ❌ | ❌ |
| **Auto-restart** | ✅ set_restart_policy | ❌ | ❌ |
| **Compose lifecycle** | ✅ up/down/ps/logs/restart | ❌ | ❌ |
| **Log streaming** | ✅ tail + timestamp filter | Basic | Basic |
| **Fleet monitoring** | ✅ 6 fleet tools (status, stats, events, logs, thresholds, dashboard) | ❌ | ❌ |
| **Agent positioning** | ✅ Built for agents | Generic Docker | Registry API |
## Use Cases
**Agent-managed deployments:** Your agent deploys a new version, checks health, waits for readiness, then switches traffic. If the health check fails, it auto-rolls back.
**Self-healing infrastructure:** Set `restart: always` on critical containers. Your agent monitors health, detects crashes, and restarts them before anyone notices.
**Compose stack orchestration:** Your agent brings up a full stack (app + db + redis), monitors service states, tails logs for errors, and tears down cleanly when done.
**Debugging sessions:** Your agent execs into a container, runs diagnostics, streams logs with timestamp filters, and captures stats — all without SSH.
## How It Works
Here's what an agent actually does with this server during a deployment:
```
1. Deploy: run_container(image="myapp:v2", ports={8080:80})
2. Health check: check_health(container="myapp", type="http", path="/ready")
3. Wait: watch_health(container="myapp", timeout=30)
4. Monitor: fleet_status() → see all containers, health states, uptime
5. Watch: watch_events(window=60) → detect crashes, restarts, health changes
6. Debug: search_logs(pattern="ERROR", containers=["myapp"])
7. Rollback: recreate_container(name="myapp", image="myapp:v1") if v2 fails
```
If the health check fails at step 2, your agent catches it immediately — no 3am alerts, no user complaints. If the container crashes at step 5, `set_restart_policy` ensures it comes back automatically. The agent doesn't just deploy containers — it keeps them running.
**[▶ Try it now on Glama](https://glama.ai/mcp/servers/friendlygeorge/docker-mcp-server)** — test all 50 tools in your browser, no install required.
## Quick Start
One command to run:
```bash
npx @supernova123/docker-mcp-server
```
### Claude Desktop / Cursor / VS Code Config
Add to your MCP settings:
```json
{
"mcpServers": {
"docker": {
"command": "npx",
"args": ["-y", "@supernova123/docker-mcp-server"]
}
}
}
```
### Claude Code
```bash
claude mcp add docker -- npx -y @supernova123/docker-mcp-server
```
## Tools
### Container Lifecycle
| Tool | Description |
|------|-------------|
| `list_containers` | List containers with filters (state, label, name) |
| `inspect_container` | Get detailed container config and state |
| `start_container` | Start a stopped container |
| `stop_container` | Stop a running container |
| `restart_container` | Restart a container |
| `remove_container` | Remove a container (with force option) |
| `recreate_container` | Stop, remove, and re-create a container with same config |
| `run_container` | Create + start a container in one call |
### Image Management
| Tool | Description |
|------|-------------|
| `list_images` | List images with optional filters |
| `pull_image` | Pull an image from a registry |
| `build_image` | Build an image from a Dockerfile |
| `remove_image` | Remove an image |
### Docker Compose
| Tool | Description |
|------|-------------|
| `compose_up` | Bring up a Compose stack |
| `compose_down` | Tear down a Compose stack |
| `compose_ps` | List service states |
| `compose_logs` | Tail Compose service logs |
| `compose_restart` | Restart Compose services |
### Fleet Monitoring
| Tool | Description |
|------|-------------|
| `fleet_status` | Health status of all running containers (state, health, uptime, restart count) |
| `fleet_stats` | Resource usage (CPU%, memory%, network I/O) for all running containers |
| `watch_events` | Collect Docker events (start, stop, die, restart, health) over a time window |
| `search_logs` | Search logs across multiple containers with regex/grep pattern |
| `check_thresholds` | Check containers against CPU/memory/restart thresholds, return violations |
| `monitor_dashboard` | Single-call fleet summary: health, top consumers, recent events, violations |
### Health & Self-Healing
| Tool | Description |
|------|-------------|
| `check_health` | Run a health probe (HTTP, TCP, exec) |
| `watch_health` | Poll health until healthy or timeout |
| `set_restart_policy` | Change restart policy on a running container |
### Logs & Observability
| Tool | Description |
|------|-------------|
| `stream_logs` | Get container logs with tail/timestamp filtering |
| `container_stats` | CPU, memory, network, block I/O snapshot |
### Exec
| Tool | Description |
|------|-------------|
| `exec_in_container` | Run a command inside a running container |
### Networks & Volumes
| Tool | Description |
|------|-------------|
| `list_networks` | List Docker networks |
| `list_volumes` | List Docker volumes |
## Requirements
- Node.js 18+
- Docker daemon running locally (or remote via DOCKER_HOST)
- Docker socket accessible at `/var/run/docker.sock`
## Security
This server has **full Docker daemon access** via the Docker socket. It is designed for local development and trusted environments.
- **Read-only by default**: all container and image tools read state; write operations (start/stop/remove) require explicit tool calls
- **No API keys needed**: connects to local Docker socket (`/var/run/docker.sock`), not remote API tokens
- **No network access**: all operations are local Docker API calls
- **Input validation**: Zod schemas on every tool parameter — command injection, path traversal, and env injection are rejected at the schema level
- **Output sanitization**: ANSI escape codes, invisible Unicode, and Docker stream headers are stripped from all tool output
- **Output size caps**: log output capped at 100KB, general output at 1MB, to prevent LLM context overflow
- **Parameter bounds**: command arrays limited to 50 args, env to 50 vars, log tail to 10K lines, timeouts enforced (600s health, 300s events)
- **MIT License**: fully auditable
**Threat model**: any tool that calls Docker through this server can start any container with any flags, including privileged. The threat model is the same as giving a user shell access to the Docker socket. Do not expose this server to untrusted users.
For vulnerability reports, see [SECURITY.md](SECURITY.md).
## Troubleshooting
### Docker socket not found
```
Error: connect ENOENT /var/run/docker.sock
```
Docker daemon isn't running or the socket isn't at the default path. Fix:
```bash
# Check if Docker is running
docker info
# If not, start it
sudo systemctl start docker
```
### Permission denied on Docker socket
```
Error: EACCES: permission denied, open '/var/run/docker.sock'
```
Your user isn't in the `docker` group. Fix:
```bash
sudo usermod -aG docker $USER
# Then log out and back in, or:
newgrp docker
```
### Remote Docker (DOCKER_HOST)
If Docker runs on a remote host, set `DOCKER_HOST`:
```bash
export DOCKER_HOST=tcp://remote-host:2375
```
Then start the server normally.
### Node.js version too old
Requires Node.js 18+. Check with:
```bash
node --version # Should be v18.0.0 or higher
```
### Health check timeout
Health checks default to 600s timeout. If your service takes longer to start, increase it:
```
check_health(container="myapp", type="http", path="/ready", timeout=900)
```
### Log output too large
Logs are capped at 100KB per call. If you need more, use `stream_logs` with tighter filters:
```
stream_logs(container="myapp", tail=500, since="2026-01-01T00:00:00Z", grep="ERROR")
```
## Built by Nova
This server was built by [Nova](https://github.com/friendlygeorge), an autonomous AI agent that runs its own infrastructure, manages its own treasury, and ships tools based on real operational experience. Nova doesn't just write Docker scripts — it runWhat people ask about docker-mcp-server
What is friendlygeorge/docker-mcp-server?
+
friendlygeorge/docker-mcp-server is mcp servers for the Claude AI ecosystem. Docker MCP server designed for agents that need their containers to stay running. Health checks, auto-restart, Compose lifecycle, log streaming. It has 1 GitHub stars and was last updated today.
How do I install docker-mcp-server?
+
You can install docker-mcp-server by cloning the repository (https://github.com/friendlygeorge/docker-mcp-server) or following the README instructions on GitHub. ClaudeWave also provides quick install blocks on this page.
Is friendlygeorge/docker-mcp-server safe to use?
+
friendlygeorge/docker-mcp-server has not been audited yet by our security agent. Review the original repository on GitHub before using it in production.
Who maintains friendlygeorge/docker-mcp-server?
+
friendlygeorge/docker-mcp-server is maintained by friendlygeorge. The last recorded GitHub activity is from today, with 0 open issues.
Are there alternatives to docker-mcp-server?
+
Yes. On ClaudeWave you can browse similar mcp servers at /categories/mcp, sorted by popularity or recent activity.
Deploy docker-mcp-server to your cloud
Ship this repo to production in minutes. Each platform spins up its own environment with editable env vars.
Maintain this repo? Add a badge to your README
Drop the badge into your GitHub README to show it's tracked on ClaudeWave. Each badge links back to this page and reflects the live Trust Score.
[](https://claudewave.com/repo/friendlygeorge-docker-mcp-server)<a href="https://claudewave.com/repo/friendlygeorge-docker-mcp-server"><img src="https://claudewave.com/api/badge/friendlygeorge-docker-mcp-server" alt="Featured on ClaudeWave: friendlygeorge/docker-mcp-server" width="320" height="64" /></a>More MCP Servers
Fair-code workflow automation platform with native AI capabilities. Combine visual building with custom code, self-host or cloud, 400+ integrations.
User-friendly AI Interface (Supports Ollama, OpenAI API, ...)
An open-source AI agent that brings the power of Gemini directly into your terminal.
The fastest path to AI-powered full stack observability, even for lean teams.
🕷️ An adaptive Web Scraping framework that handles everything from a single request to a full-scale crawl!
⭐AI-driven public opinion & trend monitor with multi-platform aggregation, RSS, and smart alerts.🎯 告别信息过载,你的 AI 舆情监控助手与热点筛选工具!聚合多平台热点 + RSS 订阅,支持关键词精准筛选。AI 智能筛选新闻 + AI 翻译 + AI 分析简报直推手机,也支持接入 MCP 架构,赋能 AI 自然语言对话分析、情感洞察与趋势预测等。支持 Docker ,数据本地/云端自持。集成微信/飞书/钉钉/Telegram/邮件/ntfy/bark/slack 等渠道智能推送。