此仓库是一个 MCP 服务器的概念验证实现,它借助 WebSocket 来暴露另一个基于标准输入输出 (stdio) 的 MCP 服务器。通过这种方式,能有效解决传统 MCP 服务器使用过程中存在的诸多问题,提升使用的便捷性和效率。
此仓库包含一个包装程序,可以将现有 MCP 服务器(此处 列出了官方的一些)通过 WebSocket 暴露出来:
bun run mcp-server-wrapper -p 3001 -- npx -y @modelcontextprotocol/server-puppeteer@latest
为了更快的启动时间,直接使用 node 安装并运行:
pnpm install -g @modelcontextprotocol/server-puppeteer@latest
bun run mcp-server-wrapper -p 3001 -- node ~/Library/pnpm/global/5/node_modules/@modelcontextprotocol/server-puppeteer/dist/index.js
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
import { WebSocketClientTransport } from "@modelcontextprotocol/sdk/client/websocket.js";
const transport = new WebSocketClientTransport(new URL("ws://localhost:3001"));
const client = new Client(
{
name: "example-client",
version: "1.0.0",
},
{
capabilities: {},
}
);
await client.connect(transport);
const tools = await client.listTools();
console.log(
"Tools:",
tools.tools.map((t) => t.name)
);
await client.close();
bun run mcp-server-wrapper-client
$ bun run src/mcp-server-wrapper/example-client/example-client.ts
Tools: [ "puppeteer_navigate", "puppeteer_screenshot", "puppeteer_click", "puppeteer_fill",
"puppeteer_evaluate"
]
对于给定的 MCP 服务器配置,例如:
{
"mcpServers": {
"fetch": {
"command": "uvx",
"args": ["mcp-server-fetch"]
}
}
}
我们希望为这种 MCP 服务器配置生成一个 Docker 镜像,以便在任何地方运行。此仓库包含了一个脚本,该脚本将根据 MCP 服务器配置输出一个 Dockerfile:
# 这里应该有一个示例命令,但当前文档中没有提供具体的命令。
使用 MCP 服务器存在诸多不便之处,而本项目能有效解决这些问题:
npx ... 或 uvx ...,这带来了这些工具固有的延迟(通常需要 2 - 3 秒的启动时间)。本项目通过优化启动方式,提升了启动速度。如果 MCP 服务器实际上是网络服务器,即通过网络进行通信而不是 stdio,那么你可以更轻松地在程序中使用它们。本项目通过将 MCP 服务器转换为 WebSocket 服务器,实现了更高效的程序化交互方式,解决了现有 MCP 服务器管理复杂、启动缓慢的问题,同时提升了性能和用户体验。