SSH Rails Runner
Execute Rails console commands remotely and securely over SSH.
MCP Server: SSH Rails Runner
An MCP server that enables secure remote execution of Rails console commands via SSH. This server provides tools for both read-only operations and carefully managed mutations in a deployed Rails environment.
This works great with Cursor. You can use Cursor Composer to pull in your Rails model files as context and then use the execute_read_only, dry_run_mutate, and execute_mutate tools to make changes to the database. No need to trudge through complicated Admin UI's to get your data wrangling and analysis done.
Example

Features
- Remote Rails console execution over SSH
- Safe read-only operations
- Dry-run capability for mutations
- Execution of approved mutations
- Resource management for code snippets
Installation
npm install
npm run build
Configuration
Set the following environment variables:
SSH_HOST=your.remote.host
SSH_USER=your_ssh_user
SSH_PRIVATE_KEY_PATH=your_SSH_PRIVATE_KEY_PATH
RAILS_WORKING_DIR=/path/to/rails/app
Usage with Claude Desktop
Add to your Claude Desktop configuration:
{
"mcpServers": {
"ssh-rails-runner": {
"command": "npx",
"args": ["mcp-server-ssh-rails-runner"],
"env": {
"SSH_HOST": "your.remote.host",
"SSH_USER": "your_ssh_user",
"SSH_PRIVATE_KEY_PATH": "your_SSH_PRIVATE_KEY_PATH",
"RAILS_WORKING_DIR": "/path/to/rails/app/root",
"PROJECT_NAME_AS_CONTEXT": "Name that shows up in tool descriptions to help the LLM describe what kind of Rails project we're working with.",
"CODE_SNIPPET_FILE_DIRECTORY": "/path/to/store/code/snippets/locally"
}
}
}
}
If CODE_SNIPPET_FILE_DIRECTORY is not provided, snippets will be stored in a temporary directory (e.g., /tmp/mcp-ssh-rails-runner-code-snippets).
PROJECT_NAME_AS_CONTEXT is optional and helps identify the project context in tool descriptions.
Available Tools
The server now uses a Prepare -> Execute workflow:
mcp_ssh_rails_runner_prepare_code_snippet
- Arguments:
name(string, for filename),type(enum: "readOnly" | "mutate"),code(string, Ruby code),description(string, optional). - Function: Saves the provided Ruby code to a local file named
code_snippet_<name>.json, marks it as read-only or mutate, and opens the file for review. - Returns: The
file://URI of the created snippet.
mcp_ssh_rails_runner_execute_code_snippet_read_only
- Arguments:
uri(string,file://URI fromprepareCodeSnippet). - Function: Reads the code snippet from the URI, verifies it's marked as
readOnly, performs a safety check on the code, and executes it. - Returns: The output of the Rails command.
mcp_ssh_rails_runner_execute_code_snippet_mutate
- Arguments:
uri(string,file://URI fromprepareCodeSnippet). - Function: DANGER ZONE! Reads the code snippet, verifies it's marked as
mutate, and executes it directly. There is no dry run or further safety check within this tool. - Returns: The output of the Rails command.
- Usage: ONLY CALL THIS AFTER THE USER HAS REVIEWED the prepared code (via the opened file from
prepareCodeSnippet) AND EXPLICITLY CONFIRMED they want to execute the mutation.
Security Considerations
- Only use with trusted SSH endpoints from your own local machine that is (temporarily) provided access to the remote environment.
- Crucially, always review the code saved by
prepareCodeSnippetbefore executing any mutation withexecuteCodeSnippetMutate. The responsibility for confirming mutations lies with the user and the calling AI.
License
MIT
相關伺服器
Scout Monitoring MCP
贊助Put performance and error data directly in the hands of your AI assistant.
Alpha Vantage MCP Server
贊助Access financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
Language Server
MCP Language Server gives MCP enabled clients access to semantic tools like get definition, references, rename, and diagnostics.
Vibe Check
The definitive Vibe Coder's sanity check MCP server: Prevents cascading errors by calling a "Vibe-check" agent to ensure alignment and prevent scope creep
Formo
Formo makes analytics and attribution easy for crypto apps, so you can focus on growth. Measure what matters and drive growth onchain with the data platform for onchain apps. Get the best of web, product, and onchain analytics on one versatile platform.
Kali AI Pentest MCP Tools
An AI penetration testing tool that uses natural language to operate various security tools like nmap, sqlmap, and metasploit.
Docfork
Provides up-to-date documentation for over 9000 libraries directly within AI code editors.
Xcode
Tools for Xcode project management, building, testing, archiving, code signing, and iOS development utilities.
ui-ticket-mcp
Human-to-AI code review bridge. Review UI prototypes in the browser, then let AI agents fix the code automatically via MCP.
Python Notebook MCP
Enables AI assistants to interact with local Jupyter notebooks (.ipynb).
pabal-store-api-mcp
MCP server that provides App Store / Play Store ASO workflows as tools.
XcodeProj MCP Server
An MCP server for manipulating Xcode project files (.xcodeproj) using Swift. Requires Docker and macOS.