海艄公 發表於 2025-4-30 09:09:00

从零开始开发一个 MCP Server!保姆级教程!

<p>大家好,我是R哥。</p>
<p>之前分享了一篇 MCP 的介绍及使用:</p>
<blockquote>
<p>最近热火朝天的 MCP 是什么鬼?如何使用MCP?一文给你讲清楚!</p>
</blockquote>
<p>这篇文章得到了大家的广泛阅读,让大家对 MCP 的概念和使用也有了一个基础的认知,也介绍了如何使用 MCP Server,这篇再来介绍下如何从 0 开发一个自己的 MCP Server。</p>
<p>MCP 本质上是为 AI 大模型提供<strong>调用外部工具</strong>的能力,MCP Server 就是这个能力的具体实现——你可以通过它,把你已有的 <strong>API、脚本、服务</strong>包装成 AI 能理解和调用的 MCP 工具。</p>
<p>这篇我们就以<strong>获取图片</strong>为例来创建一个 MCP Server,让 AI 根据<strong>自然语言</strong>来获取图片网站上的图片,比如 <strong>Pixabay</strong> 图片网站,它就提供了 API 可以让外界来搜索图片。</p>
<p>PixabayAPI 文档:</p>
<blockquote>
<p>https://pixabay.com/api/docs/</p>
</blockquote>
<p>MCP 官方提供了 Python、Node、Java、Kotlin 等 SDK 接入,我们为了方便测试使用,本文以 Node 为例进行演示,请确保你安装了最新版本的 Node。</p>
<h2 id="安装-node-环境">安装 Node 环境</h2>
<p>如果你还没有安装 Node.js 和 npm,你可以从 nodejs.org 下载并安装,然后验证 Node.js 是否正确安装:</p>
<blockquote>
<p>node --version</p>
<p>npm --version</p>
</blockquote>
<p>安装过程,略。</p>
<h2 id="创建-mcp-server-项目">创建 MCP Server 项目</h2>
<p><strong>创建一个 MCP Server 项目:</strong></p>
<blockquote>
<p>mkdir pixabay</p>
<p>cd pixabay</p>
</blockquote>
<p><strong>初始化一个新的 npm 项目:</strong></p>
<blockquote>
<p>npm init -y</p>
</blockquote>
<p><strong>安装相关依赖:</strong></p>
<blockquote>
<p>npm install @modelcontextprotocol/sdk zod</p>
<p>npm install -D @types/node typescript</p>
</blockquote>
<p><strong>创建主要目录和文件:</strong></p>
<blockquote>
<p>mkdir src</p>
<p>touch src/index.ts</p>
</blockquote>
<p>更新 <strong>package.json</strong> 文件,添加以下主要配置项:</p>
<pre><code class="language-json">{
"type": "module",
"bin": {
    "pixabay": "./build/index.js"
},
"scripts": {
    "build": "tsc &amp;&amp; chmod 755 build/index.js"
},
"files": [
    "build"
],
}
</code></pre>
<p>在根目录创建 <strong>tsconfig.json</strong> 文件,内容如下:</p>
<pre><code class="language-json">{
"compilerOptions": {
    "target": "ES2022",
    "module": "Node16",
    "moduleResolution": "Node16",
    "outDir": "./build",
    "rootDir": "./src",
    "strict": true,
    "esModuleInterop": true,
    "skipLibCheck": true,
    "forceConsistentCasingInFileNames": true
},
"include": ["src/**/*"],
"exclude": ["node_modules"]
}
</code></pre>
<p>到此,项目初始化完成,现在让我们开始构建一个图片搜索的 MCP 服务器吧。</p>
<h2 id="构建-mcp-server">构建 MCP Server</h2>
<p>在项目 <code>index.ts</code> 文件中添加 MCP Server:</p>
<pre><code class="language-typescript">// MCP - NODE SDK
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";

// 导入 StdioServerTransport 类,用于处理服务器的输入输出通信
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";

// 导入用于验证输入参数的库
import { z } from "zod";

// Pixabay API URL
const baseUrl = "https://pixabay.com/api/";

/**
* 定义了 MCP Server 实例。
*/
const server = new McpServer({
    name: "pixabay",
    version: "1.0.0",
    capabilities: {
      resources: {},
      tools: {},
    },
});

