A Model Context Protocol (MCP) server for Chrome browser automation via debugging protocol, specifically designed to connect to Chrome debugging ports and enable browser automation with persistent login sessions.
-
π§ Zero-Dependency Deployment
- No Chrome extensions required
- No Chrome Web Store approval needed
- Fully autonomous in enterprise environments
-
π¦ Container-Friendly
- Perfect support for Docker/Kubernetes deployment
- No extension permission or installation issues
- Ideal for cloud-native architecture
-
β‘ Two-Step Launch
# Launch with just two commands # 1. Start Chrome in debug mode /Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222 --user-data-dir=/tmp/chrome-debug # 2. Run MCP server npx chrome-debug-mcp
-
π‘οΈ Enterprise-Grade Security
- Based on standard Chrome DevTools Protocol
- No third-party extension permissions required
- Complete local operation
Launch with npx - no installation required:
# 1. Start Chrome in debug mode
/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222 --user-data-dir=/tmp/chrome-debug
# 2. Run MCP server directly
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
- β Chrome Debug Port Connection: Based on standard Chrome DevTools Protocol, no extensions required
- π’ Enterprise-Grade Deployment: Zero-dependency deployment, no Chrome Web Store approval needed
- π± Intelligent Tab Management: Reuse tabs for same domains, avoid duplicate openings
- πΌοΈ Real-time Screenshot Feedback: Automatic screenshots after each operation for visual feedback
- π Network Activity Monitoring: Auto-wait for page load completion
- π³ Native Docker Support: Perfect support for containerized Chrome instances, no extension limitations
- β‘ Two-Step Launch: Start Chrome in debug mode then run
npx chrome-debug-mcp
, no complex installation required - π Smart Browser Discovery: Auto-discover Chrome instances in local and Docker environments
The server needs to connect to a Chrome instance with debugging port enabled:
# 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
Important Notes:
--user-data-dir
parameter points to a temporary directory, ensuring Chrome starts in debug mode- After startup, you can log into websites normally, and login sessions will be preserved
- The server will reuse this Chrome instance, no need to re-login
Add the following configuration to your MCP client:
{
"mcpServers": {
"browser-automation": {
"command": "npx",
"args": ["chrome-debug-mcp"]
}
}
}
That's it! No installation, no downloads, no complex path configuration needed.
π‘ Alternative Installation Methods:
Global Installation:
npm install -g chrome-debug-mcp{ "mcpServers": { "browser-automation": { "command": "chrome-debug-mcp" } } }Local Project Installation:
npm install chrome-debug-mcp{ "mcpServers": { "browser-automation": { "command": "npx", "args": ["chrome-debug-mcp"] } } }
Connect to Chrome debug port and initialize browser session.
{
"name": "launch_browser",
"arguments": {
"remote_host": "http://localhost:9222" // optional
}
}
Navigate to specified URL with intelligent tab management.
{
"name": "navigate_to",
"arguments": {
"url": "https://example.com"
}
}
Click at specified coordinates.
{
"name": "click",
"arguments": {
"coordinate": "100,200"
}
}
Input text content.
{
"name": "type_text",
"arguments": {
"text": "Hello World"
}
}
Scroll the page.
{
"name": "scroll_down",
"arguments": {}
}
Hover mouse at specified position.
{
"name": "hover",
"arguments": {
"coordinate": "100,200"
}
}
Resize browser window.
{
"name": "resize_browser",
"arguments": {
"size": "1200,800"
}
}
Get current page HTML content.
{
"name": "get_page_content",
"arguments": {}
}
Close browser connection.
{
"name": "close_browser",
"arguments": {}
}
# Manually log into Twitter/Weibo in Chrome first
# Then use MCP tools for automation
launch_browser -> navigate_to -> click -> type_text
# Keep logged-in state for Taobao/JD
# Automate product search, price monitoring, etc.
launch_browser -> navigate_to -> type_text -> click
# Scrape data from login-required websites
# Bypass login verification, direct operations
launch_browser -> navigate_to -> get_page_content
- Same domains (e.g.,
example.com
) reuse existing tabs - Different domains automatically create new tabs
- Avoid duplicate openings of same websites
- Monitor network activity, wait for complete page loading
- HTML content stability detection
- Automatic handling of dynamic content loading
- Auto-reconnect on connection drops
- Cache successful connection endpoints
- Detailed error logs and feedback
If Chrome runs in a Docker container:
# Start Chrome in Docker
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
The server will automatically discover Chrome instances in Docker environments.
- Confirm Chrome is started with
--remote-debugging-port=9222
- Check if port 9222 is occupied:
lsof -i :9222
- Ensure no other Chrome instances are running
- Check network connection
- Increase page load timeout
- Confirm target website is accessible
- Confirm page is fully loaded
- Check browser window size settings
- Try refreshing page and retry operation
MCP Client ββ stdio ββ MCP Server ββ Chrome Debug Port ββ Chrome Browser
- Transport Protocol: stdio (standard input/output)
- Browser Engine: Puppeteer + Chrome DevTools Protocol
- Connection Method: WebSocket (Chrome debug port)
- Image Format: WebP/PNG base64 encoding
# Watch mode compilation
npm run dev
# View MCP communication logs
DEBUG=mcp* npm start
# Build project
npm run build
# Publish to npm
npm publish
This project's design philosophy and core concepts were inspired by the RooCode project. RooCode is an excellent browser automation MCP server implementation that provided valuable technical references and design insights.
Special thanks to the RooCode team for their contributions in the following areas:
- π― MCP Protocol Integration: Provided technical solutions for combining MCP servers with browser automation
- π Browser Connection: Demonstrated elegant browser connection and session management
- π Tool API Design: Provided reference frameworks for standardizing browser operations
Building upon RooCode's foundation, this project further focuses on browser automation with persistent login sessions, achieving more practical automation capabilities by connecting to existing Chrome debug ports to maintain user sessions.
MIT License
Core Advantage: The biggest feature of this MCP server is its ability to connect to existing Chrome instances and maintain login sessions, making it ideal for automation scenarios requiring user authentication. Through Chrome debug ports, it can take over user-logged browser sessions, achieving true "session-persistent" browser automation.