container-mcp
MCP server for Apple container to manage, build, inspect, and diagnose Linux containers on macOS directly from AI agents.
README
container-mcp
MCP server for Apple container ā manage, build, inspect, and diagnose Linux containers on macOS directly from AI agents like Claude Desktop, Claude Code, and Cursor.
Built on Apple's container CLI for native Linux container support on Apple Silicon Macs.
Prerequisites
- macOS 26+ (Tahoe) on Apple Silicon (M1/M2/M3/M4)
- Apple container CLI installed ā github.com/apple/container
- Node.js 18+
Installation
npm install -g container-mcp
You can run the server directly via npx using the published npm package:
npx -y @arxndev/container-mcp
Or, if you prefer to build from source:
Configuration
For Claude Desktop
Add this to your claude_desktop_config.json file:
{
"mcpServers": {
"container-mcp": {
"command": "npx",
"args": [
"-y",
"@arxndev/container-mcp"
]
}
}
}
Claude Code
claude mcp add container-mcp -- npx -y container-mcp
Cursor
Add to .cursor/mcp.json in your project:
{
"mcpServers": {
"container": {
"command": "npx",
"args": ["-y", "container-mcp"]
}
}
}
Environment Variables
| Variable | Default | Description |
|---|---|---|
CONTAINER_CLI_PATH |
container |
Path to the container CLI binary |
CONTAINER_MCP_LOG_LEVEL |
info |
Log level: debug, info, warn, error |
CONTAINER_MCP_VOLUME_ROOT |
$HOME |
Restricts host paths for volume mounts and file copies. Paths outside this root are rejected. |
CONTAINER_MCP_CONTEXT_ROOT |
$HOME |
Restricts the build context path for build_image. Paths outside this root are rejected. |
Tool Reference
š³ Container Lifecycle (14 tools)
| Tool | Description | Key Parameters |
|---|---|---|
list_containers |
List all containers | all, format |
run_container |
Create & run a new container | image, name, ports, env, volumes, detach, command |
stop_container |
Stop running containers | names, timeout |
start_container |
Start stopped containers | names |
delete_container |
Remove containers | names, force |
inspect_container |
Get detailed container info | name |
exec_in_container |
Execute command in container | name, command, interactive |
container_commit |
Commit container to new image | container, image, message |
copy_to_container |
Copy file/dir from host to container | hostPath, containerName, containerPath |
copy_from_container |
Copy file/dir from container to host | containerName, containerPath, hostPath |
wait_container |
Wait for container stop, get exit code | name, timeout |
rename_container |
Rename an existing container | container, newName |
pause_container |
Pause processes in containers | names |
unpause_container |
Unpause processes in containers | names |
š¦ Image Management (7 tools)
| Tool | Description | Key Parameters |
|---|---|---|
list_images |
List local images | format |
pull_image |
Pull image from registry | reference |
build_image |
Build image from Dockerfile | context, tag, dockerfile, buildArgs, platform |
remove_image |
Remove images | references, force |
inspect_image |
Get detailed image info | reference |
tag_image |
Tag an existing local image | source, target |
push_image |
Push image to registry | image |
š Logs & Monitoring (3 tools)
| Tool | Description | Key Parameters |
|---|---|---|
get_logs |
Get container logs | name, tail, since |
get_container_stats |
Get CPU/memory/network stats | name |
get_container_processes |
List processes in container | name |
š¾ Volumes (3 tools)
| Tool | Description | Key Parameters |
|---|---|---|
list_volumes |
List all volumes | format |
create_volume |
Create a new volume | name, size |
delete_volume |
Remove volumes | names, force |
š Networks (3 tools)
| Tool | Description | Key Parameters |
|---|---|---|
create_network |
Create a container network | name, driver, options |
delete_network |
Remove one or more networks | networks |
list_networks |
List all networks | format |
āļø System (2 tools)
| Tool | Description | Key Parameters |
|---|---|---|
system_info |
Get system info & version | ā |
system_prune |
Remove all unused resources | confirm (must be true) |
š¤ AI-Powered Diagnostics (2 tools)
| Tool | Description | Key Parameters |
|---|---|---|
diagnose_container |
Analyze logs & inspect data for issues | name |
explain_container |
Human-readable container summary | name |
Example Prompts
Here are natural language prompts you can use with Claude or any MCP-compatible AI:
"List all my running containers"
"Run an nginx container named web-server on port 8080"
"Why is my database container crashing?"
"Show me the logs from the api container"
"Pull the latest Ubuntu image and run a container with it"
"What's the memory usage of all running containers?"
"Explain what the postgres container is doing"
"Build a Docker image from the current directory and tag it myapp:latest"
"Stop all containers and clean up unused images"
"Diagnose why the redis container keeps restarting"
Development
Setup
git clone https://github.com/your-org/container-mcp.git
cd container-mcp
npm install
Build
npm run build
Test
npm test
npm run test:coverage
Run locally
npm run dev
Contributing
- Fork the repository
- Create a feature branch:
git checkout -b feature/my-feature - Write code and tests
- Ensure tests pass:
npm test - Ensure the build works:
npm run build - Submit a Pull Request
Code Style
- TypeScript strict mode
- ESM modules
- Prettier + ESLint for formatting
- Zod schemas for all input validation
- JSDoc comments on all exported functions
Architecture
container-mcp
āāā MCP Server (stdio transport)
ā āāā Container Tools (8) āā container CLI
ā āāā Image Tools (5) āāāāāā container CLI
ā āāā Log Tools (3) āāāāāāāā container CLI
ā āāā Volume Tools (3) āāāāā container CLI
ā āāā Network Tools (1) āāāā container CLI
ā āāā System Tools (2) āāāāā container CLI
ā āāā AI Tools (2) āāāāāāāā combines multiple CLI calls
ā āāā diagnose_container ā logs + inspect ā pattern analysis
ā āāā explain_container ā inspect + stats + top ā summary
āāā Utilities
āāā CLI Executor (execa, safe args)
āāā Output Parsers (JSON, table)
āāā Logger (structured, stderr)
License
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.