Skip to main content
Glama
Swartdraak

Docker MCP Server

by Swartdraak

Docker MCP Server

npm version npm downloads CI CodeQL License: MIT Node.js Version TypeScript Docker Semantic Versioning

A comprehensive, production-ready, industry-standard compliant MCP (Model Context Protocol) Server that enables full Docker management capabilities for AI assistants like GitHub Copilot and Claude. Featuring 37 powerful tools covering containers, images, networks, volumes, and system operations.

๐Ÿ“‹ Table of Contents

About

Docker MCP Server is a Model Context Protocol server that bridges AI assistants with Docker, enabling natural language Docker operations. Built with TypeScript and following industry best practices, it provides a complete Docker management solution for AI-powered development workflows.

Why Docker MCP Server?

  • ๐Ÿค– AI-Native: Designed specifically for AI assistants (GitHub Copilot, Claude)

  • ๐Ÿ”ง Complete Coverage: 37 tools covering all essential Docker operations

  • ๐ŸŒ Remote Support: Connect to Docker on any host via TCP, HTTPS, or SSH tunnel

  • ๐Ÿ”’ Security First: Full TLS/SSL support with certificate authentication

  • ๐Ÿ“ฆ Production Ready: Comprehensive error handling, type safety, and testing

  • ๐Ÿ“š Well Documented: Extensive documentation with examples for every feature

  • ๐Ÿš€ Easy to Use: Simple installation and configuration

Use Cases

  • AI-Assisted DevOps: Let AI assistants manage your Docker infrastructure

  • Container Orchestration: Create, manage, and monitor containers through natural language

  • Development Automation: Automate Docker workflows with AI assistance

  • Remote Management: Securely manage Docker on remote hosts

  • Learning & Exploration: Explore Docker capabilities with AI guidance

Quick Start

# Install globally npm install -g @swartdraak/docker-mcp-server # Or use with npx (no installation needed) npx @swartdraak/docker-mcp-server

For Developers

# Clone the repository git clone https://github.com/Swartdraak/Docker-MCP.git cd Docker-MCP # Install dependencies npm install # Build the project npm run build # Start the server npm start

โœจ Features

Core Capabilities

  • โœ… 37 Docker Tools: Complete coverage of Docker operations including connection validation

  • โœ… Remote Docker Support: Connect to Docker on remote hosts via TCP, HTTP, HTTPS, or SSH tunnel

  • โœ… Secure Connections: Full TLS/SSL support for secure remote Docker management

  • โœ… Container Management: Create, run, start, stop, restart, pause, unpause, rename, remove, exec, stats, logs

  • โœ… Image Operations: List, pull, build, push, tag, remove, prune

  • โœ… Network Management: List, create, remove, inspect, connect, disconnect

  • โœ… Volume Management: List, create, remove, inspect, prune

  • โœ… System Operations: Info, version, connection validation, prune (containers, images, volumes, networks)

  • โœ… Proper Array Handling: Correctly handles command, entrypoint, and environment variables

  • โœ… VS Code Integration: Works seamlessly with GitHub Copilot

  • โœ… Industry Standard: Uses MCP SDK and Docker best practices

  • โœ… TypeScript: Full type safety and modern JavaScript features

Recent Enhancements

  • ๐ŸŒ Remote Docker Host Support: Connect to Docker on any remote host

  • ๐Ÿ”’ TLS/HTTPS Support: Secure connections with certificate authentication

  • ๐Ÿ”‘ Environment-based Configuration: Easy setup via DOCKER_HOST, DOCKER_TLS_VERIFY, DOCKER_CERT_PATH

  • ๐Ÿš‡ SSH Tunnel Support: Secure remote access without exposing Docker API

What's New in v2.0

  • ๐Ÿš€ 25 New Tools: Added extensive container, image, network, and volume management

  • ๐Ÿ”ง Container Exec: Execute commands in running containers

  • ๐Ÿ“Š Container Stats: Real-time CPU, memory, network, and I/O metrics

  • ๐Ÿ—๏ธ Image Building: Build images from Dockerfile with build args

  • ๐Ÿ”„ Advanced Lifecycle: Restart, pause, unpause, rename containers

  • ๐ŸŒ Full Network CRUD: Create, inspect, connect, disconnect, remove networks

  • ๐Ÿ’พ Full Volume CRUD: Create, inspect, remove volumes

  • ๐Ÿงน Resource Cleanup: Prune unused containers, images, volumes, networks

  • โš™๏ธ System Info: Get Docker daemon information and version

