Why Use a Custom Image
Custom images eliminate cold-start setup work (clone, install, transpile, and bootstrap) so agents spend their time on the actual task. They also reduce setup variance and lower sandbox memory requirements by keeping only what the agent needs.Build Your Own Custom Image
The OpenHands agent-server sandbox guide provides full documentation on building custom sandbox images. The approach is the same for the Enterprise Replicated VM deployment.Basic Pattern
- Start from the OpenHands agent-server base image.
- Keep the normal OpenHands entrypoint intact: extend the image, do not replace the entrypoint.
- Add your repo, docs, tools, and verification wrappers.
- Pre-run the expensive setup you do not want to repeat at task time.
- Publish the image to a registry and point the Replicated installer at it.
Base Image
To get the latest features of OpenHands Enterprise, rebuild your custom image before each upgrade. The agent server base image is updated with every OHE release.
Example: Build and Push
--platform linux/amd64 because the Enterprise Replicated VM runs on x86-64.
What to Bake In
Good candidates for prebaking:- Pinned repository checkouts
- Package manager caches and installed dependencies (
node_modules, Python virtualenvs, etc.) - Compiled or transpiled output
- Native system packages (
xvfb,libkrb5-dev,pkg-config, etc.) - Browser or Electron artifacts
- Stable helper scripts such as
prepare-*and*-verifywrappers
What to Keep Out
If the repository or dependencies change frequently, include aprepare-* script in the image
so the agent can refresh only the parts that need updating without a full rebuild.
Configure the Replicated VM Installer
Once your image is built and pushed to a registry, point the Replicated Admin Console at it.- Open the Admin Console at
https://<your-base-domain>:30000. - Navigate to Config and find the Sandbox Image section.
- Set the following fields:
| Field | Value |
|---|---|
| Use a Custom Sandbox Image | Enabled |
| Sandbox Image Repository | Your image repository (e.g. ghcr.io/your-org/openhands-custom-image) |
| Sandbox Image Tag | Your image tag (e.g. v1.2.0) |
| Registry Server | If your registry requires authentication |
| Registry Username | If your registry requires authentication |
| Registry Password or Credentials | If your registry requires authentication |
- Click Save config and then Deploy to apply the change.
This setting applies to the sandbox / agent-server image only (the image that runs inside each
agent’s isolated workspace). It does not replace the other OpenHands service images.
Reference
- OpenHands custom image example repo: Dockerfile, benchmark scripts, and analysis tooling for the VS Code custom image example.
- Agent-server sandbox guide: full SDK documentation on building and configuring custom sandbox images.

