mcpHydroSSH
An SSH MCP server that enables users to connect to and manage remote servers directly from Claude Code. It provides tools to execute commands, monitor connection status, and dynamically manage server configurations through natural language.
README
mcp-hydrocoder-ssh
中文 | English | Configuration Guide | 配置指南
MCP server that provides SSH remote connection capabilities for Claude Code. Connect to remote servers, execute commands, and automate deployments without needing a separate SSH terminal.
Part 1: Features
What is this?
mcp-hydrocoder-ssh is an MCP (Model Context Protocol) server that enables Claude Code to:
- 🔌 Connect to remote SSH servers directly (persistent background connections)
- ⚡ Execute commands and get complete output
- 🔄 Maintain connection state for multi-step operations
- 🚀 Run deployment scripts (git pull, npm install, systemctl restart, etc.)
Key Benefits
| Benefit | Description |
|---|---|
| No window switching | Complete all remote operations within Claude Code conversation |
| Smart deployment | Claude can auto-determine next steps based on command output |
| Multi-server management | Manage multiple server configs, switch quickly |
| Secure authentication | Support SSH agent, key files |
| Connection pooling | Maintain persistent connections, avoid re-authentication overhead |
Available Tools
SSH Connection Tools (5):
ssh_list_servers- List all configured serversssh_connect- Connect to a serverssh_exec- Execute commands (with working directory support)ssh_get_status- Get connection statusssh_disconnect- Disconnect from server
Configuration Management Tools (5):
ssh_add_server- Add new server configurationssh_remove_server- Remove server configurationssh_update_server- Update server configurationssh_view_config- View config (filters sensitive info)ssh_help- Show help information
Part 2: Installation
One-Line Installation (Easiest, Recommended)
claude mcp add hydrossh npx mcp-hydrocoder-ssh@latest
Restart Claude Code and you're done!
Option 2: Global Installation
npm install -g mcp-hydrocoder-ssh
claude mcp add hydrossh mcp-hydrocoder-ssh
Option 3: Manual JSON Configuration
Edit ~/.claude.json:
Windows path: C:\Users\<YourUsername>\.claude.json
macOS/Linux path: ~/.claude.json
{
"mcpServers": {
"hydrossh": {
"command": "npx",
"args": ["-y", "mcp-hydrocoder-ssh@latest"]
}
}
}
Note:
hydrosshis the server identifier, can be changed to any name you prefer.-yflag lets npx auto-confirm installation, avoiding interactive prompts.
Verify Installation
In Claude Code, enter:
List available SSH servers
If you see a server list (empty list means no servers configured yet), the installation was successful.
Part 3: Using from Source Code
1. Clone Repository
git clone https://github.com/hydroCoderClaud/mcpHydroSSH.git
cd mcpHydroSSH
2. Install Dependencies
npm install
3. Build
npm run build
Build output goes to dist/ directory:
dist/index.js- MCP server entry pointdist/ssh-manager.js- SSH connection managementdist/config.js- Configuration management
4. Configure Claude Code
Edit ~/.claude.json:
{
"mcpServers": {
"hydrossh": {
"command": "node",
"args": ["<absolute-path>/dist/index.js"]
}
}
}
Note: Replace
<absolute-path>with your actual source directory absolute path.
5. Restart Claude Code
Close and reopen Claude Code.
6. Development Mode (Optional)
For hot-reload development:
npm run dev
Then configure Claude Code with:
{
"mcpServers": {
"hydrossh": {
"command": "npx",
"args": ["tsx", "<absolute-path>/src/index.ts"]
}
}
}
Appendix A: SSH Configuration
Configuration file location: ~/.hydrossh/config.json
Auto-created on first run: The ~/.hydrossh/ directory and config file are automatically created when the MCP server first starts.
Quick Add via Claude Code
After installation, you can add server configs using natural language commands.
Configuration Example
{
"servers": [
{
"id": "prod-server",
"name": "Production Server",
"host": "example.com",
"port": 22,
"username": "deploy",
"authMethod": "agent"
},
{
"id": "test-server",
"name": "Test Server",
"host": "test.example.com",
"username": "ubuntu",
"authMethod": "key",
"privateKeyPath": "~/.ssh/id_rsa"
}
],
"settings": {
"defaultConnectTimeout": 30000,
"defaultKeepaliveInterval": 60000,
"commandTimeout": 60000,
"maxConnections": 5,
"logCommands": true
}
}
Authentication Methods
| Method | Configuration | Description |
|---|---|---|
| SSH Agent | "authMethod": "agent" |
Recommended, uses system SSH agent |
| Key File | "authMethod": "key", "privateKeyPath": "~/.ssh/id_rsa" |
Default, reads private key file |
| Password | "authMethod": "password", "password": "xxx" |
Not recommended, password stored in plaintext |
See CONFIG-GUIDE_EN.md for details.
Appendix B: Usage Examples
Basic Usage
User: List available servers
Claude: Found 2 configured servers: prod-server, test-server
User: Connect to prod-server
Claude: [ssh_connect] Connected! connectionId: xxx
User: Execute command: uptime
Claude: [ssh_exec] Returns: up 30 days, 2 users, load average: 0.1, 0.2, 0.5
User: Disconnect
Claude: [ssh_disconnect] Disconnected
Automated Deployment
User: Deploy latest code to production server
Claude: Okay, I'll execute the deployment flow...
1. Connect to prod-server
2. cd /opt/myapp && git pull
3. npm ci --production
4. sudo systemctl restart myapp
5. Check service status
6. Disconnect
Deployment complete!
Appendix C: Security Notes
- 🔒 SSH Agent Recommended - Prefer
authMethod: "agent" - 🔒 Config File Permissions - Ensure
~/.hydrossh/config.jsonis readable only by you - 🔒 Config Viewing -
ssh_view_configtool automatically filters passwords and key paths
Appendix D: Troubleshooting
| Issue | Solution |
|---|---|
| SSH Agent not running | Windows: Start "OpenSSH Authentication Agent" service |
| Connection timeout | Check server address, port, network connectivity |
| Command not found | Verify npm global install or check PATH environment variable |
| Config not loaded | Check if ~/.claude.json format is correct |
| Config file not found | Auto-created on first run, or manually create ~/.hydrossh/config.json |
Appendix E: Command Reference
Development Commands
npm run build # Build TypeScript
npm run dev # Development mode (hot reload)
npm test # Run tests
npm run lint # Code linting
npm run format # Code formatting
MCP Tool Parameters
| Tool | Parameters | Description |
|---|---|---|
ssh_list_servers |
none | List all configured servers |
ssh_connect |
serverId, timeout? |
Connect to server |
ssh_exec |
command, connectionId?, timeout?, cwd? |
Execute command |
ssh_get_status |
connectionId? |
Get connection status (all if not specified) |
ssh_disconnect |
connectionId? |
Disconnect (most recent if not specified) |
ssh_add_server |
id, name, host, username, port?, authMethod?, privateKeyPath?, password? |
Add server config |
ssh_remove_server |
serverId |
Remove server config |
ssh_update_server |
serverId, name?, host?, port?, username?, authMethod?, privateKeyPath?, password? |
Update server config |
ssh_view_config |
none | View config (filters sensitive info) |
ssh_help |
topic? |
Show help information |
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.