当前位置: 首页 > article >正文

手把手教你用Node.js开发一个MCP Server(附完整调试流程)

从零构建MCP Server的Node.js实战指南1. MCP协议与开发环境准备Model Context ProtocolMCP正在成为AI工具集成领域的新兴标准。这个由Anthropic提出的开放协议本质上为AI模型与外部系统搭建了一座标准化桥梁。想象一下当Claude这样的AI需要访问数据库、调用API或操作系统文件时MCP就像USB接口一样提供即插即用的连接能力。开发环境要求Node.js 18 环境TypeScript 5.0代码编辑器VS Code推荐终端工具iTerm2或Windows Terminal# 验证Node.js环境 node -v npm -v # 初始化项目 mkdir mcp-time-server cd mcp-time-server npm init -y npm install typescript types/node --save-dev npx tsc --init提示Windows用户需确保PATH中包含Node.js路径Mac用户建议通过nvm管理多版本Node2. 核心架构设计2.1 MCP Server的工作机制典型的MCP交互包含三个关键角色MCP Client集成在AI工具中如Claude、CursorMCP Server开发者实现的业务逻辑载体协议适配层处理JSON-RPC 2.0格式的通信// 典型请求结构示例 { jsonrpc: 2.0, method: tools/call, params: { name: getCurrentTime, arguments: {timezone: Asia/Shanghai} }, id: 1 }2.2 通信模式选择模式适用场景性能特点典型配置示例STDIO本地调试、CLI工具低延迟、高吞吐command: node, args: [server.js]SSE远程服务、Web集成实时事件推送url: http://localhost:8000/sse3. 实现时间服务Server3.1 初始化MCP Server首先安装官方SDKnpm install modelcontextprotocol/sdk zod创建基础服务框架import { McpServer } from modelcontextprotocol/sdk/server/mcp; import { StdioServerTransport } from modelcontextprotocol/sdk/server/stdio; import { z } from zod; const server new McpServer({ name: TimeService, version: 1.0.0, description: 提供全球时区时间查询服务 });3.2 实现时间查询工具server.tool( getCurrentTime, 获取指定时区的当前时间, { timezone: z .string() .optional() .describe(IANA时区标识如America/New_York) }, async ({ timezone }) { try { const options timezone ? { timeZone: timezone } : {}; return { timestamp: new Date().toISOString(), localTime: new Date().toLocaleString(zh-CN, options), timezone: timezone || Intl.DateTimeFormat().resolvedOptions().timeZone }; } catch (error) { throw new Error(时区参数错误: ${error.message}); } } );3.3 启动服务async function start() { const transport new StdioServerTransport(); await server.connect(transport); console.log(⌚ 时间服务已启动); } start().catch(console.error);4. 调试与测试方案4.1 使用MCP Inspector官方提供的调试工具可可视化测试npx modelcontextprotocol/inspector node dist/server.js调试界面主要功能工具列表查看参数构造器原始请求/响应监控历史记录回放4.2 手动测试脚本创建测试用例验证功能const { spawn } require(child_process); const serverProcess spawn(node, [dist/server.js]); serverProcess.stdout.on(data, (data) { console.log([SERVER] ${data}); }); // 构造测试请求 const testRequest JSON.stringify({ jsonrpc: 2.0, method: tools/call, params: { name: getCurrentTime, arguments: { timezone: Europe/Berlin } }, id: Date.now() }); serverProcess.stdin.write(testRequest \n);4.3 常见问题排查时区无效错误验证IANA时区标识检查Node.js版本需≥14更新ICU数据npm install full-icuSTDIO通信故障Windows需使用cmd包装{ command: cmd, args: [/c, node, server.js] }5. 生产环境进阶配置5.1 性能优化策略连接池配置const transport new StdioServerTransport({ maxConnections: 10, idleTimeout: 30000 });日志集成npm install winstonimport winston from winston; const logger winston.createLogger({ level: debug, format: winston.format.json(), transports: [new winston.transports.File({ filename: mcp-debug.log })] }); server.setLogger((level, message) { logger.log(level, message); });5.2 安全防护措施输入验证z.string().regex(/^[A-Za-z_\/]$/).max(64)速率限制npm install express-rate-limit敏感操作审计server.on(toolCalled, (toolName, params) { auditLog(toolName, params); });6. 扩展开发实践6.1 多工具集成示例实现复合型天气预报服务server.tool(getWeather, ...); server.resource(cityList, ...); server.prompt(weatherQueryTips, ...);6.2 混合通信模式同时支持STDIO和HTTPimport { HttpServerTransport } from modelcontextprotocol/sdk/server/http; // HTTP服务 const httpTransport new HttpServerTransport({ port: 8080 }); server.connect(httpTransport); // STDIO服务 const stdioTransport new StdioServerTransport(); server.connect(stdioTransport);6.3 CI/CD集成示例GitHub Actions配置name: MCP Server Deployment on: [push] jobs: deploy: runs-on: ubuntu-latest steps: - uses: actions/checkoutv3 - run: npm ci - run: npm test - run: docker build -t mcp-time-server . - run: docker push your-registry/mcp-time-server在实现过程中发现时区处理是最容易出错的环节。特别是在Docker环境中需要确保容器时区与宿主机一致。一个实用的技巧是在Dockerfile中加入ENV TZAsia/Shanghai RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime

