Supports containerized deployment and management of the MCP server itself using Docker and Docker Compose for scalable container orchestration.
Provides comprehensive Kubernetes cluster management capabilities including Pod, Service, Deployment operations, resource lifecycle management, container log retrieval, and complete Kubernetes API access through natural language interactions.
MCP Remote Server for Kubernetes
🚀 通用远程 MCP 服务器 - 基于 MCP (Model Context Protocol) 协议的 Kubernetes 管理服务器,支持通过 HTTP/SSE 协议远程访问,为各种 AI 平台和应用程序提供 Kubernetes 集群的自然语言管理能力。
🌟 核心优势
🔌 通用兼容性: 支持所有遵循 MCP 协议的客户端(Dify、Claude Desktop、自定义客户端等)
🌐 远程访问: 通过 HTTP/SSE 协议提供远程 MCP 服务,无需本地部署
🔒 企业级安全: JWT 认证、RBAC 权限控制、速率限制等安全机制
☸️ 完整 K8s 支持: 涵盖 Pod、Service、Deployment 等资源的完整生命周期管理
📊 生产就绪: 健康检查、结构化日志、错误处理、监控告警等企业特性
🚀 主要特性
MCP 协议支持
标准协议: 完整实现 MCP 2024-11-05 协议规范
多传输方式: 支持 HTTP POST 和 SSE (Server-Sent Events)
实时通信: 支持双向通信和事件推送
Kubernetes 集成
API 代理: 通过代理模式提供完整的 Kubernetes API 访问
资源管理: 支持 Pod、Service、Deployment、ConfigMap 等资源操作
日志查看: 实时获取容器日志
多集群: 支持集群内和集群外两种部署模式
安全和认证
JWT 认证: 基于 JSON Web Token 的安全认证
RBAC 权限: 细粒度的角色权限控制
速率限制: 防止 API 滥用和 DDoS 攻击
安全传输: 支持 HTTPS 和安全头部配置
多平台支持
🤖 Dify: 完整的 Dify 平台集成支持
💬 Claude Desktop: 原生 MCP 客户端支持
🔧 自定义客户端: 提供多语言 SDK 和示例
🌐 Web 应用: 支持浏览器直接访问
📋 系统要求
Node.js >= 18.0.0
Kubernetes 集群访问权限
Docker (可选,用于容器化部署)
🛠️ 安装和配置
1. 克隆项目
2. 安装依赖
3. 配置环境变量
复制环境变量模板并根据需要修改:
主要配置项:
4. 构建项目
5. 启动服务
🐳 Docker 部署
使用 Docker Compose
手动 Docker 部署
☸️ Kubernetes 部署
🔌 多平台集成
支持的客户端平台
平台 | 状态 | 集成方式 | 文档链接 |
🤖 Dify | ✅ 完全支持 | HTTP MCP | |
💬 Claude Desktop | ✅ 完全支持 | 标准 MCP | |
🔧 自定义客户端 | ✅ 完全支持 | HTTP/SSE API | |
🌐 Web 应用 | ✅ 完全支持 | REST API |
快速集成示例
1. Dify 平台集成
在 Dify 中配置 MCP 服务器:
自然语言使用示例:
"显示默认命名空间中的所有 Pod"
"部署一个 nginx 应用,使用 3 个副本"
"获取 nginx Pod 的最近 100 行日志"
"删除名为 test-pod 的 Pod"
2. Claude Desktop 集成
创建 MCP 客户端代理脚本 mcp-client-proxy.js
:
然后在 Claude Desktop 配置中:
3. 自定义客户端集成
📡 API 接口
支持的 MCP 方法
方法 | 描述 | 参数 |
| 初始化连接 | 协议版本、客户端信息 |
| 获取工具列表 | 无 |
| 调用工具 | 工具名称、参数 |
| 获取资源列表 | 无 |
| 获取提示列表 | 无 |
可用工具
工具名称 | 功能描述 | 必需参数 | 可选参数 |
| 获取 K8s 资源 |
|
,
|
| 应用配置 |
|
|
| 删除资源 |
,
|
|
| 获取日志 |
|
,
,
|
API 端点
认证:
POST /auth/login
MCP 协议:
POST /mcp
SSE 实时:
GET /mcp/sse
健康检查:
GET /health
📡 API 使用
认证
首先获取访问令牌:
MCP 协议调用
使用获取的令牌调用 MCP 接口:
支持的工具
kubectl_get
: 获取 Kubernetes 资源kubectl_apply
: 应用资源配置kubectl_delete
: 删除资源kubectl_logs
: 获取 Pod 日志
示例:获取 Pods
示例:应用部署
🔧 开发
项目结构
开发命令
🔒 安全考虑
更改默认密钥: 生产环境中务必更改
JWT_SECRET
RBAC 权限: 根据需要调整 Kubernetes RBAC 权限
网络安全: 使用 HTTPS 和适当的网络策略
速率限制: 根据需要调整请求频率限制
日志审计: 启用详细的访问日志记录
📊 监控和日志
健康检查
日志配置
支持多种日志级别和输出格式:
LOG_LEVEL
: error, warn, info, debug, verboseLOG_FORMAT
: combined, json, simpleLOG_FILE
: 日志文件路径(可选)LOG_CONSOLE
: 控制台输出开关
🤝 贡献
Fork 项目
创建特性分支 (
git checkout -b feature/AmazingFeature
)提交更改 (
git commit -m 'Add some AmazingFeature'
)推送到分支 (
git push origin feature/AmazingFeature
)打开 Pull Request
📄 许可证
本项目采用 MIT 许可证 - 查看 LICENSE 文件了解详情。
🆘 故障排除
常见问题
Kubernetes 连接失败
检查
KUBECONFIG
路径是否正确验证集群访问权限
确认网络连接
认证失败
检查 JWT 密钥配置
验证令牌是否过期
确认用户权限
端口冲突
修改
PORT
环境变量检查端口是否被占用
调试模式
启用详细日志:
📞 支持
如有问题或建议,请:
查看 Issues 页面
创建新的 Issue
联系维护者
注意: 这是一个开发版本,请在生产环境使用前进行充分测试。
This server cannot be installed
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Provides Kubernetes cluster management capabilities through natural language via MCP protocol over HTTP/SSE. Supports Pod, Service, Deployment operations, log retrieval, and resource management with JWT authentication and RBAC permissions.