Shellkeeper
MCP server for persistent terminal sessions with SSH support
Ask AI about Shellkeeper
Powered by Claude Β· Grounded in docs
I know everything about Shellkeeper. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
π MCP ShellKeeper
Persistent Terminal Sessions + File Transfer for AI Assistants
SSH into servers, run commands, transfer files β all through your AI assistant. No more stateless limitations.
Real-World Example β’ Installation β’ Core Features β’ Use Cases β’ Tools
π― The Problem
AI assistants like Cursor execute commands statelessly β each command runs in a fresh environment:
β ssh user@server # Hangs forever - no output until exit
β Can't run commands after SSH
β Each command starts from scratch
β No way to transfer files to/from servers
β Must re-authenticate for every operation
β¨ The Solution
ShellKeeper transforms AI assistants into stateful operators with persistent sessions and file transfer capabilities.
π Core Features
π Stateful ExecutionTraditional AI (Stateless)
ShellKeeper (Stateful)
AI maintains full context between your questions! |
π― Persistent SessionsNatural Conversation Flow
The AI remembers everything:
|
π Seamless File TransferJust Ask in Natural Language
It just works:
|
π¬ Real-World Example
Watch how a natural conversation becomes automated operations:
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
π€ YOU ASK:
"Debug the slow API on prod-server-01"
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
π€ AI EXECUTES:
[Connecting...]
β ssh user@prod-server-01
β
Connected to prod-server-01
[Investigating processes...]
β ps aux | grep api
π API process found: PID 1234, using 98% CPU
[Checking logs...]
β cd /var/log/api && tail -n 100 error.log
π ERROR: Memory leak in /api/v1/users endpoint
[Downloading for analysis...]
β Download: /var/log/api/error.log β ./local-debug/
β
Downloaded 2.4MB (analyzed: 500+ memory errors)
[Applying fix...]
β Upload: ./fixed-config.yml β /app/config/
β
Uploaded new rate-limiting config
[Restarting service...]
β systemctl restart api-service
β systemctl status api-service
β
Service restarted, CPU now at 12%
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
π€ AI RESPONDS:
"Fixed! The API had a memory leak in the users endpoint.
β’ Downloaded logs and found 500+ memory allocation errors
β’ Applied rate-limiting configuration
β’ Restarted service - CPU dropped from 98% to 12%
β’ All operations completed in one persistent session"
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β¨ All in ONE session, NO re-authentication needed! β¨
π¦ Installation
npm install -g mcp-shellkeeper
Configuration
|
Cursor Settings JSON:
( |
Claude Code Config file:
( |
VS Code (Cline) Settings JSON:
|
Restart your AI assistant and you're ready! π
π‘ Use Cases
| Scenario | What You Ask | What AI Does |
|---|---|---|
| π Debug Production | "Why is prod-api slow?" | SSH β Check CPU/memory β Download logs β Analyze β Upload fix β Restart |
| π Deploy Updates | "Deploy v2.0 to staging" | SSH β Backup β Upload files β Migrate DB β Restart β Verify |
| π§ Update Configs | "Update SSL certs on web servers" | SSH β Download old certs β Upload new β Test β Reload nginx |
| ποΈ Backup Database | "Backup prod DB to local" | SSH through bastion β Dump DB β Compress β Download β Verify |
| π Analyze Logs | "Find all 500 errors today" | SSH β Parse logs β Download β Analyze locally β Report patterns |
| π Batch Operations | "Update configs on all servers" | Parallel sessions β Upload β Restart β Download results |
All through natural conversation with your AI! No scripts, no manual SSH juggling.
π Available Tools
The AI uses these tools automatically, but you can reference them for advanced use:
| Tool | Purpose | Key Features |
|---|---|---|
terminal_execute | Run commands in persistent session | Timeout config, exit code capture, clean output |
terminal_upload_file | Upload local β remote (max 10MB) | Auto-detect directory, handle duplicates, works through SSH |
terminal_download_file | Download remote β local (max 10MB) | Auto-create dirs, preserve permissions, verify integrity |
terminal_new_session | Create isolated session | Parallel operations, separate environments |
terminal_list_sessions | View all active sessions | Status, uptime, last command |
terminal_close_session | Clean up session | Free resources when done |
terminal_get_buffer | Debug raw output | Useful for troubleshooting |
π‘ Tip: The AI handles these automatically based on your natural language requests!
π Security Best Practices
β DO:
- Use SSH key authentication (not passwords):
ssh-keygen -t ed25519 - Jump through bastion hosts for production:
ssh -J bastion.com user@prod - Limit file upload destinations (avoid
/etc,/root,.ssh/) - Use read-only accounts for investigation
- Clean up sessions after tasks
- Audit all AI operations
β DON'T:
- Store passwords in commands or configs
- Upload untrusted files to production
- Download sensitive data without encryption
- Run destructive commands without verification
- Grant unnecessary permissions
π οΈ How It Works
Persistent Sessions:
- Uses PTY (Pseudo-Terminal) for full TTY emulation with state persistence
- Smart markers detect command completion automatically
- Exit codes captured for error detection
- Output parsed clean (no ANSI codes)
File Transfer:
- Base64 encoding through existing SSH sessions (no separate SCP/SFTP)
- Works through jump hosts without re-authentication
- Max 10MB, 5-minute timeout (completes early if faster)
π Troubleshooting
Commands timeout or hang
// Increase timeout for long-running commands
terminal_execute({
command: "npm install",
timeout: 120000 // 2 minutes
})
// Check if SSH keys are set up correctly
ssh -v user@server
SSH asks for password
# Set up passwordless authentication
ssh-keygen -t ed25519
ssh-copy-id user@server
# Verify
ssh user@server "echo Success"
File upload fails
// Check if in SSH session first
terminal_execute({ command: "pwd" }) // Verify you're on remote server
// Ensure remote directory exists
terminal_execute({ command: "mkdir -p /app/uploads" })
// Then upload
terminal_upload({ local_path: "file.txt", remote_path: "/app/uploads/file.txt" })
File download fails
// Verify remote file exists
terminal_execute({ command: "ls -lh /path/to/file" })
// Check permissions
terminal_execute({ command: "cat /path/to/file | wc -l" })
// Try download with absolute path
terminal_download({ remote_path: "/full/path/to/file", local_path: "./" })
Session becomes unresponsive
// List all sessions
terminal_list_sessions()
// Close problematic session
terminal_close_session({ session_id: "stuck-session" })
// Create fresh session
terminal_new_session({ session_id: "new-session" })
π§ͺ Development
# Clone repository
git clone https://github.com/tranhuucanh/mcp-shellkeeper.git
cd mcp-shellkeeper
# Install dependencies
npm install
# Build
npm run build
# Test locally with stdio transport
node dist/index.js
# Test with MCP Inspector
npm run inspector
π€ Contributing
Contributions welcome! Help make AI-assisted server management better.
- Fork the repository
- Create feature branch (
git checkout -b feature/amazing-feature) - Commit changes (
git commit -m 'Add amazing feature') - Push to branch (
git push origin feature/amazing-feature) - Open Pull Request
π License
MIT License - see LICENSE file for details.
You can:
- β Use commercially
- β Modify
- β Distribute
- β Private use
π Acknowledgments
- Built with Model Context Protocol SDK
- Uses node-pty for terminal emulation
- Inspired by the need for stateful command execution in AI workflows
π Support
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- MCP Community: Discord
Built with β€οΈ for the AI developer community
Stateful execution + File transfer = Limitless possibilities
