Connects to any SSH server and exposes a single exec tool that runs shell commands remotely and returns stdout. Supports four auth modes: password, key file, key from environment variable (for Vault, Doppler, or envpkt workflows), and SSH_AUTH_SOCK for system agents including 1Password, Bitwarden Desktop, and KeePassXC. Built on somamcp so you get soma_health, soma_capabilities, and soma_connections introspection out of the box. Path expansion handles tilde, dollar signs, and relative paths with fail-fast validation at startup. Reach for this when you need an LLM to run commands on remote Linux, macOS, or Windows OpenSSH hosts without building your own SSH wrapper.
SSH Client MCP Server is a local Model Context Protocol (MCP) server that lets LLMs and other MCP clients execute shell commands on remote hosts over SSH. It runs from Linux, macOS, or Windows and targets any reachable SSH server (Linux, macOS, Windows with OpenSSH, etc.).
Built on somamcp — a functional MCP framework over FastMCP with telemetry, introspection, and backend abstraction.
npx — see Client Setup.No global install required — npx fetches and runs the latest published version.
exec tool — runs a shell command on the remote host, returns stdout. stderr surfaces as a structured error.SSH_AUTH_SOCK (system ssh-agent, 1Password, Bitwarden Desktop, KeePassXC).--key supports ~, $VAR, ${VAR}, and relative paths via functype-os. Unresolved variables fail fast with a typed error.--user defaults to the current OS username when omitted.exec call.soma_health, soma_capabilities, soma_connections auto-registered by somamcp.| Tool | Description |
|---|---|
exec | Execute a shell command on the remote SSH server and return stdout. |
soma_health | Server uptime, status, active session count. |
soma_capabilities | Enumerate registered tools, resources, and prompts. |
soma_connections | Gateway connection status (unused here). |
For driving long-running interactive processes (e.g. a remote coding agent) across calls, the server exposes tmux-backed tools. tmux must be installed on the remote host.
tmux_list — list live tmux sessions.tmux_send({ session?, input, submit? }) — type input into session (created if absent); presses Enter unless submit: false.tmux_read({ session?, lines? }) — return the recent pane transcript (lines default 200, max 2000).tmux_keys({ session?, keys }) — send control/special keys, e.g. { keys: ["C-c"] }.session defaults to --tmux-session (default agent). Tip: run agents in a line-oriented mode (not a full-screen TUI) so tmux_read returns a clean transcript.
npx (recommended)No install step — your MCP client launches it on demand. See Client Setup.
npm install -g ssh-client-mcp-server
# then:
ssh-client-mcp-server --host=1.2.3.4 --user=root --password=pass
git clone https://github.com/jordanburke/ssh-client-mcp-server.git
cd ssh-client-mcp-server
pnpm install
pnpm build
The server reads SSH connection info from CLI flags:
| Flag | Required | Default | Description |
|---|---|---|---|
--host | yes | — | Hostname or IP of the remote SSH server. |
--user | no | OS username | SSH username. Falls back to the local OS user (whoami) when omitted. |
--port | no | 22 | SSH port. |
--password | no* | — | SSH password. |
--key | no* | — | Path to a private SSH key. Supports ~, $VAR, ${VAR}, and relative paths. |
--key-env | no* | — | Name of an env var holding the private key PEM (e.g. injected by envpkt, Vault, Doppler). |
--agent | no* | — | Set to true to use SSH_AUTH_SOCK (system ssh-agent, 1Password, Bitwarden Desktop, KeePassXC). |
*Auth precedence is --password → --key → --key-env → --agent. If none are set the server starts but ssh2 will fail to authenticate on first exec.
Each of these can expose your SSH keys via SSH_AUTH_SOCK. Unlock the vault, confirm the agent is enabled, then run with --agent=true — the server never sees the private key.
# verify the agent is reachable
ssh-add -l
# launch the MCP server through it
ssh-client-mcp-server --host=1.2.3.4 --user=root --agent=true
For Bitwarden Desktop ≥ 2024.12: enable Settings → SSH agent, then on macOS confirm launchctl getenv SSH_AUTH_SOCK points at Bitwarden's socket.
Store the PEM as a sealed value in envpkt.toml, then launch via envpkt exec:
envpkt exec -- ssh-client-mcp-server --host=1.2.3.4 --user=root --key-env=MY_SSH_KEY
Same pattern works for HashiCorp Vault, Doppler, Infisical, AWS Secrets Manager, or any wrapper that lands the key in process.env.
claude_desktop_config.json){
"mcpServers": {
"ssh-client-mcp-server": {
"command": "npx",
"args": ["-y", "ssh-client-mcp-server", "--host=1.2.3.4", "--user=root", "--key=~/.ssh/id_ed25519"]
}
}
}
Replace the --key arg with --password=hunter2. Avoid checking this into version control.
Omit --user entirely — the server defaults to your local username.
Any client that speaks the stdio MCP transport works. Same command / args shape.
npx @modelcontextprotocol/inspector npx ssh-client-mcp-server --host=1.2.3.4 --user=root --key=~/.ssh/id_ed25519
pnpm build)pnpm inspect
This builds and launches the MCP Inspector pointed at dist/index.js.
All tooling is delegated to ts-builds:
pnpm validate # format → lint → typecheck → test → build
pnpm test # vitest run
pnpm test:watch # vitest watch mode
pnpm build # production build to dist/
pnpm dev # tsdown watch mode to lib/
pnpm inspect # build + launch MCP Inspector
Pure helpers (parseArgv, validateConfig, resolveAuth, effectiveUser) live in src/config.ts and are covered by test/config.spec.ts (18 cases, including tempfile-backed key reads and env-var expansion).
Provided under the MIT License. Use at your own risk. Not affiliated with or endorsed by any SSH vendor or MCP provider. Be careful granting LLMs shell access — audit commands, restrict target-account privileges, and consider a jump box.
Issues and PRs welcome at jordanburke/ssh-client-mcp-server. Please run pnpm validate before submitting.
ray0907/git-mcp-server
cyanheads/git-mcp-server
io.github.b1ff/atlassian-dc-mcp-bitbucket
io.github.b1ff/atlassian-dc-mcp-jira
com.mcparmory/atlassian-jira
sirlordt/vscode-terminal-mcp