Skip to content

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

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

json
{
  "mcpServers": {
    "project-db": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-sqlite", "--db-path", "./data/app.db"]
    }
  }
}

项目级配置优势:

  • 团队成员可以共享配置(提交到 Git)
  • 不同项目使用不同的 MCP 服务
  • 配置更灵活,不会污染全局设置

传输方式配置

Claude Code 支持三种传输方式:

STDIO(本地进程)

json
{
  "mcpServers": {
    "local-tool": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-filesystem", "/path"]
    }
  }
}

HTTP(远程服务)

json
{
  "mcpServers": {
    "remote-api": {
      "url": "https://api.example.com/mcp",
      "transport": "http",
      "headers": {
        "Authorization": "Bearer your-token"
      }
    }
  }
}

SSE(服务器推送)

json
{
  "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 会自动:

  1. 检查配置文件格式
  2. 验证环境变量
  3. 测试服务器连接
  4. 提供具体的修复建议

常见问题排查

问题可能原因解决方案
服务器未连接配置文件格式错误检查 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 包含数据库 MCP

2. 敏感信息环境变量化

永远不要在配置文件中硬编码密钥!

配置文件可能会被意外提交到 Git 仓库,导致密钥泄露。正确的做法是将敏感信息存储在环境变量中,配置文件只引用变量名。这样即使配置文件被公开,也不会暴露实际的密钥。

json
{
  "env": {
    "GITHUB_TOKEN": "$GITHUB_TOKEN",  // ✓ 好 - 从环境变量读取
    "GITHUB_TOKEN": "ghp_abc123"       // ✗ 不好 - 硬编码密钥
  }
}

3. 版本锁定

为什么需要锁定版本?

默认情况下,npx -y 会总是使用最新版本的 MCP 服务器。这可能导致问题:新版本可能引入不兼容的更改,或者某个服务器突然被下架/改名。

通过在包名后添加 @版本号,可以确保始终使用经过验证的特定版本,避免因自动更新导致的意外问题。

json
{
  "command": "npx",
  "args": ["-y", "@modelcontextprotocol/server-github@1.2.3"]  // 固定版本
}

4. 文档化你的 MCP 配置

让团队成员快速理解 MCP 配置

当项目中有多个 MCP 服务器时,新成员可能不清楚每个服务器的用途和配置要求。在 .claude/ 目录下创建一个 README.md 文件,说明每个服务器的用途、所需的配置项以及获取方式,可以大大降低团队的沟通成本。

在项目中创建 .claude/README.md

在项目中创建 .claude/README.md

markdown
# MCP 配置说明

本项目使用的 MCP 服务器:

## github
用于自动化 GitHub 操作,需要配置 GITHUB_TOKEN。

## sqlite
连接到 ./data/app.db,用于查询和修改数据。

## puppeteer
用于 E2E 测试。

Claude Code vs Claude Desktop

特性Claude CodeClaude Desktop
配置文件~/.claude.json.claude/mcp.jsonclaude_desktop_config.json
项目级配置✓ 支持✗ 不支持
自然语言管理✓ 支持✗ 需手动编辑
诊断工具/doctor✗ 无
热重载✓ 自动重载✗ 需重启应用
适用场景开发工作流、CI/CD日常使用、办公

常用 MCP 服务器

💡 完整的 MCP 服务器列表请参考附录 MCP 服务器大全

GitHub 服务器

功能: Issues、PR、仓库管理

json
{
  "mcpServers": {
    "github": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-github"],
      "env": {
        "GITHUB_PERSONAL_ACCESS_TOKEN": "your-token"
      }
    }
  }
}

获取 Token: https://github.com/settings/tokens

SQLite 服务器

功能: 查询和管理 SQLite 数据库

json
{
  "mcpServers": {
    "sqlite": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-sqlite", "--db-path", "./data/database.db"]
    }
  }
}

文件系统服务器

功能: 访问指定目录的文件

json
{
  "mcpServers": {
    "filesystem": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-filesystem", "/Users/yourname/Documents"]
    }
  }
}

Puppeteer 浏览器自动化

功能: 浏览器控制、截图、自动化测试

json
{
  "mcpServers": {
    "puppeteer": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-puppeteer"]
    }
  }
}

Brave 搜索服务器

功能: 网络搜索

json
{
  "mcpServers": {
    "brave-search": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-brave-search"],
      "env": {
        "BRAVE_API_KEY": "your-brave-api-key"
      }
    }
  }
}

参考资源

官方文档

官方服务器

教程文章

配置指南

开发教程

MCP 服务器资源

地图和天气服务

社区资源

实际应用案例