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

这篇文章得到了大家的广泛阅读,让大家对 MCP 的概念和使用也有了一个基础的认知,也介绍了如何使用 MCP Server,这篇再来介绍下如何从 0 开发一个自己的 MCP Server。

MCP 本质上是为 AI 大模型提供调用外部工具的能力,MCP Server 就是这个能力的具体实现——你可以通过它,把你已有的 API、脚本、服务包装成 AI 能理解和调用的 MCP 工具。

这篇我们就以获取图片为例来创建一个 MCP Server,让 AI 根据自然语言来获取图片网站上的图片,比如 Pixabay 图片网站,它就提供了 API 可以让外界来搜索图片。

Pixabay API 文档:

Pixabay API Documentation

MCP 官方提供了 Python、Node、Java、Kotlin 等 SDK 接入,我们为了方便测试使用,本文以 Node 为例进行演示,请确保你安装了最新版本的 Node。

安装 Node 环境

如果你还没有安装 Node.js 和 npm,你可以从 nodejs.org 下载并安装,然后验证 Node.js 是否正确安装:

node --version

npm --version

安装过程,略。

创建 MCP Server 项目

创建一个 MCP Server 项目:

mkdir pixabay

cd pixabay

初始化一个新的 npm 项目:

npm init -y

安装相关依赖:

npm install @modelcontextprotocol/sdk zod

npm install -D @types/node typescript

创建主要目录和文件:

mkdir src

touch src/index.ts

更新 package.json 文件,添加以下主要配置项:

{
  "type": "module",
  "bin": {
    "pixabay": "./build/index.js"
  },
  "scripts": {
    "build": "tsc && chmod 755 build/index.js"
  },
  "files": [
    "build"
  ],
}

在根目录创建 tsconfig.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"]
}

到此,项目初始化完成,现在让我们开始构建一个图片搜索的 MCP 服务器吧。

构建 MCP Server

在项目 index.ts 文件中添加 MCP Server:

// 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' }) => {
        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}&q=${query}&image_type=${type}&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();

这里主要定义了一个 McpServer,然后添加了一个名为 pixabay-image-search 的 MCP Tool 工具,用来从 Pixabay 根据关键字和类型搜索图片。

最后使用以下命令进行构建:

npm run build

根据之前的项目定义,最终会在 build 目录中构建为 index.js 文件。

调试 MCP Server

官方提供了一个 Inspector 调试工具,它是一款用于测试和调试 MCP 服务器的交互式开发者工具,详细介绍和使用方法如下:

Inspector - Model Context Protocol

启动调试参考命令:

sudo npx @modelcontextprotocol/inspector node build/index.js

启动成功后,访问以下地址:

http://127.0.0.1:6274/

这个界面主要分为三个区域:

  • 左侧进行环境变量配置、MCP Server 连接/重启等操作;
  • 中间选择要调试的 MCP 工具;
  • 右侧对选择的 MCP 工具进行调试。

如图,测试成功。

在工具中使用 MCP Server

在 Claude for Desktop 中使用

首先需要安装 Claude 桌面版,安装地址如下:

App unavailable \ Anthropic

然后打开以下配置文件:

~/Library/Application Support/Claude/claude_desktop_config.json

添加 MCP Server 配置:

{
    "mcpServers": {
        "pixabay": {
            "command": "node",
            "args": [
                "../pixabay/build/index.js"
            ],
            "env": {
                "PIXABAY_KEY": "..."
            }
        }
    }
}

注意,请替换成自己的 index.js 文件全路径和 PIXABAY_KEY。

然后再重启 Claude 桌面软件,可以看到有一个 MCP 工具可用:

然后我们发起测试一下:

成功通过自然语言获取到了猫吃饭的图片,通过 Claude for Desktop 测试自定义的 MCP Server 调用成功。

在 VS Code 中使用

在 VS Code 中只需要安装一个 ROO CODE 插件,不懂的请先看这篇:

DeepSeek 装进 VSCode,编程非常丝滑!

然后添加 MCP 图标配置 MCP Server:

{
  "mcpServers": {
    "pixabay": {
      "command": "node",
      "args": [
        "../pixabay/build/index.js"
      ],
      "env": {
        "PIXABAY_KEY": "..."
      }
    }
  }
}

配置成功后如图所示:

然后同样发起测试:

成功通过自然语言获取到了猫吃饭的图片,通过 VS Code 测试自定义的 MCP Server 调用成功。

在其他 AI 编程中使用 MCP Server 也是一样的道理,比如 Cursor,具体用法请参考这篇:

最近热火朝天的 MCP 是什么鬼?如何使用 MCP?一文给你讲清楚!

