一个用于与 MySQL 数据库交互的 MCP 服务器。
该服务器支持执行只读查询(query)和最终会被回滚的写查询(test_execute)。
将以下环境变量添加到 ~/.mcp/.env
文件中:
MYSQL_HOST=host.docker.internal # Hostname to access host services from Docker container MYSQL_PORT=3306 MYSQL_USER=root MYSQL_PASSWORD=your_password
注意:
host.docker.internal
是一个特殊的 DNS 名称,用于从 Docker 容器访问主机服务。 当连接到运行在您主机上的 MySQL 服务器时,请使用此设置。 如果连接到其他 MySQL 服务器,请更改为主机名。
{
"mcpServers": {
"mysql": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"--add-host=host.docker.internal:host-gateway",
"--env-file",
"/Users/username/.mcp/.env",
"ghcr.io/xiangma9712/mcp/mysql"
]
}
}
}

docker run -i --rm --add-host=host.docker.internal:host-gateway --env-file ~/.mcp/.env ghcr.io/xiangma9712/mcp/mysql

注意:如果您使用 OrbStack,
host.docker.internal
会自动支持,因此可以省略--add-host
选项。 虽然 Docker Desktop 通常也会自动支持这一点,但为了更好的可靠性,建议添加--add-host
选项。
{
"type": "query",
"payload": {
"sql": "SELECT * FROM your_table"
}
}

响应:
{
"success": true,
"data": [
{
"id": 1,
"name": "example"
}
]
}

{
"type": "test_execute",
"payload": {
"sql": "UPDATE your_table SET name = 'updated' WHERE id = 1"
}
}

响应:
{
"success": true,
"data": "The UPDATE SQL query can be executed."
}

{
"type": "list_tables"
}

响应:
{
"success": true,
"data": ["table1", "table2", "table3"]
}

{
"type": "describe_table",
"payload": {
"table": "your_table"
}
}

响应:
{
"success": true,
"data": [
{
"Field": "id",
"Type": "int(11)",
"Null": "NO",
"Key": "PRI",
"Default": null,
"Extra": ""
},
{
"Field": "name",
"Type": "varchar(255)",
"Null": "YES",
"Key": "",
"Default": null,
"Extra": ""
}
]
}

host.docker.internal
连接到主机 MySQL(兼容 OrbStack 和 Docker Desktop)