Files
pig-farm-controller/internal/domain/task/full_collection_task.go

104 lines
3.5 KiB
Go
Raw Normal View History

2025-10-29 16:37:05 +08:00
package task
import (
2025-11-05 21:40:19 +08:00
"context"
2025-10-29 16:37:05 +08:00
"fmt"
"git.huangwc.com/pig/pig-farm-controller/internal/domain/device"
"git.huangwc.com/pig/pig-farm-controller/internal/domain/plan"
2025-10-29 16:37:05 +08:00
"git.huangwc.com/pig/pig-farm-controller/internal/infra/logs"
"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
"git.huangwc.com/pig/pig-farm-controller/internal/infra/repository"
)
2025-11-02 18:16:44 +08:00
// FullCollectionTask 实现了 plan.Task 接口,用于执行一次全量的设备数据采集
2025-10-29 16:37:05 +08:00
type FullCollectionTask struct {
2025-11-05 21:40:19 +08:00
ctx context.Context
2025-10-29 16:37:05 +08:00
log *models.TaskExecutionLog
deviceRepo repository.DeviceRepository
deviceService device.Service
}
// NewFullCollectionTask 创建一个全量采集任务实例
func NewFullCollectionTask(
2025-11-05 21:40:19 +08:00
ctx context.Context,
2025-10-29 16:37:05 +08:00
log *models.TaskExecutionLog,
deviceRepo repository.DeviceRepository,
deviceService device.Service,
) plan.Task {
2025-10-29 16:37:05 +08:00
return &FullCollectionTask{
2025-11-05 21:40:19 +08:00
ctx: ctx,
2025-10-29 16:37:05 +08:00
log: log,
deviceRepo: deviceRepo,
deviceService: deviceService,
}
}
// Execute 是任务的核心执行逻辑
2025-11-05 21:40:19 +08:00
func (t *FullCollectionTask) Execute(ctx context.Context) error {
taskCtx, logger := logs.Trace(ctx, t.ctx, "Execute")
logger.Infow("开始执行全量采集任务", "task_id", t.log.TaskID, "task_type", t.log.Task.Type, "log_id", t.log.ID)
2025-10-29 16:37:05 +08:00
2025-11-05 21:40:19 +08:00
sensors, err := t.deviceRepo.ListAllSensors(taskCtx)
2025-10-29 16:37:05 +08:00
if err != nil {
return fmt.Errorf("全量采集任务: 从数据库获取所有传感器失败: %w", err)
}
if len(sensors) == 0 {
2025-11-05 21:40:19 +08:00
logger.Infow("全量采集任务: 未发现任何传感器设备,跳过本次采集", "task_id", t.log.TaskID, "task_type", t.log.Task.Type, "log_id", t.log.ID)
2025-10-29 16:37:05 +08:00
return nil
}
2025-11-10 22:23:31 +08:00
sensorsByController := make(map[uint32][]*models.Device)
2025-10-29 16:37:05 +08:00
for _, sensor := range sensors {
sensorsByController[sensor.AreaControllerID] = append(sensorsByController[sensor.AreaControllerID], sensor)
}
var firstError error
for controllerID, controllerSensors := range sensorsByController {
2025-11-05 21:40:19 +08:00
logger.Infow("全量采集任务: 准备为区域主控下的传感器下发采集指令",
2025-10-29 16:37:05 +08:00
"task_id", t.log.TaskID,
"task_type", t.log.Task.Type,
"log_id", t.log.ID,
"controller_id", controllerID,
"sensor_count", len(controllerSensors),
)
2025-11-05 21:40:19 +08:00
if err := t.deviceService.Collect(taskCtx, controllerID, controllerSensors); err != nil {
logger.Errorw("全量采集任务: 为区域主控下发采集指令失败",
2025-10-29 16:37:05 +08:00
"task_id", t.log.TaskID,
"task_type", t.log.Task.Type,
"log_id", t.log.ID,
"controller_id", controllerID,
"error", err,
)
if firstError == nil {
firstError = err // 保存第一个错误
}
}
}
if firstError != nil {
return fmt.Errorf("全量采集任务执行期间发生错误: %w", firstError)
}
2025-11-05 21:40:19 +08:00
logger.Infow("全量采集任务执行完成", "task_id", t.log.TaskID, "task_type", t.log.Task.Type, "log_id", t.log.ID)
2025-10-29 16:37:05 +08:00
return nil
}
// OnFailure 定义了当 Execute 方法返回错误时,需要执行的回滚或清理逻辑
2025-11-05 21:40:19 +08:00
func (t *FullCollectionTask) OnFailure(ctx context.Context, executeErr error) {
logger := logs.TraceLogger(ctx, t.ctx, "OnFailure")
logger.Errorw("全量采集任务执行失败",
2025-10-29 16:37:05 +08:00
"task_id", t.log.TaskID,
"task_type", t.log.Task.Type,
"log_id", t.log.ID,
"error", executeErr,
)
}
// ResolveDeviceIDs 获取当前任务需要使用的设备ID列表
2025-11-10 22:23:31 +08:00
func (t *FullCollectionTask) ResolveDeviceIDs(ctx context.Context) ([]uint32, error) {
// 全量采集任务不和任何设备绑定, 每轮采集都会重新获取全量传感器
2025-11-10 22:23:31 +08:00
return []uint32{}, nil
}