Installation

npm install -g @swartdraak/docker-mcp-server

From Source

Prerequisites

  • Node.js 18 or higher

  • Docker installed and running

  • npm or yarn package manager

Setup

  1. Clone the repository:

git clone https://github.com/Swartdraak/Docker-MCP.git cd Docker-MCP
  1. Install dependencies:

npm install
  1. Build the project:

npm run build

Usage

Standalone Mode

Run the server directly:

npm start

Remote Docker Configuration

The MCP server supports connecting to remote Docker hosts using environment variables:

Connect to Remote Docker via TCP

DOCKER_HOST=tcp://192.168.1.100:2375 npm start

Connect to Remote Docker via HTTPS with TLS

DOCKER_HOST=https://192.168.1.100:2376 \ DOCKER_TLS_VERIFY=1 \ DOCKER_CERT_PATH=~/.docker/certs \ npm start

Connect via SSH Tunnel

First, set up an SSH tunnel:

ssh -NL localhost:2375:/var/run/docker.sock user@remote-host

Then connect to the tunneled Docker:

DOCKER_HOST=tcp://localhost:2375 npm start

VS Code Integration

To integrate with VS Code and GitHub Copilot, add the following to your MCP settings file:

For Local Docker (~/.vscode/mcp-settings.json or in your workspace settings):

{ "mcpServers": { "docker": { "command": "node", "args": ["/path/to/Docker-MCP/dist/index.js"] } } }

For Remote Docker over TCP:

{ "mcpServers": { "docker": { "command": "node", "args": ["/path/to/Docker-MCP/dist/index.js"], "env": { "DOCKER_HOST": "tcp://192.168.1.100:2375" } } } }

For Remote Docker with TLS:

{ "mcpServers": { "docker": { "command": "node", "args": ["/path/to/Docker-MCP/dist/index.js"], "env": { "DOCKER_HOST": "https://192.168.1.100:2376", "DOCKER_TLS_VERIFY": "1", "DOCKER_CERT_PATH": "/home/user/.docker/certs" } } } }

For Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):

{ "mcpServers": { "docker": { "command": "node", "args": ["/path/to/Docker-MCP/dist/index.js"] } } }

Alternative using npx (after publishing to npm):

{ "mcpServers": { "docker": { "command": "npx", "args": ["@swartdraak/docker-mcp-server"] } } }

Testing Your Connection

Connection Test Utility

Before using the MCP server, you can test your Docker connection with the included test utility:

# Test local Docker connection node test-connection.js # Test remote Docker via TCP DOCKER_HOST=tcp://192.168.1.100:2375 node test-connection.js # Test remote Docker via TLS DOCKER_HOST=https://192.168.1.100:2376 \ DOCKER_TLS_VERIFY=1 \ DOCKER_CERT_PATH=~/.docker/certs \ node test-connection.js # Test SSH tunnel connection DOCKER_HOST=tcp://localhost:2375 node test-connection.js

The test utility will:

  • โœ“ Validate your configuration

  • โœ“ Check TLS certificates (if applicable)

  • โœ“ Test connection to Docker daemon

  • โœ“ Verify Docker operations (list containers, images, networks, volumes)

  • โœ“ Display system information

  • โœ“ Provide troubleshooting recommendations

validate_connection Tool

Once the MCP server is running, you can also use the validate_connection tool from your AI assistant:

"Validate my Docker connection"

This tool performs runtime connectivity tests and returns:

  • Connection status

  • Docker version and API information

  • System information

  • Test results for common operations

Manual Testing

You can also test your connection directly with Docker CLI:

# Set environment variables export DOCKER_HOST=tcp://192.168.1.100:2375 # Test commands docker version docker info docker ps

For detailed setup instructions, troubleshooting, and platform-specific guides, see:

  • CONFIGURATION.md - MCP server configuration examples

  • REMOTE_SETUP.md - Comprehensive remote connection setup guide (includes Windows 11 specific instructions)

Available Tools (37 Total)

Container Operations (15 tools)

list_containers

List all Docker containers (running or all)

{ "all": true }

create_container

Create a new Docker container

{ "image": "nginx:latest", "name": "my-nginx", "command": ["nginx", "-g", "daemon off;"], "env": ["NODE_ENV=production"], "exposedPorts": {"80/tcp": {}}, "hostConfig": { "PortBindings": {"80/tcp": [{"HostPort": "8080"}]}, "Binds": ["/host/path:/container/path"] } }

