Claude Code MCP 完全指南
什么是 Claude Code MCP?
Claude Code 是 Anthropic 官方推出的 AI 命令行工具,而 MCP(Model Context Protocol) 则是让 Claude Code 能够连接外部工具和服务的协议。
简单来说,MCP 让 Claude Code 从一个「只能读写本地文件」的 AI 助手,变成一个「能访问 GitHub、数据库、API、云服务」的超级助手!
为什么需要在 Claude Code 中使用 MCP?
没有 MCP 的 Claude Code
你能做的:
✓ 读取本地文件
✓ 编辑代码
✓ 运行命令
✓ 使用 Bash 工具
你不能做的:
✗ 查看你的 GitHub Issues
✗ 访问云数据库
✗ 调用外部 API
✗ 获取实时天气有了 MCP 的 Claude Code
你能做的:
✓ 所有原来的功能
✓ 查看/创建 GitHub Issues 和 PR
✓ 查询 SQLite、PostgreSQL 数据库
✓ 访问 Notion、Slack 等外部服务
✓ 获取实时天气、地图数据
✓ 浏览器自动化
✓ ...以及更多!快速开始
步骤 1:了解配置文件位置
Claude Code 的 MCP 配置文件位于:
| 级别 | 配置文件路径 | 作用范围 |
|---|---|---|
| 用户级 | ~/.claude.json | 所有项目 |
| 项目级 | .claude/mcp.json | 当前项目 |
推荐优先使用项目级配置,让不同项目使用不同的 MCP 服务。
步骤 2:用自然语言添加 MCP 服务器
在 Claude Code 中,你不需要手动编辑配置文件或记忆命令,直接用自然语言描述即可:
你:帮我添加 GitHub MCP 服务器,我的 token 是 ghp_xxx
Claude:我来帮你配置 GitHub MCP 服务器...
[自动更新 .claude/mcp.json]你:添加一个 SQLite 数据库服务器,数据库文件在 ./data/app.db
Claude:好的,我来配置 SQLite MCP 服务器...你:添加一个 HTTP 类型的 MCP 服务器,地址是 https://api.example.com/mcp
Claude:我来添加这个远程 MCP 服务器...步骤 3:验证配置
直接询问 Claude Code:
你:现在有哪些可用的 MCP 服务器?
Claude:当前已配置的 MCP 服务器:
• github - GitHub 集成
• sqlite - SQLite 数据库
• filesystem - 文件系统访问或使用诊断命令:
/doctor步骤 4:开始使用
配置成功后,直接用自然语言调用 MCP 功能:
你:帮我在 GitHub 上创建一个 Issue
Claude:我可以帮你创建 GitHub Issue。请告诉我:
- 仓库地址(如 owner/repo)
- Issue 标题
- Issue 描述Claude Code 的自然语言管理
查看和管理 MCP 服务器
你可以完全用自然语言与 Claude Code 交互:
你:列出所有已配置的 MCP 服务器
你:检查一下 MCP 服务器的连接状态
你:删除 notion 这个 MCP 服务器
你:更新 github 服务器的 token诊断问题
当遇到问题时:
你:检查一下 MCP 连接有什么问题
Claude:[会自动运行诊断,分析配置文件,检查服务器状态]配置方式详解
用户级配置(全局)
编辑 ~/.claude.json:
{
"mcpServers": {
"filesystem": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/Users/yourname/Documents"]
},
"github": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-github"],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "your-token"
}
}
}
}项目级配置(推荐)
编辑项目根目录的 .claude/mcp.json:
{
"mcpServers": {
"project-db": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-sqlite", "--db-path", "./data/app.db"]
}
}
}项目级配置优势:
- 团队成员可以共享配置(提交到 Git)
- 不同项目使用不同的 MCP 服务
- 配置更灵活,不会污染全局设置
传输方式配置
Claude Code 支持三种传输方式:
STDIO(本地进程)
{
"mcpServers": {
"local-tool": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/path"]
}
}
}HTTP(远程服务)
{
"mcpServers": {
"remote-api": {
"url": "https://api.example.com/mcp",
"transport": "http",
"headers": {
"Authorization": "Bearer your-token"
}
}
}
}SSE(服务器推送)
{
"mcpServers": {
"streaming": {
"url": "https://api.example.com/sse",
"transport": "sse"
}
}
}实战示例
示例 1:GitHub 工作流自动化
你:帮我把当前的修改推送到 GitHub,然后创建一个 PR,标题是"添加新功能"
Claude:
1. 检查当前 git 状态...
2. 创建新分支 feature/new-feature...
3. 提交更改...
4. 推送到远程...
5. 调用 github_create_pull_request 创建 PR...
6. PR 已创建:https://github.com/owner/repo/pull/123示例 2:数据库查询
你:查询数据库中最近注册的 10 个用户
Claude:
1. 连接到 SQLite 数据库...
2. 执行查询:SELECT * FROM users ORDER BY created_at DESC LIMIT 10
3. 返回结果:
- 张三 (zhang@example.com) - 2025-02-28
- 李四 (li@example.com) - 2025-02-27
...示例 3:网页截图分析
你:打开 https://example.com 并截图,分析一下页面设计
Claude:
1. 启动浏览器...
2. 导航到 https://example.com...
3. 截取屏幕...
4. [返回截图]
5. 页面设计分析:
- 布局采用居中设计,最大宽度 1200px
- 主色调为蓝色 (#3b82f6)
- 导航栏固定在顶部
...示例 4:与 Notion 集成
你:把我刚才的笔记保存到 Notion
Claude:
1. 使用 Notion MCP 服务器...
2. 创建新页面...
3. 已保存:https://notion.so/page/xxx调试技巧
使用自然语言诊断
遇到问题时,直接告诉 Claude Code:
你:我的 MCP 服务器连接不上了,帮我检查一下
你:GitHub MCP 工具调用失败,是什么原因?
你:为什么 sqlite 服务器一直显示连接中?Claude Code 会自动:
- 检查配置文件格式
- 验证环境变量
- 测试服务器连接
- 提供具体的修复建议
常见问题排查
| 问题 | 可能原因 | 解决方案 |
|---|---|---|
| 服务器未连接 | 配置文件格式错误 | 检查 JSON 语法 |
| 工具无法调用 | 权限不足 | 检查环境变量 |
| 连接超时 | 网络问题 | 检查 URL 或网络 |
| 进程崩溃 | 服务器代码错误 | 查看服务器日志 |
手动诊断命令
/doctor输出示例:
系统诊断报告:
===============
Claude Code: v2.5.0 ✓
Node.js: v20.0.0 ✓
MCP 服务器状态:
• github: ✓ 已连接 (12 tools)
• sqlite: ✗ 连接失败 - Database file not found
• puppeteer: ✓ 已连接 (8 tools)
建议:
1. 检查 sqlite 数据库路径是否正确
2. 确保 .claude/mcp.json 格式正确最佳实践
1. 项目级配置优先
为什么推荐项目级配置?
不同的项目往往需要不同的 MCP 服务。例如,前端项目可能需要浏览器测试工具,而后端项目则需要数据库连接。使用项目级配置可以让每个项目拥有自己专属的 MCP 服务器集合,避免全局配置的混乱。
更重要的是,项目级配置可以提交到 Git 仓库,团队成员克隆项目后就能直接使用相同的 MCP 服务,无需重复配置。
项目 A(前端项目)→ .claude/mcp.json 包含浏览器测试 MCP
项目 B(后端项目)→ .claude/mcp.json 包含数据库 MCP2. 敏感信息环境变量化
永远不要在配置文件中硬编码密钥!
配置文件可能会被意外提交到 Git 仓库,导致密钥泄露。正确的做法是将敏感信息存储在环境变量中,配置文件只引用变量名。这样即使配置文件被公开,也不会暴露实际的密钥。
{
"env": {
"GITHUB_TOKEN": "$GITHUB_TOKEN", // ✓ 好 - 从环境变量读取
"GITHUB_TOKEN": "ghp_abc123" // ✗ 不好 - 硬编码密钥
}
}3. 版本锁定
为什么需要锁定版本?
默认情况下,npx -y 会总是使用最新版本的 MCP 服务器。这可能导致问题:新版本可能引入不兼容的更改,或者某个服务器突然被下架/改名。
通过在包名后添加 @版本号,可以确保始终使用经过验证的特定版本,避免因自动更新导致的意外问题。
{
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-github@1.2.3"] // 固定版本
}4. 文档化你的 MCP 配置
让团队成员快速理解 MCP 配置
当项目中有多个 MCP 服务器时,新成员可能不清楚每个服务器的用途和配置要求。在 .claude/ 目录下创建一个 README.md 文件,说明每个服务器的用途、所需的配置项以及获取方式,可以大大降低团队的沟通成本。
在项目中创建 .claude/README.md:
在项目中创建 .claude/README.md:
# MCP 配置说明
本项目使用的 MCP 服务器:
## github
用于自动化 GitHub 操作,需要配置 GITHUB_TOKEN。
## sqlite
连接到 ./data/app.db,用于查询和修改数据。
## puppeteer
用于 E2E 测试。Claude Code vs Claude Desktop
| 特性 | Claude Code | Claude Desktop |
|---|---|---|
| 配置文件 | ~/.claude.json 或 .claude/mcp.json | claude_desktop_config.json |
| 项目级配置 | ✓ 支持 | ✗ 不支持 |
| 自然语言管理 | ✓ 支持 | ✗ 需手动编辑 |
| 诊断工具 | ✓ /doctor | ✗ 无 |
| 热重载 | ✓ 自动重载 | ✗ 需重启应用 |
| 适用场景 | 开发工作流、CI/CD | 日常使用、办公 |
常用 MCP 服务器
💡 完整的 MCP 服务器列表请参考附录 MCP 服务器大全
GitHub 服务器
功能: Issues、PR、仓库管理
{
"mcpServers": {
"github": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-github"],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "your-token"
}
}
}
}获取 Token: https://github.com/settings/tokens
SQLite 服务器
功能: 查询和管理 SQLite 数据库
{
"mcpServers": {
"sqlite": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-sqlite", "--db-path", "./data/database.db"]
}
}
}文件系统服务器
功能: 访问指定目录的文件
{
"mcpServers": {
"filesystem": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/Users/yourname/Documents"]
}
}
}Puppeteer 浏览器自动化
功能: 浏览器控制、截图、自动化测试
{
"mcpServers": {
"puppeteer": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-puppeteer"]
}
}
}Brave 搜索服务器
功能: 网络搜索
{
"mcpServers": {
"brave-search": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-brave-search"],
"env": {
"BRAVE_API_KEY": "your-brave-api-key"
}
}
}
}参考资源
官方文档
官方服务器
- @modelcontextprotocol/server-github - GitHub 集成
- @modelcontextprotocol/server-sqlite - SQLite 数据库
- @modelcontextprotocol/server-postgres - PostgreSQL 数据库
- @modelcontextprotocol/server-filesystem - 文件系统访问
- @modelcontextprotocol/server-puppeteer - 浏览器自动化
- @modelcontextprotocol/server-fetch - 网页抓取
- @modelcontextprotocol/server-brave-search - Brave 搜索
- @modelcontextprotocol/server-git - Git 操作
教程文章
- 一文讲透 MCP 的原理及实践
- MCP(Model Context Protocol)架构与工作原理
- 2025 大模型最新教程:MCP 协议从入门到精通
- 从零开始学 MCP(八)- 构建一个 MCP server
配置指南
开发教程
- 零基础构建 MCP 服务器 TypeScript/Python 双语言实战指南
- 终极 MCP 服务器构建指南:TypeScript 与 Python 双版本完整教程
- 使用 TypeScript 构建一个最简单的 MCP 服务器
- 使用 Azure 容器应用生成 TypeScript MCP 服务器
MCP 服务器资源
- Awesome MCP Servers - 最全面的 MCP 服务器列表
- Official MCP Registry - Anthropic 官方「应用商店」
- MCP.so - 社区 MCP 服务器中心
- Glama.ai MCP - 带评分评论的 MCP 目录
- Smithery - MCP 服务器市场
- MCPHub - 界面简洁的目录
- LobeHub MCP - 中文 MCP 目录
地图和天气服务
社区资源
- Everything Claude Code Config - 生产级 Claude Code 配置集合
- AI Coding Guide - Claude Code 中文学习路径
实际应用案例
- BlenderMCP - AI 驱动的 3D 建模 - 4,100+ ⭐
- MCP 生产环境 15 条最佳实践
