MCP Server: Trend Data Persister

MCP Server: Trend Data Persister

Flow-Research

研究与数据
访问服务器

README

MCP 服务器:趋势数据持久化器

本项目使用 Python (fastmcp) 实现了一个模型上下文协议 (MCP) 服务器,用于将趋势数据(上升或下降)持久化到 PostgreSQL 数据库中。

该服务器公开了一个工具 persist-trend-data,它接受:

  1. datasource_url: 目标 PostgreSQL 数据库的连接字符串。

  2. json_data: 代表趋势的 JSON 对象。它必须匹配以下模式之一:

    • 上升趋势:
      {
        "trend": "upward",
        "rockstars": [
          { "name": "string", "department": "string", "amount": integer },
          ...
        ]
      }
      
    • 下降趋势:
      {
        "trend": "downward",
        "culprits": [
          { "name": "string", "department": "string", "amount": integer },
          ...
        ]
      }
      

功能:

根据 json_data 中的 trend 值:

  • 如果 trend 是 "upward",它会确保存在一个名为 upward_trend_rockstars 的表(包含 idnamedepartmentamount 列)。然后,它将 rockstars 数组中的数据插入到该表中。
  • 如果 trend 是 "downward",它会确保存在一个名为 downward_trend_culprits 的表(包含相同的列)。然后,它将 culprits 数组中的数据插入到该表中。
  • 该工具使用 Pydantic 进行输入验证,并使用 psycopg2 与 PostgreSQL 数据库交互。

前提条件

  • Python (建议 >=3.10,如 pyproject.toml 中指定)
  • make
  • uv (可选,如果未找到 uv,Makefile 将回退到 python -m venvpip)
  • 可以访问正在运行的 PostgreSQL 数据库。

设置和运行

为了方便起见,提供了一个 Makefile。

  1. 克隆/导航: 进入项目目录:
    cd /path/to/mcp-server-trend-persister
    
  2. 运行服务器:
    make
    
    该设置将安装依赖项,运行 MCP 服务器并检查它。此外,MCP 服务器将监听通过标准输入/输出发送的请求。

Makefile 目标

Makefile 中提供了以下目标:

  • make install: 创建/更新 .venv 虚拟环境,并使用 uv(首选)或 pip 安装依赖项。
  • make run: 使用 .venv 中的 Python 解释器运行 MCP 服务器 (persister.py)。
  • make inspect: 使用 MCP 检查器 (npx @modelcontextprotocol/inspector uv run persister.py) 检查 persister.py 中定义的工具。依赖于 install
  • make lint: 运行代码检查器(例如,Ruff、Black)的占位符。
  • make clean: 删除虚拟环境、缓存文件和其他构建工件。
  • make help: 显示可用目标的列表。

与 MCP 客户端集成

配置您的 MCP 客户端(如上下文中提到的客户端)以连接到此服务器。使用 Makefile 时,启动服务器的命令会简化。

示例配置片段:

{
    "mcpServers": {
        "trend-persister": {
            "command": "make",
            "args": [
                "run" // 要执行的目标
            ],
            "cwd": "/Users/julian/Documents/Code/Learning/MCP/mcp-server-trend-persister" // 重要:设置工作目录
        },
        // ... 其他服务器
    }
}

确保 cwd 路径指向 Makefile 所在的正确项目目录。

示例工具请求

MCP 客户端将发送如下请求:

{
  "toolName": "persist-trend-data",
  "arguments": {
    "datasource_url": "postgresql://your_user:your_password@your_host:5432/your_db",
    "json_data": {
      "trend": "upward",
      "rockstars": [
        { "name": "Alice", "department": "Sales", "amount": 50000 },
        { "name": "Bob", "department": "Engineering", "amount": 60000 }
      ]
    }
  }
}

推荐服务器

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