devnullvoid/mcp-ssh-session
If you are the rightful owner of mcp-ssh-session and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
An MCP server that facilitates AI agents in managing persistent SSH sessions.
MCP SSH Session
An MCP (Model Context Protocol) server that enables AI agents to establish and manage persistent SSH sessions.
Features
- Persistent Sessions: SSH connections are reused across multiple command executions
- SSH Config Support: Automatically reads and uses settings from
~/.ssh/config
- Multi-host Support: Manage connections to multiple hosts simultaneously
- Automatic Reconnection: Dead connections are detected and automatically re-established
- Thread-safe: Safe for concurrent operations
- Network Device Support: Automatic enable mode handling for routers and switches
- Sudo Support: Automatic password handling for sudo commands on Unix/Linux hosts
Installation
Using Claude Code
Add to your ~/.claude.json
:
{
"mcpServers": {
"ssh-session": {
"type": "stdio",
"command": "uvx",
"args": ["uvx git+https://github.com/devnullvoid/mcp-ssh-session.git"],
"env": {}
}
}
}
Replace /path/to/mcp-ssh-session
with the actual path to this project.
Using MCP Inspector
npx @modelcontextprotocol/inspector uvx --from /path/to/mcp-ssh-session mcp-ssh-session
Development Installation
uv venv
source .venv/bin/activate
uv pip install -e .
Usage
Available Tools
execute_command
Execute a command on an SSH host using a persistent session.
Using SSH config alias:
{
"host": "myserver",
"command": "uptime"
}
Using explicit parameters:
{
"host": "example.com",
"username": "user",
"command": "ls -la",
"key_filename": "~/.ssh/id_rsa",
"port": 22
}
Network device with enable mode:
{
"host": "router.example.com",
"username": "admin",
"password": "ssh_password",
"enable_password": "enable_password",
"command": "show running-config"
}
Unix/Linux with sudo:
{
"host": "server.example.com",
"username": "user",
"sudo_password": "user_password",
"command": "systemctl restart nginx"
}
list_sessions
List all active SSH sessions.
close_session
Close a specific SSH session.
{
"host": "myserver"
}
close_all_sessions
Close all active SSH sessions.
SSH Config Support
The server automatically reads ~/.ssh/config
and supports:
- Host aliases
- Hostname mappings
- Port configurations
- User specifications
- IdentityFile settings
Example ~/.ssh/config
:
Host myserver
HostName example.com
User myuser
Port 2222
IdentityFile ~/.ssh/id_rsa
Then simply use:
{
"host": "myserver",
"command": "uptime"
}
Documentation
See for detailed documentation.
License
[Add license information]