loading…
Search for a command to run...
loading…
MCP server connecting Claude Code with E2B cloud sandboxes for working on any GitHub repo.
MCP server connecting Claude Code with E2B cloud sandboxes for working on any GitHub repo.
An MCP (Model Context Protocol) server that connects Claude Code with E2B cloud sandboxes, giving you isolated Linux VMs to work on any GitHub repository without touching your local machine.
This server provides Claude Code with 29 tools to create cloud sandboxes, clone repos, run commands, manage files, and perform git operations — all in a secure, disposable Linux environment.
Your local machine stays untouched. Every operation happens inside an E2B sandbox VM.
Running commands through E2B sandboxes instead of local Bash reduces the tokens consumed per conversation. Tool outputs are structured and truncated (100KB per stream, 200KB total), so large build/test outputs don't flood your context window.
| Project Size | Example | Local Bash Tokens | E2B Sandbox Tokens | Savings |
|---|---|---|---|---|
| Small | Express API, ~10 files | ~15K-25K | ~10K-18K | ~20-30% |
| Medium | Next.js app, 50-100 files | ~50K-100K | ~25K-45K | ~40-55% |
| Large | Monorepo, 500+ files | ~200K-500K+ | ~60K-120K | ~60-75% |
Why it scales: A local npm install on a monorepo can dump 10K+ lines into context. A full test suite adds thousands more. With E2B, those outputs are capped and structured. Background processes (sandbox_exec_background) return only a process ID — zero streaming output. Directory listings are capped at 1000 entries. The result: your context window stays available for actual work instead of being consumed by terminal noise.
Clone any repository into a sandbox, run its build and test suite, make changes, and push — without ever installing the project locally.
You: "Clone github.com/fastify/fastify, run the tests, and find why test X fails"
Claude Code:
→ sandbox_create
→ sandbox_git_clone "https://github.com/fastify/fastify"
→ sandbox_exec "npm install"
→ sandbox_exec "npm test"
→ sandbox_file_read (inspect failing test)
→ sandbox_file_write (apply fix)
→ sandbox_exec "npm test" (verify)
Try risky changes — dependency upgrades, major refactors, migration scripts — in a throwaway environment. If it breaks, sandbox_kill and start fresh.
Pause a sandbox when you're done for the day, resume it tomorrow with all your files and state intact. No more rebuilding environments from scratch.
You: "Pause this sandbox, I'll continue tomorrow"
Claude Code:
→ sandbox_pause (saves state)
Next day:
→ sandbox_resume (picks up where you left off)
Start a web app in a sandbox and get a public URL to preview it in your browser — no port forwarding or tunneling needed.
You: "Start the dev server and give me a URL to preview it"
Claude Code:
→ sandbox_exec_background "npm run dev"
→ sandbox_get_url 3000
→ Returns: https://abc123-3000.e2b.dev
Spin up multiple sandboxes, clone different repos, work on all of them simultaneously. Each sandbox is fully isolated.
Run your full test suite in a fresh Linux environment. Catch "works on my machine" issues before pushing to CI.
Fork a repo, clone it in a sandbox, make your changes, commit, and push to your fork — all without local project setup.
Clone a PR branch into a sandbox, run the tests, inspect the changes, and verify the behavior — without checking out the branch locally.
No separate install needed — just point Claude Code at the npm package with npx:
claude mcp add e2b-sandbox -s user \
-e E2B_API_KEY=your-e2b-api-key \
-e GITHUB_TOKEN=your-github-token \
-- npx -y e2b-sandbox-mcp
Restart Claude Code after adding the server.
If you prefer a global install instead of npx:
npm install -g e2b-sandbox-mcp
claude mcp add e2b-sandbox -s user \
-e E2B_API_KEY=your-e2b-api-key \
-e GITHUB_TOKEN=your-github-token \
-- e2b-sandbox-mcp
Start Claude Code and ask it to work on any repo:
"Create a sandbox, clone https://github.com/expressjs/express, and run the test suite"
Claude Code will call the MCP tools automatically.
| Tool | Description |
|---|---|
sandbox_create |
Create a new cloud sandbox (Linux VM) |
sandbox_list |
List all active sandboxes |
sandbox_info |
Get details about a specific sandbox |
sandbox_kill |
Terminate and destroy a sandbox |
sandbox_keep_alive |
Extend a sandbox's timeout |
sandbox_pause |
Pause a sandbox, preserving its state for later |
sandbox_resume |
Resume a previously paused sandbox |
| Tool | Description |
|---|---|
sandbox_get_url |
Get a public URL for a port (preview dev servers in browser) |
sandbox_upload_url |
Get a presigned URL to upload files to the sandbox |
sandbox_download_url |
Get a presigned URL to download files from the sandbox |
| Tool | Description |
|---|---|
sandbox_exec |
Run a shell command and get stdout/stderr/exit code |
sandbox_exec_background |
Start a background process (dev servers, watchers) |
sandbox_process_list |
List all running processes with PIDs |
sandbox_process_kill |
Kill a running process by PID |
| Tool | Description |
|---|---|
sandbox_file_read |
Read file contents |
sandbox_file_write |
Write/create a file |
sandbox_file_list |
List directory contents |
sandbox_file_mkdir |
Create a directory |
sandbox_file_remove |
Delete a file or directory |
sandbox_file_info |
Get file metadata (size, type, permissions) |
sandbox_file_exists |
Check if a file or directory exists |
sandbox_file_rename |
Rename or move a file or directory |
| Tool | Description |
|---|---|
sandbox_git_clone |
Clone a repository (supports private repos with GITHUB_TOKEN) |
sandbox_git_status |
Get working tree status |
sandbox_git_commit |
Stage files and commit |
sandbox_git_push |
Push commits to remote |
sandbox_git_pull |
Pull latest changes from remote |
sandbox_git_branch |
List, create, or switch branches |
sandbox_git_init |
Initialize a new git repository |
| Variable | Required | Description |
|---|---|---|
E2B_API_KEY |
Yes | Your E2B API key from e2b.dev/dashboard |
GITHUB_TOKEN |
No | GitHub personal access token for private repo access and git push |
src/
├── index.ts # MCP server entry point (stdio transport)
├── types.ts # Shared types and error helpers
├── services/
│ └── sandbox-manager.ts # Sandbox registry (tracks active VMs)
└── tools/
├── sandbox.ts # Lifecycle tools
├── commands.ts # Command execution tools
├── filesystem.ts # File operation tools
└── git.ts # Git operation tools
The server manages a registry of active sandbox instances. Each tool references sandboxes by ID, allowing concurrent work across multiple isolated environments.
sandbox_keep_alive to extend.MIT
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"e2b-sandbox-mcp": {
"command": "npx",
"args": []
}
}
}