fancyboi999/feiying-mcp
If you are the rightful owner of feiying-mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
飞影数字人 MCP 服务器是一个基于 FastMCP 框架的集成服务,提供数字人克隆、声音克隆、视频创作等功能。
avatar_tools
数字人相关工具
voice_tools
声音相关工具
video_tools
视频相关工具
audio_tools
音频相关工具
upload_tools
上传相关工具
query_tools
查询相关工具
飞影数字人 MCP 服务器
飞影数字人 MCP 服务器 是一个基于 FastMCP 框架构建的强大后端服务。它无缝集成了飞影数字人的先进 API,为大语言模型(LLM)提供了一套功能丰富的工具集,涵盖了从数字人克隆、声音复制到视频创作的全方位功能。
该项目利用 SQLAlchemy 2.0 进行异步数据库操作,并通过一个后台任务管理器自动更新任务状态,确保了系统的高效和稳定。
✨ 功能特性
- 数字人克隆:支持通过照片或视频创建个性化的数字人形象。
- 声音克隆:支持通过音频文件或文本创建和管理自定义声音。
- 视频创作:支持通过文本驱动(Text-to-Video)或音频驱动(Audio-to-Video)两种方式创作数字人视频。
- 音频创作:支持通过文本生成高质量的语音内容(Text-to-Speech)。
- 文件管理:提供文件上传接口,方便管理媒体资源。
- 状态查询:提供任务状态、数字人列表、声音列表等多种查询功能。
- 异步任务处理:所有耗时操作(如视频生成)均为异步处理,并自动更新任务状态。
🛠️ 可用工具
服务器提供以下工具,可供 LLM 或其他客户端直接调用:
数字人工具 (avatar_tools
)
create_personal_avatar_by_photo
: 通过单张照片创建个人数字人。create_personal_avatar_by_video
: 通过视频文件创建个人数字人。
声音工具 (voice_tools
)
create_voice_by_file
: 通过音频文件克隆声音。create_voice_by_text
: 通过文本创建声音(用于声音定制)。
视频创作工具 (video_tools
)
create_video_by_audio
: 使用指定的数字人和音频文件创作视频。create_video_by_script
: 使用指定的数字人和文本脚本创作视频。
音频创作工具 (audio_tools
)
create_audio_by_text
: 将文本转换为语音。
文件上传工具 (upload_tools
)
upload_file
: 上传媒体文件(音频、视频)到服务器。
查询工具 (query_tools
)
query_task_status
: 查询指定任务的当前状态和结果。query_personal_avatars
: 查询已创建的个人数字人列表。query_personal_voices
: 查询已创建的个人声音列表。query_public_avatars
: 查询公共数字人列表。query_public_voices
: 查询公共声音列表。query_video_templates
: 查询可用的视频模板。
🚀 快速开始
1. 环境要求
- Python 3.11+
- 飞影数字人 API Token
2. 安装步骤
-
克隆仓库:
git clone https://github.com/fancyboi999/feiying-mcp.git cd feiying-mcp
-
创建虚拟环境并安装依赖:
# 推荐使用 uv, an extremely fast Python package installer uv venv source .venv/bin/activate uv pip install -e . # 确保安装了 greenlet 依赖,这对 SQLAlchemy 异步操作是必需的 uv pip install greenlet
如果未使用
uv
,也可以使用venv
:python -m venv .venv source .venv/bin/activate pip install -e . pip install greenlet
-
配置环境变量: 复制示例配置文件并填入您的 API Token。
cp env.example .env
编辑
.env
文件,至少需要设置FLYWORKS_API_TOKEN
。
3. 数据库迁移
在首次运行前,请执行数据库迁移以创建所需的表结构:
alembic upgrade head
4. Docker 部署
本项目提供了 Docker 支持,可以轻松部署到容器环境或 Smithery 平台。
使用 Docker Compose 本地部署
-
构建并启动容器:
docker-compose up -d
-
查看日志:
docker-compose logs -f
-
停止服务:
docker-compose down
部署到 Smithery 平台
项目已配置好 Dockerfile
和 smithery.yaml
文件,可以直接部署到 Smithery 平台:
-
确保已经在 Smithery 平台创建了项目
-
配置环境变量: 在 Smithery 平台的项目设置中,添加必要的环境变量,特别是
FLYWORKS_API_TOKEN
。 -
部署项目: 按照 Smithery 平台的指引,将代码推送到关联的 Git 仓库,平台会自动构建和部署。
-
访问服务: 部署完成后,可以通过 Smithery 提供的 URL 访问服务。
5. 运行服务器与配置
本项目支持多种方式来运行和配置 FastMCP 服务器,以适应不同的开发和部署需求。
环境变量配置
Docker 部署时,可以通过环境变量传递配置,主要包括:
FLYWORKS_API_TOKEN
: 飞影API令牌(必需)DATABASE_URL
: 数据库连接URLSERVER_HOST
: 服务器主机地址SERVER_PORT
: 服务器端口SERVER_PATH
: API路径前缀SERVER_LOG_LEVEL
: 日志级别
命令行工具
安装后,您可以使用 feiying-mcp
命令行工具来启动服务器:
# 激活虚拟环境
source .venv/bin/activate
# HTTP 模式 (默认端口 8000)
python -m feiying_mcp.server --transport http
# 自定义主机和端口
python -m feiying_mcp.server --transport http --host 0.0.0.0 --port 8080
# SSE 模式
python -m feiying_mcp.server --transport sse
# STDIO 模式 (用于 MCP 集成)
python -m feiying_mcp.server --transport stdio
或者使用安装的命令行工具:
# HTTP 模式 (默认端口 8000)
feiying-mcp --transport http
# 自定义主机和端口
feiying-mcp --transport http --host 0.0.0.0 --port 8080
# SSE 模式
feiying-mcp --transport sse
# STDIO 模式 (用于 MCP 集成)
feiying-mcp --transport stdio
配置方式
服务器的配置项(如主机、端口等)可以通过以下三种方式设置,优先级从高到低:
- 命令行参数: 启动时直接传入参数,优先级最高。
- 配置文件: 通过
--config
参数指定一个 JSON 配置文件。 - 环境变量: 从
.env
文件中加载,通常用于存放敏感信息如 API Token。
传输协议 (Transport)
FastMCP 支持多种传输协议,您可以通过不同的子命令选择:
-
http
(默认): 启动一个基于 Streamable HTTP 的 Web 服务器。这是推荐用于 Web 服务部署的方式。# 使用默认配置 (http://127.0.0.1:8000) python -m feiying_mcp.server --transport http # 自定义主机和端口 python -m feiying_mcp.server --transport http --host 0.0.0.0 --port 8080
-
sse
: 启动一个基于 Server-Sent Events (SSE) 的服务器。这是旧版协议,新项目推荐使用http
。python -m feiying_mcp.server --transport sse
-
stdio
: 启动一个基于标准输入/输出的服务器。这主要用于与 MCP 客户端集成。python -m feiying_mcp.server --transport stdio
命令行参数
您可以使用以下参数来配置服务器的运行:
--transport <type>
: 传输协议类型,可选http
,sse
,stdio
。--host <address>
: 服务器监听的主机地址 (默认为127.0.0.1
)。--port <number>
: 服务器监听的端口 (默认为8000
)。--path <url_path>
: HTTP 模式下的 URL 路径 (默认为/api
)。--log-level <level>
: 设置日志级别 (debug
,info
,warning
,error
,critical
)。--config <file>
: 指定配置文件路径。
客户端连接配置
Cursor IDE 集成
Cursor IDE 支持通过 MCP 协议与飞影数字人服务器集成。配置步骤如下:
- 编辑 Cursor 的 MCP 配置文件 (
~/.cursor/mcp.json
):
{
"mcpServers": {
"feiying-mcp": {
"command": "uvx",
"args": ["feiying-mcp", "--transport", "stdio"],
"env": {
"FLYWORKS_API_TOKEN": "你的API令牌"
}
}
}
}
-
确保飞影数字人服务器已经安装并配置正确
-
在 Cursor 中选择 "feiying-mcp" 作为 MCP 服务器
远程连接 (HTTP)
如果您需要将服务部署为网络服务,可以使用 HTTP 连接。
-
启动服务器:
python -m feiying_mcp.server --transport http --host 0.0.0.0 --port 8000
-
配置客户端: 在客户端的配置文件中,添加一个指向您服务器 URL 的条目。
{ "mcpServers": { "feiying-mcp-remote": { "transport": "http", "url": "http://your-server-ip:8000/api" } } }
注意: 请将
your-server-ip
替换为运行服务器的机器的实际 IP 地址或域名。
完成配置并重启客户端后,即可连接到飞影数字人 MCP 服务器。
⚙️ 项目结构
feiying-mcp/
├── feiying_mcp/ # Python 包目录
│ ├── __init__.py # 包初始化文件
│ └── server.py # 服务器实现
│ ├── utils/ # 工具类目录
│ │ ├── config.py # 配置管理模块
│ │ ├── database.py # 数据库会话管理
│ │ ├── models.py # SQLAlchemy 数据库模型定义
│ │ ├── api_client.py # 飞影 API 客户端封装
│ │ └── task_manager.py # 后台任务状态更新管理器
│ └── tools/ # MCP 工具目录
│ ├── avatar_tools.py # 数字人相关工具
│ ├── voice_tools.py # 声音相关工具
│ ├── video_tools.py # 视频相关工具
│ ├── audio_tools.py # 音频相关工具
│ ├── upload_tools.py # 上传相关工具
│ └── query_tools.py # 查询相关工具
├── migrations/ # Alembic 数据库迁移脚本
├── pyproject.toml # 项目元数据和构建配置
├── requirements.txt # 项目依赖
└── README.md # 项目文档
📄 许可证
本项目采用 授权。
如有任何问题,欢迎提交 Issue 或联系项目维护者。