SSH MCP Server

SSH MCP Server

Enables AI assistants to execute SSH commands and perform token-efficient file operations on remote servers via the Model Context Protocol.

Category
Visit Server

README

๐Ÿš€ SSH MCP Server (Node.js)

NPM Version GitHub Issues License: MIT Node.js

A secure, high-performance Model Context Protocol (MCP) server that enables AI assistants like Claude Desktop to execute SSH commands on remote servers. Built with Node.js and the official MCP SDK for maximum compatibility and reliability.

๐Ÿ”„ Version 2.1.0 - Token-Efficient File Operations: Complete rewrite in Node.js with official MCP SDK - eliminates all previous Go compatibility issues!


โœจ Features

  • ๐Ÿ” Secure SSH: Private key authentication with multiple key format support
  • ๐Ÿค– AI-Ready: Official MCP SDK integration for Claude Desktop and other AI tools
  • โšก High Performance: Node.js async architecture for fast command execution
  • ๐Ÿ“ฆ Zero Setup: One-command installation via NPX - no compilation required
  • ๐ŸŒ Universal: Pure JavaScript runs on Windows, macOS, and Linux
  • ๐Ÿ›ก๏ธ Type Safe: Built with modern JavaScript and comprehensive error handling
  • ๐Ÿ“‹ Standards Compliant: Uses official @modelcontextprotocol/sdk

๐Ÿš€ Quick Start

Installation & Usage

# Use directly with NPX (recommended)
npx @idletoaster/ssh-mcp-server@latest

# Or install globally
npm install -g @idletoaster/ssh-mcp-server

Claude Desktop Configuration

Add to your Claude Desktop MCP configuration file:

{
  "mcpServers": {
    "ssh": {
      "command": "npx",
      "args": ["-y", "@idletoaster/ssh-mcp-server@latest"],
      "env": {}
    }
  }
}

That's it! Claude can now execute SSH commands on your remote servers.


๐Ÿ’ฌ Usage Examples

Once configured, Claude can help you with commands like:

"Check disk usage on my production server at 192.168.1.100"

"Restart the nginx service on server.example.com as user admin"

"Show running processes on my Ubuntu server using my SSH key"

Manual Tool Usage

{
  "tool": "remote-ssh",
  "arguments": {
    "host": "192.168.1.100",
    "user": "ubuntu",
    "command": "df -h",
    "privateKeyPath": "/home/user/.ssh/id_rsa"
  }
}

๐Ÿ”ง Configuration

SSH Key Authentication

The server supports multiple authentication methods:

1. Explicit Key Path

{
  "privateKeyPath": "/path/to/your/private/key"
}

2. Environment Variable

export SSH_PRIVATE_KEY="/home/user/.ssh/id_rsa"

3. Auto-Discovery

Automatically searches for keys in:

  • ~/.ssh/id_rsa
  • ~/.ssh/id_ed25519
  • ~/.ssh/id_ecdsa

Supported Key Formats

  • โœ… RSA keys (id_rsa)
  • โœ… ED25519 keys (id_ed25519)
  • โœ… ECDSA keys (id_ecdsa)
  • โœ… OpenSSH format
  • โœ… PEM format

๐Ÿ› ๏ธ Development

Prerequisites

  • Node.js 18+ (check: node --version)
  • NPM 9+ (check: npm --version)

Install Node.js

Windows:

Download from nodejs.org or use Chocolatey:

choco install nodejs

Linux (Ubuntu/Debian):

curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash -
sudo apt-get install -y nodejs

Linux (CentOS/RHEL):

curl -fsSL https://rpm.nodesource.com/setup_20.x | sudo bash -
sudo yum install -y nodejs

macOS:

brew install node

Build from Source

# Clone repository
git clone https://github.com/idletoaster/ssh-mcp-server.git
cd ssh-mcp-server

# Install dependencies
npm install

# Run locally
npm start

# Development with auto-reload
npm run dev

๐Ÿ—๏ธ Architecture

ssh-mcp-server/
โ”œโ”€โ”€ package.json          # NPM configuration & dependencies
โ”œโ”€โ”€ index.js              # Main MCP server (Official SDK)
โ”œโ”€โ”€ lib/
โ”‚   โ””โ”€โ”€ ssh-client.js     # SSH connection management
โ”œโ”€โ”€ README.md             # Documentation
โ”œโ”€โ”€ LICENSE               # MIT license
โ””โ”€โ”€ .gitignore           # Node.js gitignore

Technology Stack

  • Runtime: Node.js 18+ with ES Modules
  • MCP SDK: @modelcontextprotocol/sdk (Official)
  • SSH: ssh2 library for Node.js
  • Distribution: NPM with direct NPX execution

