Hosted Apps¶
Workspace containers can run web applications (Jupyter, Marimo, Vite dev servers, etc.) on dynamically allocated ports. Klangk's nginx reverse proxy makes them accessible at predictable URLs without exposing raw container ports.
Note
Hosted apps are for development and demonstration — not permanent hosting. Port allocations and containers are ephemeral; use a dedicated hosting platform for production deployments.
Warning
Hosted apps are accessible to anyone who can reach the Klangk server. Do not serve sensitive content or data you don't want to be publicly visible.
How it works¶
- Each workspace gets 5 ports allocated from the host range starting at port 9000 (configurable via
KLANGK_PORT_RANGE_START). These map to container ports 8000-8004. - When a container starts, the port mappings are injected as
KLANGK_PORT_MAPPINGS(e.g.,8000:9000,8001:9001,...). - Nginx proxies requests from
/hosted/{workspace_id}/{port}/directly to the container — no Python in the request path.
Accessing hosted apps¶
Start any HTTP server on a container port (8000-8004), then visit:
For example, if your workspace ID is abc123 and you run a server on container port 8000 (mapped to host port 9000):
WebSocket connections are supported — tools like Jupyter and Marimo work out of the box.
Environment variables inside containers¶
| Variable | Example | Description |
|---|---|---|
KLANGK_PORT_MAPPINGS |
8000:9000,8001:9001,... |
Container-to-host port mapping (CSV) |
KLANGK_HOSTING_HOSTNAME |
localhost:8995 |
Hostname for constructing hosted app URLs |
KLANGK_HOSTING_PROTO |
http |
Protocol for hosted app URLs |
KLANGK_HOSTING_BASE_PATH |
/klangk |
Base path prefix (empty for root deployments) |
Extensions and scripts inside the container can use these to construct correct URLs for their hosted apps. Pi's built-in get_hosted_url tool does this automatically.
Behind a reverse proxy¶
When Klangk runs behind an outer reverse proxy (e.g., on a subpath like /klangk), the hosting info is auto-derived from standard headers:
X-Forwarded-Host— used as the hostnameX-Forwarded-Proto— used as the protocolX-Forwarded-Prefix— used as the base path
The generated hosted app URL becomes:
No manual configuration needed — the KLANGK_HOSTING_* environment variables are only required if header-based derivation doesn't work for your setup.
Configuration¶
| Variable | Default | Description |
|---|---|---|
KLANGK_PORT_RANGE_START |
9000 |
First host port for workspace app allocations |
KLANGK_NGINX_PORT |
8995 |
Nginx port (used in URL derivation) |
Ports are allocated atomically and cleaned up automatically when workspaces are deleted.