MCP S SH服务器
一个功能强大的S SH协议实现的服务器,专为模型上下文协议(MCP)设计。此服务器通过S SH协议支持安全的远程命令执行和文件操作,支持密码和基于密钥的身份验证。
功能
- ✨ 安全的S SH连接管理
- 🔑 密码和基于密钥的身份验证
- 💻 远程命令执行
- 📁 文件操作(上传/下载)
- 📊 传输进度跟踪
- 🔐 权限管理
- 📂 目录操作
- 🚀 批量文件传输
- 📝 详细日志记录
安装
- 安装包:
npm install mcp-ssh
- 添加到您的Claude桌面配置(
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"
}
}
}
}
使用方法
密码身份验证
$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"
密钥身份验证
$body = @{
id = "test"
host = "example.com"
port = 22
username = "user"
privateKey = Get-Content ~/.ssh/id_rsa | Out-String
passphrase = "optional-key-passphrase"
} | ConvertTo-Json
Invoke-RestMethod -Uri "http://localhost:8889/connect" -Method Post -Body $body -ContentType "application/json"
执行命令
$execBody = @{
id = "test"
command = "ls -la"
} | ConvertTo-Json
Invoke-RestMethod -Uri "http://localhost:8889/exec" -Method Post -Body $execBody -ContentType "application/json"
文件操作
$uploadForm = @{
file = Get-Item -Path "localfile.txt"
remotePath = "/remote/path/file.txt"
}
Invoke-RestMethod -Uri "http://localhost:8889/upload/test" -Method Post -Form $uploadForm
Invoke-RestMethod -Uri "http://localhost:8889/download/test?remotePath=/remote/path/file.txt" -Method Get -OutFile "downloaded.txt"
目录操作
Invoke-RestMethod -Uri "http://localhost:8889/ls/test?path=/remote/path" -Method Get
Invoke-RestMethod -Uri "http://localhost:8889/status/test" -Method Get
开发
- 克隆仓库:
git clone https://github.com/shaike1/mcp-server-ssh.git
cd mcp-server-ssh
- 安装依赖项:
npm install
- 构建:
npm run build
- 启动服务器:
npm start
环境变量
SSH_PORT
:服务器端口(默认:8889)
SSH_LOG_LEVEL
:日志级别(默认:info)
贡献指南
- 叉克隆仓库
- 创建功能分支(
git checkout -b feature/amazing-feature
)
- 提交更改(
git add .
和 git commit -m "您的提交消息"
)
- 推送到远程仓库(
git push origin feature/amazing-feature
)
- 提交拉取请求
问题反馈
如果您遇到任何问题或有改进建议,请在GitHub仓库中创建问题。
感谢使用MCP S SH服务器!