SSH Server MCP
An MCP server that provides SSH-based remote management tools, acting as proxy
SSH MCP Server
A Model Context Protocol (MCP) server for managing Linux servers via SSH. This server provides tools for executing commands, managing files, monitoring services, and analyzing logs on remote Linux systems.
Installation
Docker (Recommended)
- Copy the environment file and configure your SSH credentials:
cp env.example .env
# Edit .env with your SSH server details
- Build and run with Docker Compose:
docker compose up -d
Manual Installation
- Install dependencies:
pip install -r requirements.txt
- Set environment variables:
export SSH_HOST=your-server.example.com
export SSH_USER=root
export SSH_PASSWORD=your_password
# OR
export SSH_KEY_FILE=/path/to/private/key
- Run the server:
python -m ssh_mcp_server.server
AnythingLLM Integration
Add the following configuration to your anythingllm_mcp_servers.json:
{
"mcpServers": {
"ssh-mcp-server": {
"name": "SSH MCP Server",
"type": "streamable",
"url": "http://ssh-mcp-server:8000/mcp",
"auth_token": null,
"enabled": true
}
}
}
Configuration
Environment Variables
| Variable | Description | Default |
|---|---|---|
SSH_HOST | Target server hostname or IP | localhost |
SSH_USER | SSH username | root |
SSH_PASSWORD | SSH password | - |
SSH_KEY_FILE | Path to SSH private key | - |
SSH_PORT | SSH port | 22 |
SERVER_HOST | MCP server bind address | 0.0.0.0 |
SERVER_PORT | MCP server port | 8000 |
Authentication
The server supports two authentication methods:
- Password Authentication: Set
SSH_PASSWORDin your environment - Key-based Authentication: Set
SSH_KEY_FILEto the path of your private key
Usage
Basic Connection Test
# Test SSH connection
test_ssh_connection(
hostname="server.example.com",
username="root",
password="your_password"
)
Execute Commands
# Execute a simple command
execute_command("ls -la /var/log")
# Execute with sudo
execute_command("systemctl status nginx", use_sudo=True)
File Operations
# Read a file
read_file("/etc/nginx/nginx.conf")
# Write to a file
write_file("/tmp/test.txt", "Hello World!")
# List directory contents
list_directory("/var/log")
Service Management
# Check service status
get_service_status("nginx")
# Start a service
start_service("nginx")
# Stop a service
stop_service("nginx")
# Restart a service
restart_service("nginx")
Process Management
# List all processes
list_processes()
# List specific processes
list_processes(filter_by="nginx")
# Kill a process
kill_process("12345", signal="TERM")
Network Tools
# Check if port is open
check_port(80)
# Get network connections
get_network_connections()
Log Analysis
# Tail a log file
tail_log("/var/log/nginx/access.log", lines=100)
# Search in logs
search_log("/var/log/nginx/error.log", "error")
Security Considerations
- Use SSH key-based authentication when possible
- Limit SSH access to specific users and IPs
- Regularly rotate SSH keys and passwords
- Monitor SSH access logs
- Use sudo judiciously and limit sudo privileges
Troubleshooting
Connection Issues
- Authentication Failed: Check username, password, or key file
- Connection Refused: Verify SSH service is running and port is correct
- Host Key Verification: Ensure the server's host key is trusted
Permission Issues
- File Access Denied: Check file permissions and ownership
- Sudo Required: Use
use_sudo=Truefor privileged operations - Service Management: Ensure user has appropriate systemd permissions
Performance Issues
- Slow Commands: Increase timeout values for long-running commands
- Connection Timeouts: Check network connectivity and server load
- Resource Usage: Monitor server resources during operations
API Reference
The server exposes the following MCP tools:
test_ssh_connection: Test SSH connectivityget_server_info: Get system informationexecute_command: Execute commandsread_file: Read file contentswrite_file: Write file contentslist_directory: List directory contentsget_service_status: Check service statusstart_service: Start a servicestop_service: Stop a servicerestart_service: Restart a servicelist_processes: List running processeskill_process: Kill a processcheck_port: Check port statusget_network_connections: Get network connectionstail_log: Tail log filessearch_log: Search log files
License
This project is licensed under the MIT License.
Server Terkait
Alpha Vantage MCP Server
sponsorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
CVE MCP Server
A production-grade Model Context Protocol (MCP) server that turns Claude into a full-spectrum security analyst. Instead of juggling 15+ browser tabs across NVD, EPSS, CISA KEV, Shodan, VirusTotal, and GreyNoise, ask Claude one question and get correlated intelligence in seconds. Built with Python, FastMCP, httpx, aiosqlite, Pydantic v2, and defusedxml.
agentskill.sh
Search, discover, and install 55k+ AI agent skills for Claude Code, Cursor, Copilot, Windsurf, and more.
Vega-Lite
Generate visualizations from fetched data using the VegaLite format and renderer.
Chalee MCP RAG
A Retrieval-Augmented Generation (RAG) server for document processing, vector storage, and intelligent Q&A, powered by the Model Context Protocol.
Vibes
Transforms Claude Desktop into a conversational development environment using distributed MCP servers.
Raspberry Pi MCP Servers Collection
A collection of production-ready MCP servers optimized for Raspberry Pi and AI workloads.
WCAG Aria patterns MCP
MCP server for WCAG practices found at https://github.com/karanshah229/wcag-aria-practices-mcp-skill/tree/main
Claude Google Apps Script MCP Guide
Integrate Claude AI with Google Apps Script to automate tasks in Google Sheets and Gmail.
markmap-http-mcp
An MCP server for converting Markdown to interactive mind maps with export support (PNG/JPG/SVG). Server runs as HTTP service.
Replicate Recraft V3
Generate high-quality images using the Recraft V3 model via the Replicate API.