Skip to content

Latest commit

 

History

History
88 lines (73 loc) · 3.33 KB

File metadata and controls

88 lines (73 loc) · 3.33 KB

简介

sandbox create(别名 cr)从指定模板创建一个新的沙箱实例并连接到其终端。当终端会话结束时,沙箱将被自动终止。

使用 --detach 模式时,创建沙箱后不连接终端,沙箱保持存活直到超时。

沙箱通过 keep-alive 机制保持存活,终端连接期间会自动续命,无需手动设置超时。

格式

qshell sandbox create [template] [-t <seconds>] [--detach] [-m <metadata>] [-e <KEY=VALUE>...] [--auto-pause] [--injection-rule <ruleID>...] [--inline-injection <spec>...]
qshell sbx cr [template] [-t <seconds>] [--detach] [-m <metadata>] [-e <KEY=VALUE>...] [--auto-pause] [--injection-rule <ruleID>...] [--inline-injection <spec>...]

帮助文档

$ qshell sandbox create -h
$ qshell sandbox create --doc

鉴权

需要配置 QINIU_API_KEYE2B_API_KEY 环境变量,或在当前目录 .env 文件中设置。

参数

  • template:模板 ID(实际创建时必填;命令参数层最多接受 1 个模板参数)
  • -t, --timeout:沙箱超时时间(秒)
  • --detach:创建沙箱但不连接终端,沙箱保持存活直到超时。此参数没有短参数
  • -m, --metadata:元数据键值对(格式:key1=value1,key2=value2)
  • -e, --env-var:环境变量(KEY=VALUE 格式,可多次指定)
  • --auto-pause:超时后自动暂停沙箱,而不是终止沙箱
  • --injection-rule:创建沙箱时附加的注入规则 ID,可多次指定
  • --inline-injection:创建沙箱时附加的内联注入配置,可多次指定,格式为 type=<type>,api-key=<key>,base-url=<url>,headers=<k1=v1;k2=v2>

内联注入说明:

  • type 支持 openaianthropicgeminiqiniuhttp
  • api-key 可用于 openaianthropicgeminiqiniu
  • base-url 可用于覆盖默认目标地址;type=http 时必填,type=qiniu 默认目标地址为 api.qnaigc.com
  • headers 仅用于 type=http,多个请求头使用分号分隔,例如 headers=Authorization=Bearer token;X-Env=prod

示例

  1. 创建沙箱
$ qshell sandbox create my-template
$ qshell sbx cr my-template
  1. 设置超时时间
$ qshell sandbox create my-template --timeout 300
$ qshell sbx cr my-template -t 300
  1. 分离模式创建(不连接终端,沙箱存活 5 分钟)
$ qshell sandbox create my-template -t 300 --detach
$ qshell sbx cr my-template -t 300 --detach
  1. 设置环境变量
$ qshell sandbox create my-template -e FOO=bar -e BAZ=qux
$ qshell sbx cr my-template -e FOO=bar -e BAZ=qux
  1. 超时后自动暂停
$ qshell sandbox create my-template -t 300 --auto-pause
$ qshell sbx cr my-template -t 300 --auto-pause
  1. 添加元数据
$ qshell sandbox create my-template -m env=dev,team=backend
$ qshell sbx cr my-template -m env=dev,team=backend
  1. 创建时附加注入规则
$ qshell sandbox create my-template --injection-rule rule-openai --injection-rule rule-http
$ qshell sbx cr my-template --injection-rule rule-openai --injection-rule rule-http
  1. 创建时附加内联注入配置
$ qshell sandbox create my-template \
    --inline-injection 'type=openai,api-key=sk-xxx' \
    --inline-injection 'type=http,base-url=https://api.example.com,headers=Authorization=Bearer token;X-Env=prod'
$ qshell sbx cr my-template --inline-injection 'type=gemini,api-key=sk-gem'