All-in-One (AIO) Sandbox Example
This example demonstrates how to create and access an All-in-One (AIO) Sandbox via OpenSandbox.
Start OpenSandbox server [local]
You can find the latest version here.
You can pre-pull the target image which is used in the example.
Notes (Docker runtime requirement)
The server is configured with runtime.type = "docker" by default, so it must be able to connect to a running Docker daemon.
- Docker Desktop: ensure Docker Desktop is running, then verify with
docker version. - Colima (macOS): start it first (
colima start) and export the socket before starting the server:
export DOCKER_HOST="unix://${HOME}/.colima/default/docker.sock"# pre-pull target image
docker pull ghcr.io/agent-infra/sandbox:latestThen, start the OpenSandbox server, you can obtain stdout log from terminal.
uv pip install opensandbox-server
opensandbox-server init-config ~/.sandbox.toml --example docker
opensandbox-serverNote:
opensandbox-serverruns in the foreground and will keep the current terminal session busy. The example code lives in this repository—clone it and, in a new terminal window/tab,cdinto the project root before running the AIO sandbox creation steps below. If you see errors likeFileNotFoundError: [Errno 2] No such file or directoryfromdocker/transport/unixconn.py, it usually means the Docker unix socket is missing / Docker daemon is not running.
Create and Access the AIO Sandbox Instance
This example uses a fixed configuration for quick start:
- OpenSandbox server:
http://localhost:8080 - Image:
ghcr.io/agent-infra/sandbox:latest - AIO port:
8080 - Timeout:
300s
Install dependencies with uv under project root:
uv pip install opensandbox agent-sandbox==0.0.18Run the example (it will create a sandbox via OpenSandbox, wait until it's Running, then connect to it via agent-sandbox):
uv run python examples/aio-sandbox/main.pySubsequently, you will instantiate an AIO sandbox, navigate to Google, capture a screenshot, and download it to your local environment.
Creating AIO sandbox with image=ghcr.io/agent-infra/sandbox:latest on OpenSandbox server http://localhost:8080...
[check] sandbox ready after 7.1s
AIO portal endpoint: 127.0.0.1:56123
total 52
drwxr-x--- 10 gem gem 4096 Dec 15 13:22 .
drwxr-xr-x 1 root root 4096 Dec 15 13:22 ..
-rw-r--r-- 1 gem gem 220 Jan 7 2022 .bash_logout
-rw-r--r-- 1 gem gem 27 Dec 15 13:22 .bashrc
drwxr-xr-x 5 gem gem 4096 Dec 15 13:22 .cache
drwxrwxr-x 6 gem gem 4096 Dec 15 13:22 .config
drwxr-xr-x 2 gem gem 4096 Dec 15 13:22 .ipython
drwxr-xr-x 4 gem gem 4096 Dec 15 13:22 .jupyter
drwxrwxr-x 4 gem gem 4096 Dec 15 13:22 .local
drwxr-xr-x 3 gem gem 4096 Dec 15 13:22 .npm
drwxrwxr-x 3 gem gem 4096 Dec 15 13:22 .npm-global
drwx------ 3 gem gem 4096 Dec 15 13:22 .pki
-rw-r--r-- 1 gem gem 807 Jan 7 2022 .profile
-rw-rw-r-- 1 gem gem 0 Dec 15 13:22 .Xauthority
export TERM=xterm-256color
Screenshot saved to sandbox_screenshot.pngMore examples
For more examples of using the AIO Sandbox, refer to agents-infra/sandbox examples.
References
此页内容来自仓库源文件:
examples/aio-sandbox/README.md