Sessions
Create isolated execution contexts within a sandbox. Each session maintains its own shell state, environment variables, and working directory. See Session management concept for details.
Create a new isolated execution session.
const session = await sandbox.createSession(options?: SessionOptions): Promise<ExecutionSession>Parameters:
options(optional):id- Custom session ID (auto-generated if not provided)env- Environment variables for this sessioncwd- Working directory (default:"/workspace")
Returns: Promise<ExecutionSession> with all sandbox methods bound to this session
// Multiple isolated environmentsconst prodSession = await sandbox.createSession({ id: "prod", env: { NODE_ENV: "production", API_URL: "https://api.example.com" }, cwd: "/workspace/prod",});
const testSession = await sandbox.createSession({ id: "test", env: { NODE_ENV: "test", API_URL: "http://localhost:3000" }, cwd: "/workspace/test",});
// Run in parallelconst [prodResult, testResult] = await Promise.all([ prodSession.exec("npm run build"), testSession.exec("npm run build"),]);// Multiple isolated environmentsconst prodSession = await sandbox.createSession({ id: 'prod', env: { NODE_ENV: 'production', API_URL: 'https://api.example.com' }, cwd: '/workspace/prod'});
const testSession = await sandbox.createSession({ id: 'test', env: { NODE_ENV: 'test', API_URL: 'http://localhost:3000' }, cwd: '/workspace/test'});
// Run in parallelconst [prodResult, testResult] = await Promise.all([ prodSession.exec('npm run build'), testSession.exec('npm run build')]);Retrieve an existing session by ID.
const session = await sandbox.getSession(sessionId: string): Promise<ExecutionSession>Parameters:
sessionId- ID of an existing session
Returns: Promise<ExecutionSession> bound to the specified session
// First request - create sessionconst session = await sandbox.createSession({ id: "user-123" });await session.exec("git clone https://github.com/user/repo.git");await session.exec("cd repo && npm install");
// Second request - resume session (environment and cwd preserved)const session = await sandbox.getSession("user-123");const result = await session.exec("cd repo && npm run build");// First request - create sessionconst session = await sandbox.createSession({ id: 'user-123' });await session.exec('git clone https://github.com/user/repo.git');await session.exec('cd repo && npm install');
// Second request - resume session (environment and cwd preserved)const session = await sandbox.getSession('user-123');const result = await session.exec('cd repo && npm run build');Delete a session and clean up its resources.
const result = await sandbox.deleteSession(sessionId: string): Promise<SessionDeleteResult>Parameters:
sessionId- ID of the session to delete (cannot be"default")
Returns: Promise<SessionDeleteResult> containing:
success- Whether deletion succeededsessionId- ID of the deleted sessiontimestamp- Deletion timestamp
// Create a temporary session for a specific taskconst tempSession = await sandbox.createSession({ id: "temp-task" });
try { await tempSession.exec("npm run heavy-task");} finally { // Clean up the session when done await sandbox.deleteSession("temp-task");}// Create a temporary session for a specific taskconst tempSession = await sandbox.createSession({ id: 'temp-task' });
try { await tempSession.exec('npm run heavy-task');} finally { // Clean up the session when done await sandbox.deleteSession('temp-task');}Set environment variables in the sandbox.
await sandbox.setEnvVars(envVars: Record<string, string>): Promise<void>Parameters:
envVars- Key-value pairs of environment variables to set
const sandbox = getSandbox(env.Sandbox, "user-123");
// Set environment variables firstawait sandbox.setEnvVars({ API_KEY: env.OPENAI_API_KEY, DATABASE_URL: env.DATABASE_URL, NODE_ENV: "production",});
// Now commands can access these variablesawait sandbox.exec("python script.py");const sandbox = getSandbox(env.Sandbox, 'user-123');
// Set environment variables firstawait sandbox.setEnvVars({ API_KEY: env.OPENAI_API_KEY, DATABASE_URL: env.DATABASE_URL, NODE_ENV: 'production'});
// Now commands can access these variablesawait sandbox.exec('python script.py');The ExecutionSession object has all sandbox methods bound to the specific session:
| Category | Methods |
|---|---|
| Commands | exec(), execStream() |
| Processes | startProcess(), listProcesses(), killProcess(), killAllProcesses(), getProcessLogs(), streamProcessLogs() |
| Files | writeFile(), readFile(), mkdir(), deleteFile(), renameFile(), moveFile(), gitCheckout() |
| Environment | setEnvVars() |
| Code Interpreter | createCodeContext(), runCode(), listCodeContexts(), deleteCodeContext() |
- Session management concept - How sessions work
- Commands API - Execute commands
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark
-