/**
* 定义了一个名为 "pixabay-image-search" 的工具。
* 该工具接受一个查询字符串和一个图像类型作为输入参数,
* 并返回一个包含图像信息的 JSON 字符串。
*/
server.tool(
    'pixabay-image-search',
    {
      query: z.string(),
      type: z.string()
    },
    async ({ query, type = 'all' }) =&gt; {
      try {
            // 检查是否设置了 PIXABAY_KEY 环境变量
            if (!process.env.PIXABAY_KEY) {
                console.error("PIXABAY_KEY environment variable is not set");
                process.exit(1);
            }
            console.log("PIXABAY_KEY", process.env.PIXABAY_KEY);

            // 构建 Pixabay API 请求 URL
            const requestUrl = `${baseUrl}?key=${process.env.PIXABAY_KEY}&amp;q=${query}&amp;image_type=${type}&amp;per_page=3`;

            // 发送请求并获取响应
            const response = await fetch(requestUrl);

            //检查响应状态
            const json = await response.json();

            // 返回响应结果
            return {
                content: [{
                  type: 'text',
                  text: JSON.stringify({
                        images: json.hits || [],
                        total_results: json.total,
                        query,
                  }, null, 2)
                }]
            }
      } catch (e) {
            return {
                content: [{
                  type: 'text',
                  text: `Error: ${e instanceof Error ? e.message : 'Unknown error'}`
                }],
                isError: true
            };
      }
    }
)

/**
* 启动服务器并建立与传输层的连接。
* 该函数创建一个标准输入输出的服务器传输实例,
* 并使用该实例将服务器连接到传输层。
*/
async function startServer() {
    // 创建一个标准输入输出的服务器传输实例,用于处理服务器的输入输出通信
    const transport = new StdioServerTransport();

    // 等待服务器通过指定的传输实例建立连接
    await server.connect(transport);
}