相关文章:

手把手教你用Node.js开发一个MCP Server(附完整调试流程)

从零构建MCP Server的Node.js实战指南 1. MCP协议与开发环境准备 Model Context Protocol(MCP)正在成为AI工具集成领域的新兴标准。这个由Anthropic提出的开放协议,本质上为AI模型与外部系统搭建了一座标准化桥梁。想象一下,当Cla…...

Surface Go变身专业数位板的3种高效方案

1. 从便携平板到专业画笔:Surface Go的隐藏潜力 如果你手头有一台Surface Go,可能更多时候是拿它来记笔记、看视频,或者临时处理一些轻量办公。但你可能没意识到,这台小巧的设备,其实蕴藏着变身成为专业数位板的巨大潜…...

实战教程:用PSPNet和LIP数据集搞定人体解析(附完整训练代码)

从零构建人体解析系统:基于PSPNet与LIP数据集的工程实践指南 人体解析技术正在重塑时尚电商、虚拟试衣、健身分析等领域的用户体验。想象一下,当用户上传一张自拍照片,系统能自动识别出服装款式、身体部位甚至配饰细节——这正是精准营销和个…...

Phi-3-vision-128k-instruct惊艳效果:含数学公式的教材插图推理与解题步骤生成

Phi-3-vision-128k-instruct惊艳效果:含数学公式的教材插图推理与解题步骤生成 1. 模型能力概览 Phi-3-Vision-128K-Instruct是目前最先进的轻量级开放多模态模型,专为处理复杂图文内容而设计。这个模型最令人印象深刻的能力在于它能够理解教材中的数学…...

TI电赛开发板开源软件例程深度解析与实战指南

TI电赛开发板开源软件例程深度解析与实战指南 很多刚开始接触TI电赛开发板的朋友,拿到板子后,第一反应往往是:“例程在哪?怎么用?” 面对官方提供的一堆源代码文件,有时会感觉无从下手,不知道从…...

存储型XSS的隐藏威胁:如何通过评论区漏洞入侵你的网站

存储型XSS的隐蔽杀伤链:从评论区漏洞到系统性入侵 当网站管理员清晨打开后台查看用户反馈时,屏幕上突然弹出伪造的登录框;当电商平台客服处理订单时,浏览器自动跳转到钓鱼页面;当新闻站点编辑审核内容时,数…...

基于天空星GD32F407的MQ-4甲烷传感器ADC+DMA数据采集实战

基于天空星GD32F407的MQ-4甲烷传感器ADCDMA数据采集实战 最近在做一个智能家居环境监测的小项目,需要检测厨房的天然气泄漏,于是就用上了MQ-4甲烷传感器。很多刚开始接触嵌入式开发的朋友,一看到传感器、ADC、DMA这些词就有点发怵&#xff0c…...

深入解析hutool的BeanUtil.copyProperties在多线程环境下的潜在陷阱

1. 为什么CopyOnWriteArrayList会变成ArrayList? 这个问题困扰了我整整两天。当时生产环境突然报出ArrayIndexOutOfBoundsException异常,查看日志发现是在ArrayList.add方法抛出的,但明明代码里用的是CopyOnWriteArrayList啊!这种…...

