MultiServerMCP

MultiServerMCP

arrenxxxxx

研究与数据
访问服务器

README

MultiServerMCP

一个基于 SSE 的多连接 MCP 服务器框架,用于长连接通信。为 AI 助手提供上下文和功能扩展能力。 目前仅支持 SSE 模式。

License: MIT English 中文简体

🚀 MultiServerMCP — 通过多连接服务器框架,为 AI 助手赋能扩展能力!

MultiServerMCP 旨在提供一个强大的服务器框架,支持单个服务器上的多个客户端连接,从而实现对 AI 助手的高效工具和权限管理。

🌟 主要特性

  • 支持 SSE 模式下单个服务器的多个客户端连接
  • 通过 URL 分组进行工具和权限管理
  • 内置心跳机制,确保连接稳定性
  • 简化的工具注册流程
  • 完全兼容 MCP 协议
  • 使用 SessionManager 进行全局会话管理,可在任何地方访问客户端上下文
  • 便捷的全局函数,可通过 sessionId 检索请求参数和客户端上下文

📦 安装

npm install multi-server-mcp
# or
yarn add multi-server-mcp
# or
pnpm add multi-server-mcp

🚀 快速开始

完整服务器示例

import { z } from "zod";
import { MultiServerMCP } from "multi-server-mcp";
import { ResourceTemplate } from "@modelcontextprotocol/sdk/server/mcp.js";
import { getSseReqQuery } from "multi-server-mcp";

// 创建启用 URL 分组的 MCP 服务器
const server = new MultiServerMCP(
  {
    name: "multi server",
    version: "1.0.0",
  },
  {
    enableUrlGroups: true,
  }
);

// 注册一个使用请求参数的计算器工具
server.tool("calc/add", { a: z.number(), b: z.number() }, async ({ a, b }, extra) => {
  console.log(extra);
  // 从 SSE 连接获取查询参数
  const reqQuery = getSseReqQuery(extra.sessionId as string);
  console.log(reqQuery);
  return {
    content: [{ type: "text", text: String(a + b) }],
  };
});

// 注册一个资源模板
server.resource(
  "greeting",
  new ResourceTemplate("greeting://{name}", { list: undefined }),
  async (uri, { name }) => ({
    contents: [
      {
        uri: uri.href,
        text: `Hello, ${name}!`,
      },
    ],
  })
);

// 启动服务器
server
  .start({
    transportType: "sse",
  })
  .then(() => {
    console.log(`Server started`);
  })
  .catch((error) => {
    console.error(`Server start failed: ${error}`);
    process.exit(1);
  });

基本用法

import { MultiServerMCP } from 'multi-server-mcp';

// 创建 MCP 服务器实例
const server = new MultiServerMCP({
  name: 'my-mcp-server',
  version: '1.0.0'
});

// 注册一个工具
server.tool('my-tool', async () => {
  return {
    content: [{ type: 'text', text: 'Tool executed successfully!' }]
  };
});

// 启动服务器
server.start({
  transportType: 'sse',
  sse: {
    port: 3000,
    endpoint: '/mcp',
    messagesEndpoint: '/mcp-messages'
  }
});

工具分组和权限管理

// 注册一个带有分组的工具
server.tool('group1/group2/my-tool', async () => {
  return {
    content: [{ type: 'text', text: 'Tool executed successfully!' }]
  };
});

// 启动具有权限管理的服务器
server.start({
  transportType: 'sse',
  enableUrlGroups: true
});

全局访问客户端上下文

import { getSseReqQuery, getClientContextBySessionId } from 'multi-server-mcp';
import { z } from "zod";

// 注册一个使用请求参数的工具
server.tool("calc/add", { a: z.number(), b: z.number() }, async ({ a, b }, extra) => {
  // 从 SSE 连接获取请求参数
  const reqQuery = getSseReqQuery(extra.sessionId as string);
  console.log('Query parameters:', reqQuery);
  
  return {
    content: [{ type: "text", text: String(a + b) }],
  };
});

