Skip to content

execd - OpenSandbox Execution Daemon

execd is the runtime daemon used inside OpenSandbox sandboxes.

It is built on Gin and exposes HTTP APIs for code execution, shell commands, filesystem operations, PTY sessions, and metrics.

Quick Start

1) Build

bash
cd components/execd
make build

2) Start Jupyter Server

bash
./tests/jupyter.sh

3) Run execd

bash
./bin/execd \
  --jupyter-host=http://127.0.0.1:54321 \
  --jupyter-token=your-jupyter-token \
  --port=44772

4) Verify

bash
curl -v http://localhost:44772/ping

API

  • OpenAPI spec: ../../specs/execd-api.yaml
  • Common capability groups:
    • Code execution (/code, SSE stream)
    • Session and command execution (/session, /command)
    • Filesystem operations (/files, /directories)
    • PTY over WebSocket (/pty)
    • Local metrics endpoints (/metrics, /metrics/watch)

Configuration

CLI Flags

FlagDefaultDescription
--jupyter-host""Jupyter server URL reachable by execd.
--jupyter-token""Jupyter token for HTTP/WebSocket auth.
--port44772HTTP listen port.
--log-level6Log level (0=Emergency, 7=Debug).
--access-token""Optional shared API access token.
--graceful-shutdown-timeout1sSSE tail-drain wait window before closing.
--jupyter-idle-poll-interval100msPoll interval after Jupyter reports idle.

Environment Variables

VariableDescription
JUPYTER_HOSTSame as --jupyter-host (overridden by explicit flag).
JUPYTER_TOKENSame as --jupyter-token (overridden by explicit flag).
EXECD_API_GRACE_SHUTDOWNSame as --graceful-shutdown-timeout.
EXECD_JUPYTER_IDLE_POLL_INTERVALSame as --jupyter-idle-poll-interval.
EXECD_CLONE3_COMPATLinux clone3 compatibility switch (see below).
EXECD_LOG_FILEOptional log output file path; default is stdout.
OTEL_EXPORTER_OTLP_METRICS_ENDPOINTPreferred OTLP metrics endpoint.
OTEL_EXPORTER_OTLP_ENDPOINTFallback OTLP endpoint when metrics-specific endpoint is unset.
OPENSANDBOX_IDOptional sandbox_id metric/resource attribute.
OPENSANDBOX_EXECD_METRICS_EXTRA_ATTRSOptional extra metric attrs (k=v,k2=v2).

Observability

OpenTelemetry Metrics

OTLP metrics export is enabled when either endpoint is set:

  • OTEL_EXPORTER_OTLP_METRICS_ENDPOINT
  • OTEL_EXPORTER_OTLP_ENDPOINT

Detailed metric list and attributes opentelemetry.md.

Local Metrics Endpoints

  • GET /metrics: point-in-time host metrics snapshot
  • GET /metrics/watch: SSE stream (1s cadence)

Linux clone3 Compatibility

Some sandbox environments fail on clone3(2).
Set EXECD_CLONE3_COMPAT in sandbox env to force fallback behavior:

  • 1 / true / yes / on: enable seccomp fallback
  • reexec: enable fallback and re-exec binary

License

execd is part of OpenSandbox. See ../../LICENSE.


This page is sourced from: components/execd/README.md