Sunshine 完全卸载与系统清理指南

Sunshine 完全卸载与系统清理指南 【免费下载链接】Sunshine Sunshine: Sunshine是一个自托管的游戏流媒体服务器,支持通过Moonlight在各种设备上进行低延迟的游戏串流。 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 引言 Sunshine作为一款…...

基于计算机网络原理优化LiuJuan模型分布式集群部署方案

基于计算机网络原理优化LiuJuan模型分布式集群部署方案 最近和几个做AI服务的同行聊天,大家普遍有个头疼的问题:模型单机部署,用户一多就卡死;想搞分布式集群,又怕架构太复杂,运维成本上天。这让我想起了之…...

手把手教程:用AI股票分析师daily_stock_analysis一键生成专业投资报告

手把手教程:用AI股票分析师daily_stock_analysis一键生成专业投资报告 你是不是也对那些动辄几十页、充满专业术语的股票分析报告感到头疼?自己研究吧,时间不够;找人分析吧,成本太高。现在,有个工具能让你…...

ADRC实战:用Python从零搭建一阶系统自抗扰控制器(附完整代码)

ADRC实战:用Python从零搭建一阶系统自抗扰控制器(附完整代码) 控制工程领域一直在追求更鲁棒、更智能的算法来应对复杂系统中的不确定性。自抗扰控制(Active Disturbance Rejection Control, ADRC)作为一种不依赖精确模…...

LibreELEC新手必看:用PVR IPTV Simple Client搞定电视直播(附免费m3u8源)

LibreELEC电视直播实战指南:从零搭建稳定流畅的IPTV系统 第一次在树莓派上打开央视高清频道时,那种用开源软件替代广电机顶盒的成就感至今难忘。LibreELEC作为专为Kodi优化的轻量级系统,配合PVR IPTV Simple Client插件,确实能打造…...

避坑指南:Unity触发器(Trigger)的5个典型误用场景与正确解决方案

Unity触发器(Trigger)实战避坑指南:5个高频误用场景与优化方案 在Unity物理交互开发中,触发器(Trigger)就像一把双刃剑——用得巧妙可以创造丝滑的游戏体验,用错地方则会导致诡异的bug和性能灾难。本文将揭示那些连资深开发者都可能踩中的陷阱…...

MedGemma医疗助手实战:从部署到问诊,小白也能用的AI医生

MedGemma医疗助手实战:从部署到问诊,小白也能用的AI医生 1. 引言:您的私人医疗AI助手 当深夜突然出现不明症状,或是阅读病历遇到难懂的医学术语时,您是否希望有个随时待命的专业医疗顾问?MedGemma医疗助手…...

douyin-downloader:突破平台限制的视频高效获取解决方案

douyin-downloader:突破平台限制的视频高效获取解决方案 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 在数字内容快速迭代的时代,视频资源的高效获取面临平台访问限制、动态签名验证…...

VibeVoice模型推理加速:TensorRT优化实战

VibeVoice模型推理加速:TensorRT优化实战 1. 为什么VibeVoice需要TensorRT加速 VibeVoice作为微软推出的前沿语音合成模型,能生成长达90分钟的多角色自然对话,但它的计算复杂度也相当可观。我在实际部署时发现,直接用PyTorch运行…...

Meta-Llama-3-8B-Instruct零基础部署:5分钟用vLLM+Open WebUI搭建对话机器人

Meta-Llama-3-8B-Instruct零基础部署:5分钟用vLLMOpen WebUI搭建对话机器人 1. 准备工作:了解你的工具 Meta-Llama-3-8B-Instruct是Meta公司最新开源的80亿参数对话模型,相比前代产品,它在指令遵循、多轮对话和代码理解方面都有…...

MySQL连接查询实战:从头歌平台案例学多表联合查询技巧

MySQL连接查询实战:从头歌平台案例学多表联合查询技巧 在数据库应用开发中,多表联合查询是每个开发者必须掌握的核心技能。想象一下,当你需要从学生表中获取姓名,同时从成绩表中查询对应分数,再关联课程表获取课程名称…...

ComfyUI低显存模式避坑指南:如何正确使用--disable-cuda-malloc和--normalvram参数

