Arthas MCP Proxy
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Arthas MCP ProxySSH to 192.168.1.100, list Java processes and thread dump for PID 1234"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Arthas MCP Proxy
MCP Server for JVM diagnostics via SSH + Arthas.
Provides 26+ diagnostic tools through the Model Context Protocol (MCP), enabling AI assistants to perform thread dumps, heap analysis, method tracing, CPU profiling, and more on remote Java processes.
Features
Full Arthas command suite —
thread,trace,watch,heapdump,profiler,jad, etc.Multi-target SSH — connect to multiple JVM hosts from a single server
Cross-user diagnosis — automatically uses
sudo -u <owner>when SSH user != process ownerConcurrent-safe — per-PID attach locks + three-level reuse (cache → detect → attach)
SSE & stdio transports — works with Cursor, Claude Desktop, and other MCP clients
Quick Start
Docker (recommended)
docker run -p 8000:8000 ghcr.io/narcissux/arthas-mcp-proxy:latestFrom source
git clone https://github.com/narcissux/arthas-mcp-proxy.git
cd arthas-mcp-proxy
pip install -e ".[dev]"
python -m arthas_mcp_proxy --transport sse --port 8000Cursor / MCP Client configuration
{
"mcpServers": {
"arthas": {
"url": "http://localhost:8000/sse"
}
}
}Available Tools
Tool | Purpose |
| Establish SSH connection to target server |
| List Java processes with Arthas status |
| Thread dump (top N by CPU) |
| Memory dashboard |
| Watch method params/return values |
| Universal Arthas command executor (26+ commands) |
| Install Arthas on target server |
| Disconnect and release resources |
Development
Running tests
# Unit tests only (mocked, no external dependencies)
pytest tests/ --ignore=tests/integration/
# Integration tests with auto-managed Docker target (recommended)
pytest tests/integration/ -m integration -v --docker-target
# Integration tests against a remote target (env vars required)
export TEST_SSH_HOST=your-server
export TEST_SSH_USER=your-username
export TEST_SSH_PASSWORD=your-password
pytest tests/integration/ -m integration -v
# Manual two-step Docker target
docker compose -f docker-compose.test.yml up --build -d
export TEST_SSH_HOST=localhost TEST_SSH_USER=testuser TEST_SSH_PASSWORD=testpass
pytest tests/integration/ -m integration -v
docker compose -f docker-compose.test.yml down --volumesCode quality
# Install dev dependencies
pip install -e ".[dev]"
# Run lint
ruff check src/ tests/
ruff format --check src/ tests/
# Run type check
mypy src/arthas_mcp_proxy
# Run tests
pytest -v
# Run with coverage
pytest --cov=arthas_mcp_proxy --cov-report=htmlProject Structure
.
├── src/
│ └── arthas_mcp_proxy/
│ ├── __init__.py # Package init
│ ├── __main__.py # python -m arthas_mcp_proxy
│ ├── server.py # MCP server & tools
│ ├── arthas_client.py # Arthas attach & command execution
│ ├── ssh_pool.py # SSH connection pool
│ └── decorators.py # @require_session and other decorators
├── tests/
│ ├── conftest.py # Shared fixtures (mock SSH session, state cleanup)
│ ├── test_decorators.py # @require_session tests
│ ├── test_arthas_client.py # Concurrency & logic tests
│ ├── test_ssh_pool.py # Connection pool tests
│ └── integration/
│ ├── conftest.py # Integration env validation & Docker check
│ └── test_real_jvm.py # Real JVM diagnostic tests via SSH
├── pyproject.toml # Project config, deps, tool settings
├── entrypoint.sh # Test target container startup script
├── Dockerfile
├── docker-compose.yml # Production deployment
├── docker-compose.test.yml # Test infrastructure (SSH + Java container)
├── Dockerfile.test-target # Test target image (Java + math-game.jar)
└── README.mdTest categories
Category | Command | Requirements |
Unit tests |
| None (fully mocked) |
Integration (remote) |
| SSH target with Java |
Integration (Docker) |
| Docker daemon |
Environment variables for integration tests
Variable | Required | Default | Description |
| Yes | — | Target hostname or IP |
| Yes | — | SSH username |
| Yes | — | SSH password |
| No | 22 | SSH port |
| No | auto | Specific PID to diagnose |
Security: Never commit credentials. Use environment variables or a .env
file (ignored by .gitignore).
License
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/narcissux/arthas-mcp-proxy'
If you have feedback or need assistance with the MCP directory API, please join our Discord server