Docker Hub MCP Server
Enables AI assistants to search, analyze, and manage Docker images on Docker Hub through standardized MCP tools, with features including security scanning, layer analysis, and image comparison.
README
Docker Hub MCP Server
A comprehensive Model Context Protocol (MCP) server that provides seamless integration with Docker Hub, enabling AI assistants to search, analyze, and manage Docker images through standardized MCP tools.
š Features
Core Capabilities
- Image Search & Discovery: Search Docker Hub with advanced filtering options
- Detailed Image Analysis: Get comprehensive repository information and statistics
- Tag Management: List and analyze all available tags for repositories
- Layer Analysis: Deep dive into image layers, sizes, and optimization opportunities
- Image Comparison: Compare two images for differences in layers, sizes, and composition
- Dockerfile Retrieval: Attempt to retrieve Dockerfile content when available
- Statistics & Metrics: Download counts, star ratings, and popularity analytics
Advanced Features
- Security Scanning: Vulnerability analysis and security recommendations
- Build History: Detailed layer-by-layer build process analysis
- Pull Size Estimation: Calculate actual download sizes considering caching and compression
- Performance Optimization: Layer deduplication and size optimization insights
Technical Excellence
- Production Ready: Built with TypeScript, comprehensive error handling, and rate limiting
- Smart Caching: Intelligent caching system to minimize API calls and improve performance
- Authentication Support: Secure credential management for both public and private registries
- MCP Standard Compliance: Fully compatible with popular MCP clients (Claude Desktop, Cursor, Cline)
- Multi-Transport Support: Both stdio (for MCP clients) and HTTP (for web access) transports
- Interactive Setup: Configuration wizard for easy initial setup
- Export Capabilities: Multiple export formats including CSV, SARIF, and dependency trees
- Enhanced Security: CVE cross-referencing and comprehensive security policy validation
š¦ Installation
Prerequisites
- Node.js 18+
- npm or yarn
Quick Start
-
Clone the repository
git clone <repository-url> cd mcp-docker -
Install dependencies
npm install -
Set up configuration (Interactive Wizard)
npm run setupOr manually set up environment variables:
cp env.example .env # Edit .env with your Docker Hub credentials and preferences -
Build the project
npm run build -
Start the server
npm start
š§ Configuration
Environment Variables
Create a .env file from the provided template:
# Docker Hub Authentication (Optional for public images)
DOCKERHUB_USERNAME=your_dockerhub_username
DOCKERHUB_PASSWORD=your_dockerhub_password
# OR use access token instead
DOCKERHUB_ACCESS_TOKEN=your_dockerhub_access_token
# Private Registry Support (Optional)
PRIVATE_REGISTRY_URL=https://your-private-registry.com
PRIVATE_REGISTRY_USERNAME=your_private_username
PRIVATE_REGISTRY_PASSWORD=your_private_password
# Server Configuration
MCP_SERVER_NAME=dockerhub-mcp-server
MCP_SERVER_VERSION=1.0.0
# Transport Configuration
MCP_TRANSPORT=stdio # 'stdio' for MCP clients, 'http' for web access
MCP_HTTP_HOST=localhost # Only needed for HTTP transport
MCP_HTTP_PORT=3000 # Only needed for HTTP transport
MCP_CORS=true # Enable CORS for HTTP transport
# Performance Tuning
CACHE_TTL_SECONDS=300
MAX_CACHE_SIZE=1000
DOCKERHUB_RATE_LIMIT=100
DOCKERHUB_RATE_LIMIT_WINDOW=3600
# Logging
LOG_LEVEL=info
Authentication
The server supports multiple authentication methods:
- Anonymous Access: Works for all public Docker Hub images
- Username/Password: Standard Docker Hub login credentials
- Access Token: More secure, generated from Docker Hub settings
- Private Registry: Support for custom registries
See SETUP.md for detailed authentication configuration.
š ļø Available MCP Tools
Required Tools
| Tool Name | Description |
|---|---|
docker_search_images |
Search Docker Hub for images with filtering options |
docker_get_image_details |
Get comprehensive repository information |
docker_list_tags |
List all available tags with detailed metadata |
docker_get_manifest |
Retrieve Docker image manifest and layer info |
docker_analyze_layers |
Analyze image layers for optimization insights |
docker_compare_images |
Compare two images for differences |
docker_get_dockerfile |
Attempt to retrieve Dockerfile content |
docker_get_stats |
Get download statistics and popularity metrics |
Bonus Tools
| Tool Name | Description |
|---|---|
docker_get_vulnerabilities |
Fetch security vulnerability scan results |
docker_get_image_history |
Get detailed build history and timeline |
docker_estimate_pull_size |
Calculate estimated download size for pulls |
docker_batch_image_details |
Efficiently fetch details for multiple repositories in parallel |
docker_export_data |
Export image data in various formats (CSV, dependency trees, SARIF) |
docker_enhanced_vulnerability_analysis |
Advanced security analysis with CVE cross-referencing and policy validation |
š Usage Examples
Basic Image Search
{
"tool": "docker_search_images",
"arguments": {
"query": "nginx",
"limit": 10,
"is_official": true
}
}
Detailed Image Analysis
{
"tool": "docker_get_image_details",
"arguments": {
"repository": "library/nginx"
}
}
Layer Analysis for Optimization
{
"tool": "docker_analyze_layers",
"arguments": {
"repository": "library/node",
"tag": "18-alpine"
}
}
Image Comparison
{
"tool": "docker_compare_images",
"arguments": {
"repository1": "library/node",
"tag1": "18-alpine",
"repository2": "library/node",
"tag2": "18-slim"
}
}
Security Analysis
{
"tool": "docker_get_vulnerabilities",
"arguments": {
"repository": "library/ubuntu",
"tag": "latest"
}
}
Batch Analysis
{
"tool": "docker_batch_image_details",
"arguments": {
"repositories": ["library/nginx", "library/node", "library/python"],
"include_tags": true,
"include_vulnerabilities": true,
"format": "comparison",
"export_format": "csv"
}
}
Enhanced Security Analysis
{
"tool": "docker_enhanced_vulnerability_analysis",
"arguments": {
"repository": "library/nginx",
"tag": "latest",
"severity_filter": ["critical", "high"],
"include_cve_details": true,
"security_policy": {
"max_age_days": 180,
"min_severity_threshold": "medium"
},
"export_format": "sarif"
}
}
Data Export
{
"tool": "docker_export_data",
"arguments": {
"repository": "library/node",
"tag": "18-alpine",
"export_type": "dependency-tree",
"format": "tree-string"
}
}
See EXAMPLES.md for more comprehensive usage examples and workflows.
šļø Development
Project Structure
src/
āāā auth/ # Authentication management
āāā cache/ # Caching infrastructure
āāā clients/ # Docker Hub API client
āāā tools/ # MCP tool implementations
āāā utils/ # Utilities (error handling, rate limiting)
āāā types.ts # TypeScript type definitions
āāā config.ts # Configuration management
āāā server.ts # MCP server implementation
āāā index.ts # Entry point
Development Commands
# Development with hot reload
npm run dev
# Build the project
npm run build
# Run tests
npm test
# Run with coverage
npm run test:coverage
# Lint code
npm run lint
# Fix linting issues
npm run lint:fix
Testing
The project includes comprehensive testing:
- Unit Tests: Individual function and class testing
- Integration Tests: Full API workflow testing
- Mock Tests: Testing with simulated Docker Hub responses
# Run all tests
npm test
# Run with coverage report
npm run test:coverage
# Run specific test file
npm test -- tools/search-images.test.ts
š Integration with MCP Clients
Claude Desktop
Add to your Claude Desktop configuration:
{
"mcpServers": {
"dockerhub": {
"command": "node",
"args": ["/path/to/dockerhub-mcp-server/dist/index.js"],
"env": {
"DOCKERHUB_USERNAME": "your_username"
}
}
}
}
Cursor
The server is compatible with Cursor's MCP integration. See the integration guide for setup instructions.
Cline
Works seamlessly with Cline's MCP support. Refer to Cline's documentation for MCP server configuration.
HTTP Transport (Web Access)
When using HTTP transport mode, the server provides web endpoints:
# Set HTTP transport in .env
MCP_TRANSPORT=http
MCP_HTTP_PORT=3000
# Start server
npm start
# Access endpoints
curl http://localhost:3000/health # Health check
curl http://localhost:3000/info # Server information
# MCP endpoint: http://localhost:3000/message
š³ Docker Support
Using Docker Compose
A docker-compose.yml is provided for easy testing with a local registry:
# Start local registry and server
docker-compose up
# Test with local registry
curl -X POST http://localhost:3000/api/search -d '{"query": "nginx"}'
Building Docker Image
# Build the image
docker build -t dockerhub-mcp-server .
# Run the container
docker run -d \
--name dockerhub-mcp \
-e DOCKERHUB_USERNAME=your_username \
-e DOCKERHUB_PASSWORD=your_password \
dockerhub-mcp-server
šØ Troubleshooting
Common Issues
Authentication Failures
- Verify credentials in
.envfile - Check if 2FA is enabled (use access token instead)
- Ensure proper permissions for private repositories
Rate Limiting
- Default limits: 100 requests per hour
- Authenticated users get higher limits
- Implement exponential backoff for retries
Network Issues
- Check firewall settings
- Verify DNS resolution for
registry-1.docker.io - Consider proxy configuration if behind corporate firewall
See TROUBLESHOOTING.md for comprehensive troubleshooting guide.
š Performance & Optimization
Caching Strategy
- Image Metadata: Cached for 10 minutes
- Search Results: Cached for 5 minutes
- Layer Information: Cached for 30 minutes
- Vulnerability Scans: Cached for 1 hour
Rate Limiting
- Automatic rate limit detection from Docker Hub headers
- Intelligent backoff when limits are approached
- Queue management for high-volume requests
Memory Management
- LRU cache with configurable size limits
- Automatic cleanup of expired entries
- Memory usage monitoring and alerts
š¤ Contributing
We welcome contributions! Please see our Contributing Guidelines for details.
Development Setup
- Fork the repository
- Create a feature branch
- Make your changes with tests
- Ensure all tests pass
- Submit a pull request
Code Standards
- TypeScript strict mode
- ESLint configuration provided
- 100% test coverage for new features
- Comprehensive documentation
š License
This project is licensed under the MIT License - see the LICENSE file for details.
š Acknowledgments
- Model Context Protocol for the MCP specification
- Docker Hub API for the comprehensive API
- TypeScript and Node.js communities for excellent tooling
š Support
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Documentation: Wiki
Built with ā¤ļø for the Docker and AI communities
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
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.