io.github.jschoemaker/mcpgo
Manage your Claude Code MCPs by talking to Claude β list, restart, wrap, and more.
Ask AI about io.github.jschoemaker/mcpgo
Powered by Claude Β· Grounded in docs
I know everything about io.github.jschoemaker/mcpgo. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
mcpgo
Manage your Claude Code MCPs by talking to Claude β list, restart, wrap, and more.
Works everywhere Claude Code works, including Remote Control where /mcp isn't available.
Installation
npm install -g @exfil/mcpgo
claude mcp add mcpgo --scope user -- mcpgo
Requirements: Node.js β₯ 18
Remote Control
Claude Code's Remote Control mode has no access to /mcp. That means you can't list, restart, or manage MCP servers remotely β unless you have mcpgo.
Because mcpgo is itself an MCP server, it's available everywhere Claude Code is:
"list my mcps"
"restart github"
"check postgres health"
No /mcp UI needed.
What it does
Reliable restarts
Claude Code connects to stdio MCP servers via pipes it creates at launch. If a server crashes or you want to restart it, Claude Code marks it as failed with no auto-recovery.
mcpgo solves this with a wrapper: a long-lived process that sits between Claude Code and your MCP. Claude Code talks to the wrapper (which stays alive), and the wrapper spawns the real server as a child β auto-respawning it whenever it's killed.
Wrapping is optional β you can use mcpgo just for listing, adding, or removing MCPs without wrapping anything. Wrapping is only needed if you want reliable restarts without touching /mcp.
One-time setup per MCP:
wrap_mcp_stdioβ wraps the target MCP in config- Restart Claude Code (or disconnect + reconnect via
/mcp) - Done β use
restart_mcp_processanytime
After setup:
"restart github" β instant, wrapper auto-respawns the child, Claude Code stays connected
"restart postgres" β same
If you ever want to undo wrapping, use unwrap_mcp_stdio to restore the original config.
Tools
Process management
wrap_mcp_stdio
Wrap a Claude Code stdio MCP for reliable restarts.
"wrap github"
"wrap postgres"
unwrap_mcp_stdio
Restore a wrapped MCP to its original config.
"unwrap github"
"unwrap postgres"
restart_mcp_process
Restart a wrapped MCP's child process β wrapper auto-respawns it, Claude Code stays connected.
"restart github"
"restart postgres"
check_mcp_health
Check if an MCP is configured, wrapped, and its process is running.
"check github health"
"is postgres running?"
Codex CLI support
wrap_codex_mcp_stdio
Wrap a Codex CLI MCP from ~/.codex/config.toml.
"wrap my codex mcp called postgres"
restart_codex_mcp_process
Restart a wrapped Codex CLI MCP.
"restart the codex postgres"
Config management
list_all_mcps
List all configured MCP servers.
"list my mcps"
"what mcps do I have?"
add_mcp
Add a new MCP server to ~/.claude.json.
"add an mcp called my-tool that runs python server.py"
remove_mcp
Remove an MCP server.
"remove the my-tool mcp"
configure_mcp
Update an existing MCP server's config fields.
"change github's command to python3"
get_mcp_details
Get full config details for a specific MCP.
"show me the github config"
"get details for postgres"
How wrapping works
When you call wrap_mcp_stdio "github", the config entry changes from:
{ "command": "python", "args": ["server.py"] }
to:
{
"command": "node",
"args": ["/path/to/wrapper.js", "--name", "github", "--pidfile", "...", "--", "python", "server.py"]
}
The wrapper:
- Spawns the original command as a child
- Writes the child's PID to a pidfile
- Auto-respawns the child on exit (with backoff)
- Exits cleanly on SIGTERM, SIGINT, or stdin EOF
restart_mcp_process reads the pidfile and kills the child. The wrapper respawns it β Claude Code never sees a disconnect.
unwrap_mcp_stdio reverses this β it restores the original command from the args after -- and removes the pidfile.
Stable wrapper location
When you wrap an MCP, mcpgo copies wrapper.js to a stable user-data location and writes that path into ~/.claude.json. This means the config survives npx cache clears and mcpgo version upgrades β the wrapper won't disappear from under you.
- Windows:
%LOCALAPPDATA%\mcpgo\wrapper.js - Linux/macOS:
~/.mcpgo/wrapper.js
Re-running wrap_mcp_stdio on an already-wrapped MCP refreshes the wrapper copy in place.
Pidfile locations
- Windows:
%LOCALAPPDATA%\mcpgo\pids\<name>.pid - Linux/macOS:
$TMPDIR/mcpgo/pids/<name>.pid
Notes
- Wrapping requires a Claude Code restart (or manual
/mcpdisconnect + reconnect) to take effect β Claude Code caches config in memory restart_mcp_processworks best on wrapped MCPs; for unwrapped ones it kills the process but you'll need to reconnect manually via/mcp- Mid-request crashes may cause a brief protocol desync; Claude Code recovers on the next tool call
