流程
-
接收评测机连接请求 : 后端通过 WebSocket 等技术与评测机建立连接,接收评测机的注册请求,获取评测机的相关信息,如用户 ID、连接会话等。
-
评测机注册 : 后端将评测机的信息注册到系统中,以便后续管理和分配评测任务。
-
任务分配 : 后端根据评测机的压力情况 和当前系统负载情况 ,从待评测的任务队列中选择合适的任务,并将任务分配给评测机。
-
评测任务执行 : 评测机接收到后端分配的评测任务后,执行相应的评测操作,如运行测试用例、评测代码等。
-
结果收集 : 评测机执行完评测任务后,将评测结果发送给后端 ,后端接收并处理评测结果,记录到系统中。
-
状态更新 : 后端根据评测机的状态更新请求,更新评测机的状态信息,如在线状态、负载情况等。
-
异常处理 : 处理评测机连接断开、任务执行失败等异常情况,保证评测系统的稳定性和可靠性。
实现
-
创建评测机实体类: 创建一个 EvaluationMachine 类,包含评测机的相关信息,如用户 ID、WebSocket 会话等。
-
创建评测任务实体类: 创建一个 EvaluationTask 类,包含评测任务的相关信息,如任务 ID、描述等。
-
创建评测机服务接口 : 创建一个 EvaluationMachineService 接口,定义评测机管理的相关方法,如注册评测机、分配任务、更新状态等。
-
实现评测机服务接口: 创建一个 EvaluationMachineServiceImpl 类,实现 EvaluationMachineService 接口中定义的方法,包括注册评测机、分配任务、更新状态等逻辑。
-
创建 WebSocket 控制器 : 使用 @ServerEndpoint注解创建 WebSocket 控制器,在其中处理评测机的连接、消息接收等逻辑。
-
编写业务逻辑: 在 WebSocket 控制器中实现评测机的注册、任务分配、状态更新等具体业务逻辑。
-
配置 Spring Boot 应用: 在 Spring Boot 应用的配置类中,注入 WebSocket 控制器、评测机服务实现类等相关组件,并进行必要的配置。
-
启动应用: 启动 Spring Boot 应用,评测系统的后端服务即可运行,等待评测机连接并处理评测任务。