Files
lobe-chat/docs/self-hosting/environment-variables/cloud-sandbox.zh-CN.mdx
T
Coooolfan a28fd30719 feat: suppport sandbox provider (#15184)
*  feat(cloud-sandbox): add Onlyboxes provider support for self-hosted sandbox (#15136)

- Add `SANDBOX_PROVIDER` env var (market | onlyboxes) to select sandbox backend
- Add Onlyboxes-specific env vars: `ONLYBOXES_BASE_URL`, `ONLYBOXES_API_TOKEN`, `ONLYBOXES_LEASE_TTL_SEC`
- Create `SandboxService` abstraction layer with `MarketSandboxService` and `OnlyboxesSandboxService` implementations
- Add `createSandboxService` factory that routes to configured provider
- Migrate `execInSandbox` and `exportFile` t

*  feat(sandbox): improve Onlyboxes export flow

* 🐛 fix(sandbox): pass presigned upload headers to Onlyboxes

*  test(sandbox): import tool runtime package

* 🐛 fix(sandbox): preserve Market export errors

* 🐛 fix(sandbox): allow empty docker env defaults

* 🔒 fix: redact sandbox auth params in logs

* 🐛 fix: address sandbox provider review comments

* 🔐 feat: use onlyboxes jit tokens

* 📝 docs: clarify cloud sandbox provider config

* 🐛 fix: align cloud sandbox timeout defaults

* 🐛 fix(sandbox): lower default Onlyboxes lease TTL to 15 minutes

* 🐛 fix(sandbox): cap Onlyboxes task wait time

* ♻️ refactor: split sandbox env config
2026-06-07 12:18:39 +08:00

137 lines
4.3 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
---
title: 配置云端沙箱
description: 配置内置云端沙箱能力,包括 Market 和自托管 Onlyboxes。
tags:
- 云端沙箱
- Onlyboxes
- 自托管
---
# 配置云端沙箱
云端沙箱用于内置的代码执行、Shell 命令、文件操作和文件导出工具。默认情况下,LobeHub 使用 Market 沙箱;自托管部署可以把同一套工具能力切换到兼容 Onlyboxes 的沙箱提供方。
## 核心环境变量
### `SANDBOX_PROVIDER`
- 类型:可选
- 描述:选择服务端使用的沙箱提供方。
- 默认值:`market`
- 示例:`onlyboxes`
支持的取值:
- `market`:使用现有 Market 沙箱。
- `onlyboxes`:使用兼容 Onlyboxes 的自托管沙箱 Console。
### `MARKET_BASE_URL`
- 类型:可选
- 描述:Market 服务的基础 URL。使用官方 Market 时无需配置;仅当你需要连接自托管或专用 Market 服务时设置。
- 默认值:`https://market.lobehub.com`
- 示例:`https://market.example.com`
### `MARKET_TRUSTED_CLIENT_ID`
- 类型:可选
- 描述:Market Trusted Client 的客户端 ID,用于让 LobeHub 服务端代表当前用户调用 Market 能力。需要由对应 Market 服务登记。
- 默认值:-
- 示例:`lobechat-com`
### `MARKET_TRUSTED_CLIENT_SECRET`
- 类型:可选
- 描述:Market Trusted Client 的共享密钥,必须与对应 Market 服务端配置一致。
- 默认值:-
- 示例:`your-market-trusted-client-secret`
### `ONLYBOXES_BASE_URL`
- 类型:当 `SANDBOX_PROVIDER=onlyboxes` 时必填
- 描述:Onlyboxes Console API 的基础 URL,不需要包含 `/api/v1`。
- 默认值:-
- 示例:`https://onlyboxes.example.com`
### `ONLYBOXES_JIT_SIGNING_KEY`
- 类型:当 `SANDBOX_PROVIDER=onlyboxes` 时必填
- 描述:用于签发 Onlyboxes MCP JIT Bearer Token 的 HMAC 密钥,必须与 Onlyboxes Console 的 `CONSOLE_JIT_SIGNING_KEY` 一致。
- 默认值:-
- 示例:`onlyboxes-jit-signing-secret`
### `ONLYBOXES_JIT_ISSUER`
- 类型:可选
- 描述:Onlyboxes JIT Token claims 中使用的签发方。
- 默认值:`APP_URL`
- 示例:`https://lobehub.example.com`
### `ONLYBOXES_JIT_TTL_SEC`
- 类型:可选
- 描述:LobeHub 签发的每个 Onlyboxes JIT Token 的有效期。
- 默认值:`1800`
- 示例:`900`
### `ONLYBOXES_LEASE_TTL_SEC`
- 类型:可选
- 描述:云端沙箱提供方创建持久终端会话时使用的租约时长。
- 默认值:`900`
- 示例:`3600`
## Market 配置
默认情况下,LobeHub 使用官方 Market 沙箱,不需要额外配置:
```bash
# SANDBOX_PROVIDER=market
```
如果你需要显式使用 Market,或者连接自托管 / 专用 Market 服务,可以配置:
```bash
SANDBOX_PROVIDER=market
MARKET_BASE_URL=https://market.example.com
```
如果该 Market 服务要求 LobeHub 服务端代表当前用户调用沙箱、凭据或技能能力,还需要配置 Trusted Client
```bash
MARKET_TRUSTED_CLIENT_ID=lobechat-com
MARKET_TRUSTED_CLIENT_SECRET=your-market-trusted-client-secret
```
`MARKET_TRUSTED_CLIENT_ID` 需要在 Market 服务端的可信客户端白名单中,`MARKET_TRUSTED_CLIENT_SECRET` 需要与 Market 服务端共享密钥一致。未配置 Trusted Client 时,Market 侧需要认证的能力会继续使用现有的用户授权流程。
## Onlyboxes 运行时要求
配置的 Onlyboxes worker 需要暴露 `terminalExec` 和 `terminalResource`。LobeHub 使用 `terminalExec` 作为 Shell 命令、代码执行和文件操作的兼容层,并使用 `terminalResource` 通过预签名上传 URL 导出文件。
为了和 Market 沙箱保持能力对等,终端运行镜像应包含:
- `python3`,用于文件操作封装和 Python 执行
- `node`,用于 JavaScript 执行
- `npx` 以及可用的 `tsx`,用于 TypeScript 执行
- `base64`、`find`、`grep` 等常见 Shell 工具
使用 Onlyboxes 时的最小配置:
```bash
SANDBOX_PROVIDER=onlyboxes
ONLYBOXES_BASE_URL=https://onlyboxes.example.com
ONLYBOXES_JIT_SIGNING_KEY=onlyboxes-jit-signing-secret
```
Onlyboxes Console 侧需要配置同一个密钥:
```bash
CONSOLE_JIT_SIGNING_KEY=onlyboxes-jit-signing-secret
```
<Callout type={'info'}>
文件导出仍会把沙箱内产物写入 LobeHub 配置的 S3 存储。如果用户需要下载沙箱生成的文件,请同时配置 S3
相关环境变量。
</Callout>