Share feedback
Answers are generated based on the documentation.

Architecture

This page explains how Docker Sandboxes work under the hood. For the security properties of the architecture, see Sandbox isolation.

Workspace mounting

Your workspace is mounted directly into the sandbox through a filesystem passthrough. The sandbox sees your actual host files, so changes in either direction are instant with no sync process involved.

Your workspace is mounted at the same absolute path as on your host. Preserving absolute paths means error messages, configuration files, and build outputs all reference paths you can find on your host. The agent sees exactly the directory structure you see, which reduces confusion when debugging or reviewing changes.

Warning

Avoid mounting network-attached or remote storage (network drives, SMB/NFS shares, or cloud-synced folders) as a workspace. The sandbox accesses workspaces through a filesystem passthrough, so every file read and write goes over the network. This adds latency and slows agent performance.

Storage and persistence

When you create a sandbox, everything inside it persists until you remove it: Docker images and containers built or pulled by the agent, installed packages, agent state and history, and workspace changes.

Sandboxes are isolated from each other. Each one maintains its own Docker daemon state, image cache, and package installations. Multiple sandboxes don't share images or layers.

Each sandbox consumes disk space for its VM image, Docker images, container layers, and volumes, and this grows as you build images and install packages.

Networking

All outbound traffic from the sandbox routes through an HTTP/HTTPS proxy on your host. Agents are configured to use the proxy automatically. The proxy enforces network access policies and handles credential injection. See Network isolation for how this works and Default security posture for what is allowed out of the box.

Upstream proxy

The host-side proxy makes its outbound connections using your host's network configuration and routing. When a destination is reachable through a direct route, traffic follows that route. When reaching a destination requires an upstream proxy, the host-side proxy forwards the request to it. Chaining to an upstream proxy means sandbox traffic respects the same egress controls as other applications on your host.

The sandbox daemon makes these upstream requests, and it reads the proxy environment variables HTTP_PROXY, HTTPS_PROXY, and NO_PROXY, along with their lowercase equivalents. Set NO_PROXY to list hosts that should be reached directly instead of through the upstream proxy.

To route sandbox traffic through a different proxy, set DOCKER_SANDBOXES_PROXY to the proxy URL. It applies only to sandbox traffic and sets the upstream proxy for both HTTP and HTTPS to that URL. Unlike HTTP_PROXY and HTTPS_PROXY, it doesn't affect image pulls or the daemon's own requests.

Set these variables in the environment where the sandbox daemon starts. The daemon starts automatically the first time a command needs it, so set the variables before you run a sbx command. If the daemon is already running, restart it for a change to take effect.

Two limitations apply:

  • Only HTTP and HTTPS traffic can be forwarded to an upstream proxy. Other TCP traffic can't be redirected to a proxy.
  • Proxy auto-configuration files, such as proxy.pac, aren't supported. Set the HTTP_PROXY, HTTPS_PROXY, or DOCKER_SANDBOXES_PROXY environment variables explicitly.

Lifecycle

sbx run initializes a VM with a workspace for a specified agent and starts the agent. You can stop and restart without recreating the VM, preserving installed packages and Docker images.

Sandboxes persist until explicitly removed. Stopping an agent doesn't delete the VM; environment setup carries over between runs. Use sbx rm to delete the sandbox, its VM, and all of its contents. If the sandbox used --clone, the sandbox-<name> Git remote is also removed from your host repository.

Comparison to alternatives

ApproachIsolationDocker accessUse case
Sandboxes (microVMs)Full (hypervisor)Isolated daemonAutonomous agents
Container with socket mountPartial (namespaces)Shared host daemonTrusted tools
Docker-in-DockerPartial (privileged)Nested daemonCI/CD pipelines
Host executionNoneHost daemonManual development

Sandboxes trade higher resource overhead (a VM plus its own daemon) for complete isolation. Use containers when you need lightweight packaging without Docker access. Use sandboxes when you need to give something autonomous full Docker capabilities without trusting it with your host environment.