run_container

Create and start a container (recommended)

{ "image": "python:3.9", "name": "my-python-app", "command": ["python", "app.py"], "env": ["DEBUG=true", "PORT=5000"] }

start_container

Start a stopped container

{ "containerId": "container_id_or_name" }

stop_container

Stop a running container

{ "containerId": "container_id_or_name", "timeout": 10 }

remove_container

Remove a container

{ "containerId": "container_id_or_name", "force": false, "volumes": false }

inspect_container

Get detailed container information

{ "containerId": "container_id_or_name" }

container_logs

Get container logs

{ "containerId": "container_id_or_name", "tail": 100, "follow": false }

exec_container ๐Ÿ†•

Execute a command in a running container

{ "containerId": "container_id_or_name", "command": ["ls", "-la", "/app"], "workingDir": "/app", "env": ["DEBUG=true"] }

container_stats ๐Ÿ†•

Get real-time resource usage statistics (CPU, memory, network, I/O)

{ "containerId": "container_id_or_name", "stream": false }

restart_container ๐Ÿ†•

Restart a Docker container

{ "containerId": "container_id_or_name", "timeout": 10 }

pause_container ๐Ÿ†•

Pause all processes within a container

{ "containerId": "container_id_or_name" }

unpause_container ๐Ÿ†•

Unpause all processes within a container

{ "containerId": "container_id_or_name" }

rename_container ๐Ÿ†•

Rename a Docker container

{ "containerId": "container_id_or_name", "newName": "new-container-name" }

prune_containers ๐Ÿ†•

Remove all stopped containers

{}

Image Operations (7 tools)

list_images

List Docker images

{ "all": false }

pull_image

Pull an image from registry

{ "image": "nginx:latest" }

build_image ๐Ÿ†•

Build a Docker image from a Dockerfile

{ "context": "/path/to/build/context", "dockerfile": "Dockerfile", "tag": "myimage:latest", "buildArgs": { "NODE_VERSION": "18" } }

tag_image ๐Ÿ†•

Tag an image with a new name/tag

{ "image": "myimage:latest", "repo": "myrepo/myimage", "tag": "v1.0.0" }

push_image ๐Ÿ†•

Push an image to a Docker registry

{ "image": "myrepo/myimage:v1.0.0" }

remove_image ๐Ÿ†•

Remove a Docker image

{ "image": "image_id_or_name", "force": false }

prune_images ๐Ÿ†•

Remove unused images

{ "all": false }

Network Operations (7 tools)

list_networks

List Docker networks

{}

create_network ๐Ÿ†•

Create a Docker network

{ "name": "my-network", "driver": "bridge", "internal": false }

inspect_network ๐Ÿ†•

Get detailed information about a network

{ "networkId": "network_id_or_name" }

connect_network ๐Ÿ†•

Connect a container to a network

{ "networkId": "network_id_or_name", "containerId": "container_id_or_name" }

disconnect_network ๐Ÿ†•

Disconnect a container from a network

{ "networkId": "network_id_or_name", "containerId": "container_id_or_name", "force": false }

remove_network ๐Ÿ†•

Remove a Docker network

{ "networkId": "network_id_or_name" }

prune_networks ๐Ÿ†•

Remove all unused networks

{}

Volume Operations (5 tools)

list_volumes

List Docker volumes

{}

create_volume ๐Ÿ†•

Create a Docker volume

{ "name": "my-volume", "driver": "local", "labels": { "environment": "production" } }

inspect_volume ๐Ÿ†•

Get detailed information about a volume

{ "volumeName": "volume_name" }

remove_volume ๐Ÿ†•

Remove a Docker volume

{ "volumeName": "volume_name", "force": false }

prune_volumes ๐Ÿ†•

Remove all unused volumes

{}

System Operations (3 tools)

system_info ๐Ÿ†•

Get Docker system information

{}

system_version ๐Ÿ†•

Get Docker version information

{}

validate_connection ๐Ÿ†•

Validate Docker connection and test basic operations. Returns connection status, configuration details, and test results. Useful for troubleshooting connection issues.

{}

Key Features: Array Handling

