76 lines
4.0 KiB
Markdown
76 lines
4.0 KiB
Markdown
# 框架入口
|
||
|
||
[🌏English](Entrance_en.md)
|
||
|
||
框架主要的入口是:
|
||
|
||
- `src.server.task_controller`: 用于手动启动task_controller。
|
||
- `src.start_task`: 用于启动task_worker。
|
||
- `src.assigner`: 用于启动评测。
|
||
- `src.server.task_worker`: 用于手动启动task_worker。
|
||
|
||
## src.server.task_controller
|
||
|
||
task_controller是task server的核心,用于管理所有的task_worker。
|
||
task_controller应该是最先启动的,且推荐常开,如无必要也建议全局唯一。
|
||
task_controller默认运行在5000端口,也可以通过`--port -p`参数指定。
|
||
所有接口有统一的前缀`/api/`。
|
||
|
||
一个启动task_controller并指定其运行在3000端口的示例:
|
||
|
||
```bash
|
||
python -m src.server.task_controller -p 3000
|
||
```
|
||
|
||
task_controller有以下几个用于监控的接口:
|
||
|
||
| 接口 | 方法 | 参数 | 说明 |
|
||
|----------------|------|----|------------------------------------------------------|
|
||
| /list_workers | GET | 无 | 返回所有的task_worker |
|
||
| /list_sessions | GET | 无 | 返回所有的session |
|
||
| /sync_all | POST | 无 | 同步所有的task_worker上正在运行的session,如controller意外重启应先调用此接口 |
|
||
| /cancel_all | POST | 无 | 取消所有的task_worker上正在运行的session |
|
||
|
||
## src.start_task
|
||
|
||
start_task是用于启动task_worker的脚本,其主要功能是读取配置文件并启动task_worker。
|
||
start_task的配置文件是`configs/start_task.yaml`,具体详见配置文件介绍。
|
||
|
||
start_task的参数如下:
|
||
|
||
- `[--config CONFIG]`: 指定要读取的配置文件,默认为`configs/start_task.yaml`,通常没有必要更改。
|
||
- `[--start | -s [TASK_NAME NUM [TASK_NAME NUM ...]]]`: 指定要启动的任务,格式为`TASK_NAME NUM`,其中`TASK_NAME`
|
||
是任务名称,`NUM`是需要启动的worker的个数,如此参数被指定则将覆盖**所有**配置文件中的设置。
|
||
- `[--auto-controller | -a]`: 指定是否自动启动task_controller,默认为否。
|
||
- `[--base-port | -p PORT]`:
|
||
指定task_worker的基础端口,默认为5001,task_worker将从PORT开始依次启动task_worker。如若共有N个task_worker,那么task_worker的端口将从PORT到PORT+N-1。
|
||
|
||
## src.assigner
|
||
|
||
assigner是用于启动评测的脚本,其主要功能是读取配置文件并启动评测,并将结果实时保存在指定的输出文件夹中。
|
||
|
||
assigner的参数如下:
|
||
|
||
- `[--config CONFIG]`: 指定要读取的配置文件,默认为`configs/assignments/default.yaml`。
|
||
- `[--auto-retry]`: 自动重新测试失败的样例
|
||
|
||
如配置文件中的`output`字段的值中含有`{TIMESTAMP}`,则此处将会被替换为当前时间并继续后续的操作(即相同的配置文件可能会有不同的输出文件夹)。
|
||
|
||
如果配置中`output`字段指定的目录已经存在,则assigner将会尝试从此文件夹中读取已有的评测结果,在此基础上继续评测。
|
||
|
||
assigner**每次**启动都会将读取的配置文件解析并存储到`output`字段指定的目录中,**如目录中已有配置文件,该文件将被覆盖**。
|
||
|
||
## src.server.task_worker
|
||
|
||
一个task_worker对应了一个任务进程,同样的任务可以有多个task_worker。
|
||
如无必要,**不推荐**手动启动task_worker,而是通过`src.start_task`启动。
|
||
|
||
task_worker的参数如下:
|
||
|
||
- `NAME` 任务名称,用于指定要启动的任务。
|
||
- `[--config | -c CONFIG]` 指定要读取的配置文件,默认为`configs/tasks/task_assembly.yaml`。
|
||
- `[--port | -p PORT]` 指定task_worker的端口,默认为5001。
|
||
- `[--controller | -C ADDRESS]` 指定task_controller的地址,默认为http://localhost:5000/api 。
|
||
- `[--self ADDRESS]` 指定task_worker的地址,默认为http://localhost:5001/api
|
||
,此地址将会被task_controller用于与task_worker通信,所以需要确保task_controller能够访问到此地址。
|