测试没问题后,我们就可以把代码发布到 npm 仓库供其他人使用了。

总结

本文从 MCP Server 开发实战出发,完整演示了从零搭建一个 MCP Server 的流程。你不仅掌握了 MCP Server 的构建方式,也能体验到了 MCP 工具在开发者日常工作中带来的提效魔法。

重点回顾如下:

  • MCP Server 是大模型调用外部服务的桥梁;
  • 通过 Node.js 和官方 SDK 快速开发 MCP Server;
  • 利用 Inspector 工具调试,所见即所得;
  • 轻松集成到 Claude、VS Code、Cursor 等 AI 工具中;

这不仅是一次 MCP 技术实战,也是一种新的编程范式的探索,让 AI 通过 MCP 调用我们的代码,把人类的创意和机器的执行力结合起来。

你也可以尝试把更多的业务能力封装成 MCP 工具,比如:商品推荐、新闻摘要、天气预报,甚至接入自己的数据库或私有系统等等,让 AI 真正成为我们日常工作中的得力助手。

 如何系统的去学习大模型LLM ?

大模型时代,火爆出圈的LLM大模型让程序员们开始重新评估自己的本领。 “AI会取代那些行业?”“谁的饭碗又将不保了?”等问题热议不断。

事实上,抢你饭碗的不是AI,而是会利用AI的人。

科大讯飞、阿里、华为等巨头公司发布AI产品后,很多中小企业也陆续进场!超高年薪,挖掘AI大模型人才! 如今大厂老板们,也更倾向于会AI的人,普通程序员,还有应对的机会吗?

与其焦虑……

不如成为「掌握AI工具的技术人」,毕竟AI时代,谁先尝试,谁就能占得先机!

但是LLM相关的内容很多,现在网上的老课程老教材关于LLM又太少。所以现在小白入门就只能靠自学,学习成本和门槛很高。

基于此,我用做产品的心态来打磨这份大模型教程,深挖痛点并持续修改了近70次后,终于把整个AI大模型的学习门槛,降到了最低!

在这个版本当中:

第一您不需要具备任何算法和数学的基础
第二不要求准备高配置的电脑
第三不必懂Python等任何编程语言

您只需要听我讲,跟着我做即可,为了让学习的道路变得更简单,这份大模型教程已经给大家整理并打包,现在将这份 LLM大模型资料 分享出来:包括LLM大模型书籍、640套大模型行业报告、LLM大模型学习视频、LLM大模型学习路线、开源大模型学习教程等, 😝有需要的小伙伴,可以 扫描下方二维码领取🆓↓↓↓

一、LLM大模型经典书籍

AI大模型已经成为了当今科技领域的一大热点,那以下这些大模型书籍就是非常不错的学习资源。

在这里插入图片描述

二、640套LLM大模型报告合集

这套包含640份报告的合集,涵盖了大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。(几乎涵盖所有行业)
在这里插入图片描述

三、LLM大模型系列视频教程

在这里插入图片描述

四、LLM大模型开源教程(LLaLA/Meta/chatglm/chatgpt)

在这里插入图片描述

五、AI产品经理大模型教程

在这里插入图片描述

LLM大模型学习路线 

阶段1:AI大模型时代的基础理解

  • 目标:了解AI大模型的基本概念、发展历程和核心原理。

  • 内容

    • L1.1 人工智能简述与大模型起源
    • L1.2 大模型与通用人工智能
    • L1.3 GPT模型的发展历程
    • L1.4 模型工程
    • L1.4.1 知识大模型
    • L1.4.2 生产大模型
    • L1.4.3 模型工程方法论
    • L1.4.4 模型工程实践
    • L1.5 GPT应用案例

阶段2:AI大模型API应用开发工程

  • 目标:掌握AI大模型API的使用和开发,以及相关的编程技能。

  • 内容

    • L2.1 API接口
    • L2.1.1 OpenAI API接口
    • L2.1.2 Python接口接入
    • L2.1.3 BOT工具类框架
    • L2.1.4 代码示例
    • L2.2 Prompt框架
    • L2.3 流水线工程
    • L2.4 总结与展望

阶段3:AI大模型应用架构实践

  • 目标:深入理解AI大模型的应用架构,并能够进行私有化部署。

  • 内容

    • L3.1 Agent模型框架
    • L3.2 MetaGPT
    • L3.3 ChatGLM
    • L3.4 LLAMA
    • L3.5 其他大模型介绍

阶段4:AI大模型私有化部署

  • 目标:掌握多种AI大模型的私有化部署,包括多模态和特定领域模型。

  • 内容

    • L4.1 模型私有化部署概述
    • L4.2 模型私有化部署的关键技术
    • L4.3 模型私有化部署的实施步骤
    • L4.4 模型私有化部署的应用场景

