PubChem Chemical Safety MCP Server

PubChem Chemical Safety MCP Server

Enables users to retrieve chemical safety information including compound properties, GHS safety classifications, and toxicity data from PubChem database using compound names or CIDs. Supports batch queries with caching for efficient chemical safety research and analysis.

Category
访问服务器

README

PubChem Chemical Safety MCP Server

一个基于 Model Context Protocol (MCP) 的化学安全信息服务器,用于从化合物名称或 CID 自动获取毒理、GHS 安全分类、化学性质等信息。

功能特性

  • 获取化合物基础属性信息(分子式、分子量、IUPAC名称等)
  • 获取 GHS 安全分类信息(信号词、象形图、危害声明)
  • 获取毒性实验数据(LD50、LC50等)
  • 支持批量查询和缓存机制
  • 基于 MCP 协议,可与 Claude Desktop 等 AI 客户端集成
  • 支持代理访问,解决网络连接问题

技术栈

  • 协议: Model Context Protocol (MCP)
  • 语言: Python 3.10+
  • 依赖管理: uv
  • 数据源: PubChem REST API
  • 缓存: 本地文件缓存
  • HTTP客户端: aiohttp (支持代理和重试机制)

安装与运行

1. 安装依赖

uv sync

2. 运行 MCP 服务器

uv run python -m pubchem_mcp.mcp_server

3. 测试服务器

uv run verify_mcp.py

MCP 工具

服务器提供以下 3 个 MCP 工具:

1. get_compound_info

获取化合物基础信息

  • 参数: name (化合物名称)
  • 返回: CID、分子式、分子量、IUPAC名称、SMILES等
  • 示例: get_compound_info("aspirin")get_compound_info("阿司匹林")

2. get_safety_info

获取 GHS 安全分类信息

  • 参数: cid (PubChem化合物ID)
  • 返回: 信号词、GHS象形图、危害声明、预防措施等
  • 示例: get_safety_info(2244) (阿司匹林的CID)

3. get_toxicity_data

获取毒性实验数据

  • 参数: cid (PubChem化合物ID)
  • 返回: 急性毒性、生态毒性、致癌性、生殖毒性等详细数据
  • 示例: get_toxicity_data(2244) (阿司匹林的CID)

使用示例

Python 客户端示例

import asyncio
from mcp.client.stdio import stdio_client
from mcp import ClientSession, StdioServerParameters

async def main():
    server_params = StdioServerParameters(
        command='uv',
        args=['--directory', '/path/to/project', 'run', 'python', '-m', 'pubchem_mcp.mcp_server']
    )
    
    async with stdio_client(server_params) as (stdio, write):
        async with ClientSession(stdio, write) as session:
            await session.initialize()
            
            # 获取化合物信息
            result = await session.call_tool('get_compound_info', {
                'name': 'aspirin'
            })
            print(result.content[0].text)

asyncio.run(main())

Claude Desktop 中使用

在 Claude Desktop 中可以直接使用自然语言查询:

请查询阿司匹林的安全信息
获取咖啡因的毒性数据

调试工具

使用 MCP Inspector 进行调试:

npx -y @modelcontextprotocol/inspector uv run python -m pubchem_mcp.mcp_server

项目结构

pubchem_mcp/
├── mcp_server.py          # MCP 服务器主文件
├── services/
│   ├── pubchem_client.py  # PubChem API 客户端(支持代理和重试)
│   ├── cache_service.py   # 缓存服务
│   └── pubchem_service.py # PubChem 服务层
├── models/
│   └── schemas.py         # 数据模型定义
└── api/
    └── routes.py          # API 路由(可选)

tests/                     # 测试文件
manage_cache.py            # 缓存管理工具
verify_mcp.py             # MCP 验证工具
claude_desktop_config.json # Claude Desktop 配置示例

配置选项

  • CACHE_DIR: 缓存目录路径(默认 .cache
  • PUBCHEM_RATE_LIMIT: API 请求限制(默认 5 req/s)
  • https_proxy: HTTPS 代理设置
  • http_proxy: HTTP 代理设置

缓存管理

服务器使用本地文件缓存来提高性能:

  • 缓存位置: .cache/ 目录
  • 缓存策略:
    • 化合物信息缓存2小时
    • 安全信息和毒性数据缓存1小时
    • 过期文件自动删除
  • 缓存管理: 运行 uv run manage_cache.py 查看缓存统计

网络配置

代理设置

项目支持通过环境变量设置代理:

export https_proxy=http://127.0.0.1:10808
export http_proxy=http://127.0.0.1:10808

重试机制

  • 自动重试503错误(服务器繁忙)
  • 递增等待时间避免过于频繁的请求
  • 最多重试3次

请求头优化

  • 使用完整的浏览器User-Agent
  • 添加必要的HTTP请求头(Accept、Referer等)
  • 支持gzip压缩

测试化合物

以下化合物已测试可用:

  • aspirin (阿司匹林) - CID: 2244
  • caffeine (咖啡因) - CID: 2519
  • water (水) - CID: 962
  • ethanol (乙醇) - CID: 702
  • benzene (苯) - CID: 241

故障排除

常见问题

  1. 503 错误: 服务器繁忙,会自动重试
  2. 网络连接失败: 检查代理设置是否正确
  3. 化合物未找到: 尝试使用英文名称或化学式

日志查看

服务器会输出详细的日志信息,包括:

  • 请求状态
  • 重试信息
  • 错误详情

开发

运行测试

uv run pytest tests/

代码格式化

uv run black .
uv run isort .

类型检查

uv run mypy pubchem_mcp/

许可证

MIT License

贡献

欢迎提交 Issue 和 Pull Request!

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选