- Explore MCP Servers
- mcp-server-ssh
Mcp Server Ssh
What is Mcp Server Ssh
mcp-server-ssh is a powerful SSH server implementation designed for the Model Context Protocol (MCP). It allows secure remote command execution and file operations using the SSH protocol, supporting both password and key-based authentication.
Use cases
Use cases include managing remote servers, executing scripts and commands remotely, transferring files securely, and automating deployment processes in a secure environment.
How to use
To use mcp-server-ssh, install the package via npm and configure it in your Claude desktop config. You can connect using either password or key authentication, execute commands, and perform file operations through REST API calls.
Key features
Key features include secure SSH connection management, password and key-based authentication, remote command execution, file operations (upload/download), progress tracking for file transfers, permission management, directory operations, bulk file transfers, and detailed logging.
Where to use
mcp-server-ssh can be used in various fields that require secure remote access and management of servers, such as cloud computing, DevOps, system administration, and application deployment.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Overview
What is Mcp Server Ssh
mcp-server-ssh is a powerful SSH server implementation designed for the Model Context Protocol (MCP). It allows secure remote command execution and file operations using the SSH protocol, supporting both password and key-based authentication.
Use cases
Use cases include managing remote servers, executing scripts and commands remotely, transferring files securely, and automating deployment processes in a secure environment.
How to use
To use mcp-server-ssh, install the package via npm and configure it in your Claude desktop config. You can connect using either password or key authentication, execute commands, and perform file operations through REST API calls.
Key features
Key features include secure SSH connection management, password and key-based authentication, remote command execution, file operations (upload/download), progress tracking for file transfers, permission management, directory operations, bulk file transfers, and detailed logging.
Where to use
mcp-server-ssh can be used in various fields that require secure remote access and management of servers, such as cloud computing, DevOps, system administration, and application deployment.
Clients Supporting MCP
The following are the main client software that supports the Model Context Protocol. Click the link to visit the official website for more information.
Content
MCP SSH Server
A powerful SSH server implementation for Model Context Protocol (MCP). This server enables secure remote command execution and file operations through SSH protocol, supporting both password and key-based authentication.
Features
- ✨ Secure SSH connection management
- 🔑 Password and key-based authentication
- 💻 Remote command execution
- 📁 File operations (upload/download)
- 📊 Progress tracking for file transfers
- 🔐 Permission management
- 📂 Directory operations
- 🚀 Bulk file transfers
- 📝 Detailed logging
Installation
- Install the package:
npm install mcp-ssh
- Add to your Claude desktop config (
claude_desktop_config.json):
{
"mcpServers": {
"ssh": {
"command": "node",
"args": [
"%APPDATA%/npm/node_modules/mcp-ssh/dist/server.js"
],
"env": {
"SSH_PORT": "8889",
"SSH_LOG_LEVEL": "info"
}
}
}
}
Usage
Password Authentication
$body = @{
id = "test"
host = "example.com"
port = 22
username = "user"
password = "pass123"
} | ConvertTo-Json
Invoke-RestMethod -Uri "http://localhost:8889/connect" -Method Post -Body $body -ContentType "application/json"
Key Authentication
$body = @{
id = "test"
host = "example.com"
port = 22
username = "user"
privateKey = Get-Content ~/.ssh/id_rsa | Out-String
passphrase = "optional-key-passphrase" # if your key is protected
} | ConvertTo-Json
Invoke-RestMethod -Uri "http://localhost:8889/connect" -Method Post -Body $body -ContentType "application/json"
Execute Commands
$execBody = @{
id = "test"
command = "ls -la"
} | ConvertTo-Json
Invoke-RestMethod -Uri "http://localhost:8889/exec" -Method Post -Body $execBody -ContentType "application/json"
File Operations
# Upload file
$uploadForm = @{
file = Get-Item -Path "localfile.txt"
remotePath = "/remote/path/file.txt"
}
Invoke-RestMethod -Uri "http://localhost:8889/upload/test" -Method Post -Form $uploadForm
# Download file
Invoke-RestMethod -Uri "http://localhost:8889/download/test?remotePath=/remote/path/file.txt" -Method Get -OutFile "downloaded.txt"
Directory Operations
# List directory
Invoke-RestMethod -Uri "http://localhost:8889/ls/test?path=/remote/path" -Method Get
# Get connection status
Invoke-RestMethod -Uri "http://localhost:8889/status/test" -Method Get
Development
- Clone the repository:
git clone https://github.com/shaike1/mcp-server-ssh.git
cd mcp-server-ssh
- Install dependencies:
npm install
- Build:
npm run build
- Start server:
npm start
Environment Variables
SSH_PORT: Server port (default: 8889)SSH_LOG_LEVEL: Logging level (default: info)
Contributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
MIT
Dev Tools Supporting MCP
The following are the main code editors that support the Model Context Protocol. Click the link to visit the official website for more information.










