MCP生产部署实战:从开发到上线的完整指南

1. 客户端配置详解

1.1 mcp.json 标准格式

json 复制代码
{
  "version": "1.0",
  "mcpServers": {
    "my_ai_tools": {
      "command": "python",
      "args": ["/path/to/server.py"],
      "env": {
        "OPENAI_API_KEY": "sk-xxx",
        "DB_URL": "mysql://user:pass@localhost/db"
      },
      "description": "AI工具集(数据库/天气API)"
    }
  }
}

关键字段说明

  • command:启动命令(如pythonuvicorn等)
  • args:命令行参数(支持相对路径)
  • env:环境变量(敏感信息建议通过外部注入)
  • description:客户端展示的服务描述

1.2 配置位置

  • 全局配置~/.config/mcp/config.json
  • 项目级配置./.mcp/mcp.json
  • IDE特定配置 :如Cursor会在工作区查找.vscode/mcp.json

1.3 环境变量管理

bash 复制代码
# 推荐使用.env文件(需配合python-dotenv)
echo "DB_PASSWORD=123456" > .env

然后在代码中加载:

python 复制代码
from dotenv import load_dotenv
load_dotenv()

2. 部署模式对比

2.1 STDIO模式(开发环境首选)

json 复制代码
{
  "command": "python",
  "args": ["server.py"]
}
  • 优点
    • 零延迟通信
    • 调试方便(日志直接输出)
  • 限制
    • 必须与客户端同机部署
    • 无跨进程隔离

2.2 SSE模式(生产环境必选)

json 复制代码
{
  "command": "uvicorn",
  "args": ["server:app", "--port", "8000"]
}

需要FastAPI封装:

python 复制代码
# server.py
from fastapi import FastAPI
from fastmcp import FastMCP

app = FastAPI()
mcp = FastMCP("ProductionTools")

@app.post("/mcp")
async def handle_mcp():
    return await mcp.handle_request()

# 注册工具...

3. 生产环境部署实战

3.1 使用Gunicorn+Uvicorn

bash 复制代码
gunicorn -w 4 -k uvicorn.workers.UvicornWorker server:app

对应mcp.json

json 复制代码
{
  "command": "curl",
  "args": ["http://localhost:8000/mcp"]
}

3.2 容器化部署(Docker)

dockerfile 复制代码
FROM python:3.10
WORKDIR /app
COPY . .
RUN pip install -r requirements.txt
CMD ["gunicorn", "-w", "4", "-k", "uvicorn.workers.UvicornWorker", "server:app"]

3.3 健康检查配置

python 复制代码
@app.get("/health")
def health_check():
    return {"status": "ok"}

4. 安全加固方案

4.1 认证鉴权

python 复制代码
from fastapi.security import HTTPBearer
security = HTTPBearer()

@app.post("/mcp")
async def handle_mcp(token: str = Depends(security)):
    if token != os.getenv("API_TOKEN"):
        raise HTTPException(status_code=403)
    return await mcp.handle_request()

4.2 限流保护

python 复制代码
from fastapi.middleware import Middleware
from slowapi import Limiter
from slowapi.util import get_remote_address

limiter = Limiter(key_func=get_remote_address)
app.state.limiter = limiter

@app.post("/mcp")
@limiter.limit("10/minute")
async def handle_mcp():
    return await mcp.handle_request()

5. 监控与日志

5.1 Prometheus监控

python 复制代码
from prometheus_fastapi_instrumentator import Instrumentator
Instrumentator().instrument(app).expose(app)

5.2 结构化日志

python 复制代码
import logging
import json_logging

json_logging.init_fastapi(enable_json=True)
logger = logging.getLogger("mcp-server")

附录:部署检查清单

  1. 测试STDIO和SSE两种模式
  2. 配置环境变量加密方案
  3. 设置健康检查端点
  4. 实现基础认证鉴权
  5. 配置日志和监控系统
  6. 压力测试(推荐使用locust)
相关推荐
-星空下无敌18 小时前
Skills详解(2万字详细教程),Skills是什么,如何安装并使用Skills
人工智能·ai·提示词·codex·mcp·skills·agent skills
chenjim1 天前
你的 Agent 是个黑箱:eBPF 如何看见它真正在做什么
llm·agent
Lkstar1 天前
万字长文Query改写与多路召回实战|从HyDE到RRF融合,召回率提升22%的完整方案
数据库·人工智能·llm
老H科研技术1 天前
第 07 篇:OAuth 2.1 与授权架构 —— AS/RS 分离的正确姿势
人工智能·mcp
海天一色y1 天前
深入理解 Function Calling、MCP 与 Skills:AI Agent 的三层能力架构
人工智能·mcp·skills
AI语宙漫游指南1 天前
从 CV 扩散到 NLP:详解 Google DiffusionGemma 架构、推理机制与优劣
深度学习·llm
程序员cxuan1 天前
瑞幸出 CLI 了,这会是迈向 AGI 的第一步吗?
ai·llm·agi
智泊AI1 天前
为什么现在大家都在扎堆转 Agent 流程架构师?
llm
去伪存真2 天前
如何将没有字幕的英文视频转换成中文视频?
前端·pytorch·llm
qcx232 天前
【AI Daily 2026-06-05】 AI 方向的基础设施化,能力从模型层下沉到工具链和工作流
人工智能·ai·llm·agent·agi