// 启动服务器
startServer();
</code></pre>
<p>这里主要定义了一个 McpServer,然后添加了一个名为 <code>pixabay-image-search</code> 的 MCP Tool 工具,用来从 Pixabay 根据关键字和类型搜索图片。</p>
<p>最后使用以下命令进行构建:</p>
<blockquote>
<p>npm run build</p>
</blockquote>
<p>根据之前的项目定义,最终会在 build 目录中构建为 index.js 文件。</p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090903163-2125713929.png"></p>
<h2 id="调试-mcp-server">调试 MCP Server</h2>
<p>官方提供了一个 <strong>Inspector</strong> 调试工具,它是一款用于测试和调试 MCP 服务器的交互式开发者工具,详细介绍和使用方法如下:</p>
<blockquote>
<p>https://modelcontextprotocol.io/docs/tools/inspector</p>
</blockquote>
<p>启动调试参考命令:</p>
<blockquote>
<p>sudo npx @modelcontextprotocol/inspector node build/index.js</p>
</blockquote>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090903766-1657649213.png"></p>
<p>启动成功后,访问以下地址:</p>
<blockquote>
<p>http://127.0.0.1:6274/</p>
</blockquote>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090904899-1993465440.png"></p>
<p>这个界面主要分为三个区域:</p>
<ul>
<li>左侧进行环境变量配置、MCP Server 连接/重启等操作;</li>
<li>中间选择要调试的 MCP 工具;</li>
<li>右侧对选择的 MCP 工具进行调试。</li>
</ul>
<p>如图,测试成功。</p>
<h2 id="在工具中使用-mcp-server">在工具中使用 MCP Server</h2>
<h3 id="在-claude-for-desktop-中使用">在 Claude for Desktop 中使用</h3>
<p>首先需要安装 Claude 桌面版,安装地址如下:</p>
<blockquote>
<p>https://claude.ai/download</p>
</blockquote>
<p>然后打开以下配置文件:</p>
<blockquote>
<p>~/Library/Application Support/Claude/claude_desktop_config.json</p>
</blockquote>
<p>添加 MCP Server 配置:</p>
<pre><code class="language-json">{
    "mcpServers": {
      "pixabay": {
            "command": "node",
            "args": [
                "../pixabay/build/index.js"
            ],
            "env": {
                "PIXABAY_KEY": "..."
            }
      }
    }
}
</code></pre>
<p>注意,请替换成自己的 index.js 文件全路径和 PIXABAY_KEY。</p>
<p>然后再重启 Claude 桌面软件,可以看到有一个 MCP 工具可用:</p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090905270-868200282.png"></p>
<p>然后我们发起测试一下:</p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090905727-1369235819.png"></p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090906303-1218708600.png"></p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090906838-791034498.jpg"></p>
<p>成功通过自然语言获取到了猫吃饭的图片,通过<strong>Claude for Desktop</strong> 测试自定义的 <strong>MCP Server</strong> 调用成功。</p>
<h3 id="在-vs-code-中使用">在 VS Code 中使用</h3>
<p>在 VS Code 中只需要安装一个 <strong>ROO CODE</strong> 插件,不懂的请先看这篇:</p>
<blockquote>
<p>DeepSeek 装进 VSCode,编程非常丝滑!</p>
</blockquote>
<p>然后添加 MCP 图标配置 MCP Server:</p>
<pre><code class="language-json">{
"mcpServers": {
    "pixabay": {
      "command": "node",
      "args": [
      "../pixabay/build/index.js"
      ],
      "env": {
      "PIXABAY_KEY": "..."
      }
    }
}
}
</code></pre>
<p>配置成功后如图所示:</p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090907240-2063614816.png"></p>
<p>然后同样发起测试:</p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090907764-651729820.png"></p>
<p><img src="https://img2024.cnblogs.com/other/1218593/202504/1218593-20250430090908211-990891482.png"></p>
<p>成功通过自然语言获取到了猫吃饭的图片,通过<strong>VS Code</strong> 测试自定义的 <strong>MCP Server</strong> 调用成功。</p>
<p>在其他 AI 编程中使用 MCP Server 也是一样的道理,比如 <strong>Cursor</strong>,具体用法请参考这篇:</p>
<blockquote>
<p>最近热火朝天的 MCP 是什么鬼?如何使用 MCP?一文给你讲清楚!</p>
</blockquote>
<p>测试没问题后,我们就可以把代码发布到 npm 仓库供其他人使用了。</p>
<h2 id="总结">总结</h2>
<p>本文从 MCP Server 开发实战出发,完整演示了从零搭建一个 MCP Server 的流程。你不仅掌握了 MCP Server 的构建方式,也能体验到了 MCP 工具在开发者日常工作中带来的提效魔法。</p>
<p>重点回顾如下:</p>
<ul>
<li>MCP Server 是大模型调用外部服务的桥梁;</li>
<li>通过 Node.js 和官方 SDK 快速开发 MCP Server;</li>
<li>利用 <code>Inspector</code> 工具调试,所见即所得;</li>
<li>轻松集成到 Claude、VS Code、Cursor 等 AI 工具中;</li>
</ul>
<p>这不仅是一次 MCP 技术实战,也是一种新的编程范式的探索,让 AI 通过 MCP 调用我们的代码,把人类的创意和机器的执行力结合起来。</p>
<p>你也可以尝试把更多的业务能力封装成 MCP 工具,比如:商品推荐、新闻摘要、天气预报,甚至接入自己的数据库或私有系统等等,让 AI 真正成为我们日常工作中的得力助手。</p>
<p>未完待续,下篇我继续研究和分享更有趣的 AI + MCP 应用场景和实战,关注「<strong>AI技术宅</strong>」公众号和R哥一起学 AI。</p>
<blockquote>
<p><strong>版权声明:</strong> 本文系公众号 "AI技术宅" 原创,转载、引用本文内容请注明出处,抄袭、洗稿一律投诉侵权,后果自负,并保留追究其法律责任的权利。</p>
</blockquote>
<p><strong>更多文章推荐:</strong></p>
<p>1.Spring Boot 3.x 教程,太全了!</p>
<p>2.3,000+ 道 Java面试题及答案整理(最新版)</p>
<p>3.免费获取 IDEA 激活码的 7 种方式(最新版)</p>
<p>4.Java &amp; DeepSeek &amp; AI 学习资料分享</p>
<p>5.程序员精美简历模板分享</p>
<p>觉得不错,别忘了随手点赞+转发哦!</p>


</div>
<div id="MySignature" role="contentinfo">
   
<div style="clear: both"></div><br><br>
来源:https://www.cnblogs.com/javastack/p/18854880
頁: [1]
查看完整版本: 从零开始开发一个 MCP Server!保姆级教程!