๐Ÿ”’ Security

Best Practices

  • โœ… Private key authentication only (no passwords)
  • โœ… Configurable SSH algorithms and timeouts
  • โœ… No persistent connections (session-based)
  • โœ… Input validation and sanitization
  • โœ… Comprehensive error handling

Security Guidelines

  • ๐Ÿ” Store private keys with restrictive permissions (chmod 600)
  • ๐ŸŒ Use SSH key passphrases when possible
  • ๐Ÿ›ก๏ธ Restrict SSH keys to specific hosts in ~/.ssh/config
  • ๐Ÿ“ Monitor SSH access logs
  • ๐Ÿšซ Never run as root unless absolutely necessary

Network Security

# Example SSH config for restricted access
Host production-server
    HostName 192.168.1.100
    User deploy
    IdentityFile ~/.ssh/production_key
    IdentitiesOnly yes
    StrictHostKeyChecking yes

๐Ÿงช Testing

Local Testing

# Test the MCP server
echo '{"host":"test.server.com","user":"testuser","command":"whoami"}' | npm start

Integration Testing

# Verify Node.js installation
node --version  # Should be 18+
npm --version   # Should be 9+

# Test NPX execution
npx @idletoaster/ssh-mcp-server@latest --help

๐ŸŒ Compatibility

Operating Systems

  • โœ… Windows 10/11 (x64, ARM64)
  • โœ… macOS 12+ (Intel & Apple Silicon)
  • โœ… Linux (x64, ARM64) - All major distributions

AI Platforms

  • ๐Ÿค– Claude Desktop (Primary target)
  • ๐Ÿค– Cursor IDE
  • ๐Ÿค– Any MCP-compatible application

Node.js Compatibility

  • โœ… Node.js 18.x (LTS)
  • โœ… Node.js 20.x (LTS)
  • โœ… Node.js 22.x (Current)

๐Ÿ“Š Migration from v1.x (Go)

Upgrading from the Go version? The Node.js version offers:

โœ… Improvements

  • Zero compilation - No more binary builds
  • Better compatibility - Official MCP SDK
  • Faster development - Direct code changes
  • Simpler deployment - Pure NPX distribution
  • No protocol issues - Official Anthropic SDK

๐Ÿ”„ Migration Steps

  1. Uninstall old version: Remove Go-based installation
  2. Install new version: npx @idletoaster/ssh-mcp-server@latest
  3. Update Claude config: Same configuration works!
  4. Test connection: Verify SSH functionality

๐Ÿค Contributing

Development Workflow

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make your changes
  4. Test thoroughly: npm test
  5. Submit a pull request

Code Style

  • Use ES6+ modern JavaScript
  • Follow Node.js best practices
  • Add JSDoc comments for functions
  • Validate with existing patterns

๐Ÿ“„ License

MIT License - see LICENSE file for details.


๐Ÿ™ Acknowledgments


๐Ÿ“ž Support


Built with โค๏ธ for the AI development community using Node.js and official MCP SDK

๐Ÿ†• NEW in v2.1.0: Token-Efficient File Operations

Enhanced with 4 powerful tools inspired by Desktop Commander for optimal token usage:

๐ŸŽฏ Token-Efficient Tools

  1. ssh-edit-block - Edit specific text blocks (80-90% token reduction vs full rewrites)
  2. ssh-read-lines - Read file sections by line numbers (massive savings for large files)
  3. ssh-search-code - Pattern search without reading full files
  4. ssh-write-chunk - Efficient content writing with append/rewrite modes

๐Ÿ’ก Benefits

  • 80-90% fewer tokens for file operations
  • No more full file rewrites for small changes
  • Partial file reading for large codebases
  • Pattern searching without token overhead

๐Ÿ“– New Tool Usage

// Edit specific text blocks
{
  "name": "ssh-edit-block",
  "arguments": {
    "host": "server.com",
    "user": "username", 
    "filePath": "/path/to/file.js",
    "oldText": "version: '2.0.0'",
    "newText": "version: '2.1.0'"
  }
}

// Read specific lines only
{
  "name": "ssh-read-lines", 
  "arguments": {
    "host": "server.com",
    "user": "username",
    "filePath": "/path/to/large-file.js",
    "startLine": 100,
    "endLine": 150
  }
}

// Search patterns efficiently
{
  "name": "ssh-search-code",
  "arguments": {
    "host": "server.com", 
    "user": "username",
    "path": "/project",
    "pattern": "function.*export",
    "filePattern": "*.js"
  }
}

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

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.

Official
Featured