Amadeus-QQ-MCP
An MCP server that enables AI clients to send and receive QQ messages through NapCatQQ (OneBot v11) for both private and group chats. It supports message context management, real-time WebSocket listening, and human-like typing simulation.
README
Amadeus-QQ-MCP
MCP Server,通过 NapCatQQ (OneBot v11) 让 AI 客户端收发 QQ 消息。支持群聊和私聊。
功能
- 6 个 MCP 工具:
check_status、get_group_list、get_recent_context、batch_get_recent_context、send_message、compress_context - WebSocket 实时消息监听 + 自动重连
- 消息按自然语义分段发送(句号/逗号/破折号等),模拟真人打字节奏
- 群/好友白名单控制
- 发送速率限制(3s/目标)
前置条件
- Docker
- Python 3.11+
- uv
运行
0. 安装 Docker 和 NapCat
安装 Docker:
# macOS — 安装 Docker Desktop
brew install --cask docker
# Ubuntu
curl -fsSL https://get.docker.com | sh
sudo usermod -aG docker $USER # 免 sudo 运行 docker
# 重新登录终端生效
安装 NapCat:
本项目使用 NapCatQQ 的 Docker 镜像作为 QQ 协议端。项目的 docker-compose.yml 已配置好镜像,首次运行 docker compose up -d 时会自动拉取,无需手动安装。
1. 启动 NapCat
docker compose up -d
首次启动需扫码登录,查看二维码:
docker compose logs -f napcat
Ubuntu 服务器:需设置 UID/GID 匹配宿主用户
NAPCAT_UID=1000 NAPCAT_GID=1000 docker compose up -dmacOS 默认值 (501:20) 无需设置。
登录后建议在 napcat/config/webui.json 中设置 "autoLoginAccount": "你的QQ号",避免重启后重新扫码。
2. 安装依赖 & 启动 MCP Server
# 安装依赖
uv sync
# 启动(最小参数)
uv run qq-agent-mcp --qq 你的QQ号
# 指定监听群和好友
uv run qq-agent-mcp --qq 你的QQ号 --groups 群号1,群号2 --friends 好友QQ1,好友QQ2
# 全部参数
uv run qq-agent-mcp --qq 你的QQ号 \
--napcat-host 127.0.0.1 \
--napcat-port 3000 \
--ws-port 3001 \
--groups 群号1,群号2 \
--friends 好友QQ1 \
--buffer-size 100 \
--log-level info
3. 配置 MCP 客户端
在 AI 客户端(PetGPT、Claude Desktop 等)中添加:
{
"name": "QQ Agent",
"transport": "stdio",
"command": "uv",
"args": [
"run", "--directory", "/path/to/qq-mcp",
"qq-agent-mcp",
"--qq", "你的QQ号",
"--groups", "群号1,群号2"
]
}
或全局安装后直接用:
uv tool install /path/to/qq-mcp
{
"name": "QQ Agent",
"transport": "stdio",
"command": "qq-agent-mcp",
"args": ["--qq", "你的QQ号", "--groups", "群号1,群号2"]
}
CLI 参数
| 参数 | 默认值 | 说明 |
|---|---|---|
--qq (必填) |
— | 机器人 QQ 号 |
--napcat-host |
127.0.0.1 |
NapCat HTTP 地址 |
--napcat-port |
3000 |
NapCat HTTP 端口 |
--ws-port |
3001 |
NapCat WebSocket 端口 |
--groups |
全部 | 监听的群号(逗号分隔) |
--friends |
无 | 监听的好友 QQ(逗号分隔) |
--buffer-size |
100 |
每个目标的消息缓冲区大小 |
--log-level |
info |
日志级别 |
MCP 工具
| 工具 | 说明 |
|---|---|
check_status |
检查 QQ 登录状态、在线状态、缓冲区统计 |
get_group_list |
获取已加入的群列表 |
get_recent_context(target, target_type?, limit?) |
获取消息上下文(JSON 格式,含 is_self/is_at_me 标记) |
batch_get_recent_context(targets, limit?) |
批量查询多个群/好友的消息上下文(最多 2 次 API 调用) |
send_message(target, content, target_type?, reply_to?) |
发消息,自动分段+打字延迟 |
compress_context(target, target_type?) |
手动压缩历史消息为摘要 |
架构
MCP Client (stdio)
↕ JSON-RPC
qq-agent-mcp (Python)
├── HTTP API → NapCat (OneBot v11) → QQ
└── WebSocket ← NapCat (消息事件)
↓
Message Buffer (滑动窗口)
目录结构
qq-mcp/
├── src/qq_agent_mcp/ # MCP Server 源码
├── napcat/ # NapCat Docker 挂载目录(见 napcat/README.md)
├── docker-compose.yml # NapCat 容器配置
├── pyproject.toml # Python 项目配置
└── test_mcp.py # 集成测试
License
MIT
Amadeus-QQ-MCP
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。
mcp-server-qdrant
这个仓库展示了如何为向量搜索引擎 Qdrant 创建一个 MCP (Managed Control Plane) 服务器的示例。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。