This MCP server correctly handles arrays for:

  • Command: Passed as an array of strings ["python", "app.py", "--port", "8000"]

  • Entrypoint: Passed as an array of strings ["/bin/bash", "-c"]

  • Environment Variables: Passed as an array of KEY=VALUE strings ["NODE_ENV=production", "PORT=3000"]

  • Volume Bindings: Passed as an array of bind strings ["/host/path:/container/path"]

This resolves the common "array issue" where MCP servers incorrectly expect strings instead of arrays, causing errors when integrated with VS Code and GitHub Copilot.

Development

Scripts

  • npm run build - Compile TypeScript to JavaScript

  • npm run watch - Watch mode for development

  • npm start - Run the compiled server

  • npm run dev - Build and run

Project Structure

Docker-MCP/ โ”œโ”€โ”€ src/ โ”‚ โ””โ”€โ”€ index.ts # Main server implementation โ”œโ”€โ”€ dist/ # Compiled JavaScript output โ”œโ”€โ”€ package.json # Project dependencies โ”œโ”€โ”€ tsconfig.json # TypeScript configuration โ””โ”€โ”€ README.md # This file

Troubleshooting

Docker Connection Issues

If you get "Cannot connect to Docker daemon" errors:

  • Ensure Docker is running: docker ps

  • Check Docker socket permissions

  • On Linux: Add your user to the docker group: sudo usermod -aG docker $USER

Remote Docker Connection Issues

If you can't connect to a remote Docker host:

  1. TCP Connection Issues:

    • Ensure the Docker daemon is configured to listen on TCP: Check /etc/docker/daemon.json

    • Verify the port is open: telnet remote-host 2375

    • Check firewall rules on the remote host

    • Ensure DOCKER_HOST environment variable is set correctly

  2. TLS/HTTPS Connection Issues:

    • Verify certificates are in the correct directory

    • Check certificate file names: ca.pem, cert.pem, key.pem

    • Ensure certificates are readable: chmod 644 ca.pem cert.pem key.pem

    • Verify DOCKER_TLS_VERIFY=1 and DOCKER_CERT_PATH are set

    • Test with Docker CLI first: docker --tlsverify --host=tcp://remote-host:2376 ps

  3. SSH Tunnel Issues:

    • Verify SSH tunnel is running: ps aux | grep ssh

    • Test tunnel: curl http://localhost:2375/version

    • Ensure local port is not already in use: lsof -i :2375

    • Try reconnecting the tunnel if connection is lost

VS Code Integration Issues

If the MCP server doesn't appear in VS Code:

  • Verify the path to dist/index.js is absolute

  • Check that the server builds successfully: npm run build

  • Restart VS Code after updating MCP settings

  • Check VS Code Output panel for MCP-related errors

  • Verify environment variables in MCP settings are correct

This server is specifically designed to handle arrays correctly. If you encounter array errors:

  • Ensure you're passing arrays for command, entrypoint, and env fields

  • Verify JSON formatting in tool arguments

  • Check that arrays contain string items

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Development Workflow

This project follows industry-standard practices:

  • Branching Strategy: Git Flow (see BRANCHING.md)

  • Versioning: Semantic Versioning 2.0.0 (see VERSIONING.md)

  • Commit Convention: Conventional Commits

  • CI/CD: Automated testing and releases via GitHub Actions

Quick Start for Contributors

  1. Fork the repository

  2. Create a feature branch: git checkout -b feature/my-feature

  3. Make your changes with conventional commits

  4. Ensure tests pass: npm test

  5. Push and create a Pull Request to develop

For detailed guidelines, see CONTRIBUTING.md.

Branch Structure

  • main - Production releases (protected)

  • develop - Integration branch (protected)

  • feature/* - New features

  • bugfix/* - Bug fixes

  • hotfix/* - Critical production fixes

Release Process

Releases are automated via GitHub Actions when tags are pushed:

# Create release branch git checkout -b release/2.1.0 # Update version and changelog npm version minor # Merge to main and tag git checkout main git merge --no-ff release/2.1.0 git tag -a v2.1.0 -m "Version 2.1.0" git push origin main --tags

See VERSIONING.md for complete release procedures.

For detailed usage examples, see EXAMPLES.md.

For configuration help, see CONFIGURATION.md.

Documentation

User Documentation

Developer Documentation

License

MIT License - see LICENSE file for details

Author

Swartdraak (eternusprocer@gmail.com)

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Swartdraak/Docker-MCP'

If you have feedback or need assistance with the MCP directory API, please join our Discord server