.agents/issue/sandbox/code-sandbox-queue-id-analysis.md
代码沙盒当前通过 ProcessPool / PythonProcessPool 维护每种语言的 worker 池。请求进入 /sandbox/js 或 /sandbox/python 后,会直接调用对应进程池的 execute():
waitQueue,等待 worker 释放;当某个业务方在短时间内提交大量代码执行请求时,会占用同语言 worker 和池内等待队列,影响其他业务方的请求延迟。
为代码沙盒运行接口增加 queueId:
POST /sandbox/jsPOST /sandbox/python新增环境变量控制同一个 queueId 同时允许多少个请求进入执行流程。环境变量为空时认为不启用排队能力,保持现有行为。
projects/code-sandbox/src/pool/base-process-pool.ts 已有 worker 维度等待队列 waitQueue,负责“待运行/待分配 worker”的队列。projects/code-sandbox/src/utils/semaphore.ts 已提供简单 FIFO 信号量,语义可用于单个 queueId 的并发控制。排队控制应放在 HTTP API 边界和进程池之间:
HTTP request -> queueId limiter -> process pool waitQueue -> worker execution
这样可以保持进程池只关心 worker 生命周期,不把业务 queueId 概念扩散到 worker 管理层。
queueId:不按 queueId 排队,避免把所有未标识请求挤到同一个匿名队列。queueId 内按 FIFO 唤醒。queueId 之间不做额外公平调度,仍由进程池 worker 队列决定实际执行顺序。queueId 队列在无运行请求且无等待请求后清理,避免高基数 id 导致内存长期增长。SANDBOX_QUEUE_ID_CONCURRENCY。codeSandbox.runCode() 时显式传入 queueId。本次先实现代码沙盒运行接口和 SDK 方法的可选参数,不替业务侧猜测默认 queueId。