mcp-server-echart
If you are the rightful owner of mcp-server-echart 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-server-echart is a Go-based service for dynamically generating ECharts chart pages.
mcp-server-echart
一个基于 mcp-go
框架构建的 Go 服务,它提供了一个能动态生成 ECharts 图表页面的工具。
✨ 功能特性
- 动态图表生成:通过调用工具,传入 ECharts 的 JSON 配置,即可生成一个独立的 HTML 图表页面。
- 高度可配置:支持自定义图表的标题、宽度和高度。
- 现代化页面:生成的图表页面拥有一个干净、现代化的外观。
- Docker 支持:提供
Dockerfile
,可以轻松构建轻量、可移植的 Docker 镜像。 - 配置灵活:通过环境变量或
.env
文件进行配置,轻松适配不同环境。
🚀 快速开始
1. 准备工作
2. 克隆与配置
克隆本仓库到您的本地:
git clone https://github.com/cnkanwei/mcp-server-echart.git
cd mcp-server-echart
复制配置文件模板,并根据需要进行修改:
cp .env.example .env
.env
文件包含以下配置项:
PORT
: 服务监听的端口 (默认:8989
)PUBLIC_URL
: 对外暴露的 URL 根路径 (例如http://localhost:8989
或https://your.domain.com
)LOG_LEVEL
: 日志级别 (例如info
,debug
)STATIC_DIR
: 生成的静态 HTML 文件存放的目录 (默认:static
)
3. 安装依赖
go mod tidy
📦 如何运行
在本地运行
go run main.go
服务启动后,会监听在 .env
文件中配置的 PORT
端口(默认为 8989)。
使用 Docker 运行
-
构建 Docker 镜像:
docker build -t mcp-server-echart .
-
运行 Docker 容器:
# 基础运行 docker run -p 8989:8989 -d --name my-echart-server mcp-server-echart # 自定义端口和对外 URL docker run -p 9090:9090 \ -e PORT=9090 \ -e PUBLIC_URL="https://my.domain.com" \ -d --name my-echart-server mcp-server-echart
🛠️ 工具 (Tool) API
本服务提供了一个名为 generate_echarts_page
的工具。
参数
title
(string, 必需): 图表页面的标题。inputSchema
(object, 必需): ECharts 的 JSON 配置对象。width
(number, 可选): 图表的宽度(像素),默认 800。height
(number, 可选): 图表的高度(像素),默认 600。
返回值
成功调用后,工具会返回一个 URL,指向新生成的图表页面。
💻 如何使用
本服务可以通过任何支持 Server-Sent Events (SSE) 的 MCP 客户端进行调用。
客户端配置
如果您使用的 MCP 客户端支持通过配置文件连接到服务器,您可以添加如下配置来连接到本服务。
请将 mcp-server-echart
添加到您的客户端配置中,并将 URL 指向本服务的监听地址(默认为 http://localhost:8989/sse
)。
示例配置 (client-config.json
):
{
"mcpServers": {
"mcp-server-echart": {
"url": "http://localhost:8989/sse"
}
}
}
另一个示例 (例如,用于浏览器环境):
{
"mcpServers": {
"browser-use-mcp-server": {
"url": "http://localhost:8000/sse"
}
}
}
注意:
- URL 应与您在
.env
文件中配置的PORT
和PUBLIC_URL
保持一致。mcp-go
工具调用的默认端点是/sse
,而不是/
。
客户端配置 (通过 Docker 命令)
如果您的 MCP 客户端支持通过命令启动服务,您也可以配置它来直接运行 Docker Hub 上的镜像。这会将服务作为一个子进程来管理,客户端通过标准输入/输出 (stdin/stdout) 与其通信。
这对于本地开发或将服务分发给他人使用非常方便。
示例配置 (client-config.json
):
{
"mcpServers": {
"mcp-server-echart-docker": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-p",
"8989:8989",
"-e",
"PORT=8989",
"-e",
"PUBLIC_URL=http://localhost:8989",
"cnkanwei/mcp-server-echart:latest"
]
}
}
}
注意:
-p 8989:8989
将容器的 8989 端口映射到主机的 8989 端口,以便您可以从浏览器访问生成的图表。cnkanwei/mcp-server-echart:latest
是发布在 Docker Hub 上的公共镜像。
📜 许可证
本项目基于 开源。