// 在代码的任何部分,您也可以访问客户端的请求参数
function myFunction(sessionId: string) {
  // 从 SSE 连接请求获取查询参数
  const reqQuery = getSseReqQuery(sessionId);
  console.log('Client query parameters:', reqQuery);
  
  // 如果需要,获取完整的客户端上下文
  const clientContext = getClientContextBySessionId(sessionId);
  if (clientContext) {
    console.log('Client URL groups:', clientContext.urlGroups);
    // 访问任何其他客户端上下文属性
  }
}

🔧 开发指南

目前仅支持 SSE 模式。

支持的工具类型

  • 常规工具: server.tool()
  • 资源工具: server.resource()
  • Prompt 工具: server.prompt()

会话管理

SessionManager 提供了一个单例实例来管理客户端会话:

  • SessionManager.getInstance(): 获取单例实例
  • SessionManager.getInstance().getClientContext(sessionId): 通过 sessionId 获取客户端上下文
  • SessionManager.getInstance().getReqQuery(sessionId): 通过 sessionId 获取请求查询参数
  • SessionManager.getInstance().getSessionCount(): 获取活动会话的数量

为了方便起见,提供了以下全局函数:

  • getSseReqQuery(sessionId): 通过 sessionId 获取请求查询参数
  • getClientContextBySessionId(sessionId): 通过 sessionId 获取客户端上下文

🤝 贡献

欢迎贡献、提交问题和提出功能请求!

📄 许可证

MIT

推荐服务器

Crypto Price & Market Analysis MCP Server

Crypto Price & Market Analysis MCP Server

一个模型上下文协议 (MCP) 服务器,它使用 CoinCap API 提供全面的加密货币分析。该服务器通过一个易于使用的界面提供实时价格数据、市场分析和历史趋势。 (Alternative, slightly more formal and technical translation): 一个模型上下文协议 (MCP) 服务器,利用 CoinCap API 提供全面的加密货币分析服务。该服务器通过用户友好的界面,提供实时价格数据、市场分析以及历史趋势数据。

精选
TypeScript
MCP PubMed Search

MCP PubMed Search

用于搜索 PubMed 的服务器(PubMed 是一个免费的在线数据库,用户可以在其中搜索生物医学和生命科学文献)。 我是在 MCP 发布当天创建的,但当时正在度假。 我看到有人在您的数据库中发布了类似的服务器,但还是决定发布我的服务器。

精选
Python
mixpanel

mixpanel

连接到您的 Mixpanel 数据。 从 Mixpanel 分析查询事件、留存和漏斗数据。

精选
TypeScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

这个服务器通过将复杂问题分解为顺序步骤来促进结构化的问题解决,支持修订,并通过完整的 MCP 集成来实现多条解决方案路径。

精选
Python
Nefino MCP Server

Nefino MCP Server

为大型语言模型提供访问德国可再生能源项目新闻和信息的能力,允许按地点、主题(太阳能、风能、氢能)和日期范围进行筛选。

官方
Python
Vectorize

Vectorize

将 MCP 服务器向量化以实现高级检索、私有深度研究、Anything-to-Markdown 文件提取和文本分块。

官方
JavaScript
Mathematica Documentation MCP server

Mathematica Documentation MCP server

一个服务器,通过 FastMCP 提供对 Mathematica 文档的访问,使用户能够从 Wolfram Mathematica 检索函数文档和列出软件包符号。

本地
Python
kb-mcp-server

kb-mcp-server

一个 MCP 服务器,旨在实现便携性、本地化、简易性和便利性,以支持对 txtai “all in one” 嵌入数据库进行基于语义/图的检索。任何 tar.gz 格式的 txtai 嵌入数据库都可以被加载。

本地
Python
Research MCP Server

Research MCP Server

这个服务器用作 MCP 服务器,与 Notion 交互以检索和创建调查数据,并与 Claude Desktop Client 集成以进行和审查调查。

本地
Python
Cryo MCP Server

Cryo MCP Server

一个API服务器,实现了模型补全协议(MCP),用于Cryo区块链数据提取,允许用户通过任何兼容MCP的客户端查询以太坊区块链数据。

本地
Python