Chrome Debug MCP 服务器是一个基于调试协议的浏览器自动化工具,它借助 Chrome 的调试端口,能够连接到已有的 Chrome 实例并保持登录会话,为需要用户认证的自动化场景提供了理想的解决方案。
使用 npx 启动,无需安装:
# 1. 以调试模式启动 Chrome
/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222 --user-data-dir=/tmp/chrome-debug
# 2. 直接运行 MCP 服务器
npx chrome-debug-mcp
git clone https://github.com/rainmenxia/chrome-debug-mcp.git
cd chrome-debug-mcp
npm install
npm run build
npm start
npx chrome-debug-mcp,无需复杂安装。服务器需要连接到启用了调试端口的 Chrome 实例:
# macOS
/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222 --user-data-dir=/tmp/chrome-debug
# Windows
chrome.exe --remote-debugging-port=9222 --user-data-dir=c:\temp\chrome-debug
# Linux
google-chrome --remote-debugging-port=9222 --user-data-dir=/tmp/chrome-debug
⚠️ 重要提示
--user-data-dir参数指向一个临时目录,确保 Chrome 以调试模式启动。- 启动后,您可以正常登录网站,登录会话将被保留。
- 服务器将复用此 Chrome 实例,无需重新登录。
在您的 MCP 客户端中添加以下配置:
{
"mcpServers": {
"browser-automation": {
"command": "npx",
"args": ["chrome-debug-mcp"]
}
}
}
🎉 完成!无需安装、下载,也无需复杂的路径配置。
💡 其他安装方法
全局安装:
npm install -g chrome-debug-mcp{ "mcpServers": { "browser-automation": { "command": "chrome-debug-mcp" } } }本地项目安装:
npm install chrome-debug-mcp{ "mcpServers": { "browser-automation": { "command": "npx", "args": ["chrome-debug-mcp"] } } }
launch_browser连接到 Chrome 调试端口并初始化浏览器会话。
{
"name": "launch_browser",
"arguments": {
"remote_host": "http://localhost:9222" // 可选
}
}
navigate_to使用智能标签管理导航到指定 URL。
{
"name": "navigate_to",
"arguments": {
"url": "https://example.com"
}
}
click在指定坐标处点击。
{
"name": "click",
"arguments": {
"coordinate": "100,200"
}
}
type_text输入文本内容。
{
"name": "type_text",
"arguments": {
"text": "Hello World"
}
}
scroll_down / scroll_up滚动页面。
{
"name": "scroll_down",
"arguments": {}
}
hover将鼠标悬停在指定位置。
{
"name": "hover",
"arguments": {
"coordinate": "100,200"
}
}
resize_browser调整浏览器窗口大小。
{
"name": "resize_browser",
"arguments": {
"size": "1200,800"
}
}
get_page_content获取当前页面的 HTML 内容。
{
"name": "get_page_content",
"arguments": {}
}
close_browser关闭浏览器连接。
{
"name": "close_browser",
"arguments": {}
}
# 先在 Chrome 中手动登录 Twitter/微博
# 然后使用 MCP 工具进行自动化操作
launch_browser -> navigate_to -> click -> type_text
# 保持淘宝/京东的登录状态
# 自动进行商品搜索、价格监控等操作
launch_browser -> navigate_to -> type_text -> click
# 从需要登录的网站抓取数据
# 绕过登录验证,直接进行操作
launch_browser -> navigate_to -> get_page_content
example.com)复用现有标签页。如果 Chrome 在 Docker 容器中运行:
# 在 Docker 中启动 Chrome
docker run -d --name chrome-debug \
-p 9222:9222 \
--shm-size=2gb \
zenika/alpine-chrome \
--no-sandbox \
--disable-dev-shm-usage \
--remote-debugging-address=0.0.0.0 \
--remote-debugging-port=9222
服务器将自动发现 Docker 环境中的 Chrome 实例。
--remote-debugging-port=9222 启动。lsof -i :9222。MCP Client ←→ stdio ←→ MCP Server ←→ Chrome Debug Port ←→ Chrome Browser
# 监听模式编译
npm run dev
# 查看 MCP 通信日志
DEBUG=mcp* npm start
# 构建项目
npm run build
# 发布到 npm
npm publish
本项目的设计理念和核心概念受到了 RooCode 项目的启发。RooCode 是一个优秀的浏览器自动化 MCP 服务器实现,为我们提供了宝贵的技术参考和设计思路。
特别感谢 RooCode 团队在以下方面的贡献:
在 RooCode 的基础上,本项目进一步专注于 保持登录会话的浏览器自动化,通过连接到现有的 Chrome 调试端口来维护用户会话,实现了更实用的自动化功能。
本项目采用 MIT 许可证。
核心优势:这个 MCP 服务器的最大特点是能够连接到现有的 Chrome 实例并保持登录会话,非常适合需要用户认证的自动化场景。通过 Chrome 调试端口,它可以接管用户已登录的浏览器会话,实现真正的“会话持久化”浏览器自动化。