ComfyUI低显存GPU优化实战:参数调优与性能平衡指南 当你在4GB显存的显卡上运行ComfyUI时,是否经常遇到RuntimeError: CUDA error: operation not supported的报错?这可能是显存管理策略与你的硬件不兼容导致的。本文将带你深入理解ComfyUI的显…...

3步解锁图像数据:让科研图表开口说话

3步解锁图像数据:让科研图表开口说话 【免费下载链接】WebPlotDigitizer Computer vision assisted tool to extract numerical data from plot images. 项目地址: https://gitcode.com/gh_mirrors/web/WebPlotDigitizer 在科研分析、工程计算和商业决策中&a…...

AI辅助开发:借助快马平台为你的网盘注入智能文件摘要与语义搜索能力

最近在捣鼓一个网盘项目,想着怎么让它更“聪明”一点。传统的网盘就是个文件仓库,找东西全靠文件名,有时候文件多了,或者名字起得随意,找起来真是费劲。正好看到大家都在玩AI,我就琢磨着,能不能…...

Qwen3-14b_int4_awq惊艳效果:输入‘画一个架构图:用户登录流程’生成PlantUML代码

Qwen3-14b_int4_awq惊艳效果:输入"画一个架构图:用户登录流程"生成PlantUML代码 1. 模型简介 Qwen3-14b_int4_awq是基于Qwen3-14b模型的int4量化版本,采用AngelSlim技术进行压缩优化,专门用于高效文本生成任务。这个量…...

Qwen3-14b_int4_awqvLLM部署详解:engine_args配置、tokenizer路径指定与量化权重加载

Qwen3-14b_int4_awq LLM部署详解:engine_args配置、tokenizer路径指定与量化权重加载 1. 模型简介 Qwen3-14b_int4_awq是基于Qwen3-14b模型的int4量化版本,采用AngelSlim技术进行压缩优化,专门用于高效文本生成任务。这个量化版本在保持模型…...

Matlab中如何灵活定制坐标轴标签:深入解析set(gca,xtick)与set(gca,xticklabel)

1. 为什么需要定制坐标轴标签? 在数据可视化过程中,默认的坐标轴标签往往不能满足我们的需求。比如绘制一个正弦函数时,Matlab会自动生成均匀分布的刻度值,但这些数值可能并不直观。想象一下,如果你要给非技术背景的同…...

SpringBoot+Vue3无人机AI巡检:从实时流处理到智能预警的闭环实践

1. 项目背景与技术选型 最近几年无人机巡检在安防、电力、农业等领域快速普及,但很多团队在落地时都会遇到视频延迟高、AI识别不准、预警响应慢等问题。去年我们团队用SpringBootVue3完整实现了一套无人机AI巡检系统,实测在2km范围内能做到500ms以内的端…...

3步激活旧Mac潜能:OpenCore Legacy Patcher让不支持的设备重获新生

3步激活旧Mac潜能:OpenCore Legacy Patcher让不支持的设备重获新生 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher OpenCore Legacy Patcher(OCLP&…...

如何用动态深度学习提升锂电池故障检测准确率?清华团队最新研究实践

动态深度学习在锂电池故障检测中的突破性实践 电动汽车的普及让锂电池安全问题日益凸显。传统检测方法在面对复杂工况时,往往表现出高误报率或漏检率,而清华大学团队的最新研究为这一难题提供了创新解决方案——通过动态深度学习技术,实现了锂…...

Aria2配置避坑指南:从自启动到浏览器插件联调(附完整.conf文件)

Aria2配置避坑指南:从自启动到浏览器插件联调(附完整.conf文件) 在Windows环境下配置Aria2自启动并实现浏览器插件联调,看似简单却暗藏诸多细节陷阱。许多用户在完成基础配置后,常遇到服务静默崩溃、RPC连接失败或下载…...

手把手教你修复libgit2报错:从corrupted loose reference到完整恢复Git仓库

手把手教你修复libgit2报错:从corrupted loose reference到完整恢复Git仓库 当你正在专注地开发项目,突然遇到corrupted loose reference file: refs/heads/master这样的Git错误时,那种感觉就像是在高速公路上突然爆胎。这个错误不仅会中断你…...