这份 LLM大模型资料 包括LLM大模型书籍、640套大模型行业报告、LLM大模型学习视频、LLM大模型学习路线、开源大模型学习教程等, 😝有需要的小伙伴,可以 扫描下方二维码领取🆓↓↓↓

<think>首先,用户的问题是:“我想了解MCP Server的相关信息,如定义、功能、使用方法等 请问MCP Server介绍、功能及使用方法”。这是一个关于MCP Server的查询。 现在,参考系统指令: - 所有行内数学表达式必须使用$...$格式。 - 独立公式必须使用$$...$$并单独成段。 - LaTeX语法正确。 - 使用中文回答。 - 生成相关问题。 - 回答中引用的段落末尾自然地添加引用标识。 用户还提供了几个站内引用: - [1]:MCP Server & Client,通过fastapi_mcp和SSE协议构建。 - [2]:个人开发者搭建教程MCP Server是依据模型上下文协议搭建的服务器。 - [3]:手把手实现MCP ServerMCP客户端是关键组件。 - [4]:创建Agent连接到MCP Server的代码示例。 - [5]:零代码搭建MCP Server的开源工具。 这些引用给我的信息是: - MCP Server是基于模型上下文协议的服务器。 - 它是一个中转枢纽,处理模型与客户端的通信和数据交互。 - 支持fastapi_mcp和SSE协议。 - 客户端通过JSON-RPC交互。 - 有零代码搭建工具。 系统指令还说:“上述引用仅供参考,并不是用户真正的需求,请尽可能多的参考用户上一次的问题和你的回答。” 但在这个对话中,这是第一次用户的问题,没有上一次的问题。所以,我应该基于当前的问题和提供的引用来回答。 结构回答: 1. **介绍MCP Server的定义**:根据引用[2],MCP Server是依据模型上下文协议搭建的服务器。 2. **功能**:从引用[2]和[3]: - 处理模型与上下文相关的信息。 - 实现模型与客户端的高效通信和数据交互。 - 自动匹配协议版本。 - 数据传输和JSON-RPC交互。 - 发现和使用工具、管理资源。 3. **使用方法**: - 搭建:引用[2]和[5]提到搭建方法,包括环境准备和零代码工具。 - 使用:引用[4]展示如何创建Agent连接MCP Server。 - 引用[1]提到构建MCP Server和Client。 4. **回答问题结构**:需要清晰、逐步解决用户的问题。用户要求了介绍、功能和使用方法。 5. **生成相关问题**:在回答末尾,生成相关问题,类似示例。 6. **引用标识**:在回答中引用的地方添加引用标识,例如[^1]。 回答步骤: - 先定义MCP Server。 - 然后列出功能。 - 最后解释使用方法。 确保使用中文。 生成相关问题: 类似示例,生成2-3个相关问题,基于MCP Server。 例如: 1. 如何优化MCP Server的性能? 2. MCP Server有哪些常见应用场景? 3. 零代码搭建工具的局限性是什么? 现在,回答内容: - **定义**:MCP Server(Model Context Protocol Server)是一种基于模型上下文协议的服务器,旨在作为中间枢纽,处理模型与客户端之间的通信和数据交互。它确保数据准确传输和规则执行[^2]。 - **功能**: - 高效通信:支持多种协议如fastapi_mcp和SSE协议,实现模型与客户端的实时数据交换[^1]。 - 自动化管理:自动匹配客户端协议版本,支持JSON-RPC交互和管理资源[^3]。 - 上下文处理:处理与模型上下文相关的信息,确保运行符合既定规则[^2]。 - 工具集成:允许发现和使用外部工具,如API集成[^3][^5]。 - **使用方法**: - **搭建**:个人开发者可以使用开源工具零代码搭建,如参考[^5],无需编程知识。环境准备包括安装必要的软件和评估系统需求[^2][^5]。 - **配置**:通过命令行运行,指定参数如存储路径。例如,在Agent代码中配置服务器参数:`server_params_axiv = StdioServerParameters(...)`[^4]。 - **连接客户端**:使用MCP Client连接到Server,进行数据传输和交互[^1][^3]。 最后,添加相关问题。 </think>### MCP Server介绍、功能及使用方法 MCP Server(Model Context Protocol Server,模型上下文协议服务器)是一种基于模型上下文协议(MCP开发的服务器系统,它充当模型与客户端之间的中间枢纽。其主要目标是实现高效的数据通信、上下文管理和规则执行,确保模型能够准确接收和发送数据,并支持各种工具的集成。MCP Server 的设计注重灵活性,适用于AI模型部署、自动化任务处理和实时数据交互等场景。以下我将从定义、功能和用法三个方面,逐步为您详细介绍。 #### 1. **MCP Server的定义** MCP Server 是依据模型上下文协议(MCP)搭建的服务器,致力于处理模型与上下文相关的信息交换。它像一个“智能路由中心”,负责协调模型(如AI模型)与客户端(如用户应用或界面)之间的通信,确保数据流动符合既定规则。核心价值在于简化模型部署,提升交互效率,尤其适合需要实时处理的应用场景[^2]。例如,在AI驱动的系统中,MCP Server 可以确保模型能动态响应客户端请求,而开发者无需深入底层协议细节。 #### 2. **MCP Server的核心功能** MCP Server 提供多项关键功能,使其成为高效的数据交互平台: - **高效通信与数据传输**:支持多种协议实现实时交互,包括基于FastAPI的RESTful API和Server-Sent Events(SSE)协议,确保低延迟的数据传输。例如,客户端可以发送JSON-RPC请求,服务器能自动处理模型输出并返回结果[^1][^3]。这在实时应用(如聊天机器人或数据分析工具)中尤为关键。 - **自动协议管理与版本匹配**:MCP Server 能自动检测并匹配客户端协议版本,确保兼容性。这减少了手动配置的麻烦,并支持动态功能发现(如在运行时识别可用的API工具),提升系统灵活性[^3]。 - **上下文处理与规则执行**:作为中间枢纽,它管理模型上下文(如用户会话状态或历史数据),确保数据交互符合业务规则。例如,在处理天气API请求时,它能验证输入参数并触发模型执行相应逻辑[^2][^5]。 - **工具集成与资源管理**:支持发现和使用外部工具(如Excel或微信API),允许开发者通过配置轻松扩展功能。同时,提供资源管理能力,如内存优化和连接池,避免资源冲突[^3][^5]。 - **零代码搭建支持**:通过开源工具,MCP Server 可以快速部署,无需编写代码。这降低了入门门槛,适合非技术用户快速验证想法,同时确保安全性和可靠性[^5]。 这些功能使MCP Server 广泛应用于AI模型服务、自动化工作流和实时监控系统,提高了开发效率和系统稳定性。 #### 3. **MCP Server的使用方法** 使用MCP Server 主要包括搭建、配置和连接三个步骤。基于引用内容,我为您整理了简明指南: - **搭建MCP Server**: - **零代码方法(推荐初学者)**:使用开源工具(如uv工具链),无需编程知识。只需执行命令行命令,例如通过以下步骤: ```bash # 下载工具并运行服务器 uv tool run arxiv-mcp-server --storage-path ./storage ``` 这会在本地启动一个MCP Server实例,自动处理配置(如存储路径和环境变量)。开源工具提供GUI或命令行接口,5分钟内即可完成搭建[^5][^2]。 - **定制搭建(适合开发者)**:如需更高灵活性,可以使用FastAPI框架(基于Python)。示例代码: ```python # FastAPI实现MCP Server的简化示例 from fastapi import FastAPI, Request app = FastAPI() @app.post("/mcp/execute") async def execute_model(request: Request): data = await request.json() # 处理模型逻辑,如调用AI模型 return {"result": "处理成功", "output": data} ``` 运行后,服务器即可响应客户端请求。搭建前需评估环境(如安装Python和依赖),确保系统兼容性[^1][^2]。 - **配置MCP Server**: - 服务器参数通过命令行或环境变量设置。典型参数包括: - `--storage-path`:指定数据存储位置。 - `env`:环境变量注入,如API密钥。 在Agent代码中配置示例(引用自[^4]): ```python server_params = StdioServerParameters( command="uv", # 可执行文件 args=["tool", "run", "arxiv-mcp-server", "--storage-path", "./storage"], env={**os.environ} # 继承系统环境 ) ``` 这确保了服务器与客户端的一致性和可扩展性。 - **连接并使用MCP Server**: - **客户端连接**:通过MCP Client(如IDE或自定义脚本)建立连接。客户端支持自动协议协商和JSON-RPC交互。例如,在Cursor IDE中,只需指定服务器地址即可开始数据传输[^3][^1]。 - **实际应用**:创建Agent(如一个自动化助手)连接到Server: ```python # Agent代码连接到MCP Server from mcp_client import MCPClient client = MCPClient(server_url="http://localhost:8000") response = client.execute_command(command="get_weather", params={"city": "北京"}) print(response) # 输出模型处理结果 ``` 这允许Agent调用外部工具(如天气API),实现端到端自动化[^4]。 使用注意事项:确保服务器环境安全(如防火墙设置),并监控日志以优化性能。零代码工具虽快捷,但复杂场景可能需要自定义开发[^2][^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值