Skip to content

Commit

Permalink
use goroutine pool deal sc.taskUnschedulable
Browse files Browse the repository at this point in the history
Signed-off-by: 张建宇 <[email protected]>
  • Loading branch information
张建宇 committed Jan 3, 2025
1 parent bd915ad commit 084b4bd
Showing 1 changed file with 13 additions and 3 deletions.
16 changes: 13 additions & 3 deletions pkg/scheduler/cache/cache.go
Original file line number Diff line number Diff line change
Expand Up @@ -1486,22 +1486,32 @@ func (sc *SchedulerCache) RecordJobStatusEvent(job *schedulingapi.JobInfo, updat
}
// Update podCondition for tasks Allocated and Pending before job discarded
for _, status := range []schedulingapi.TaskStatus{schedulingapi.Allocated, schedulingapi.Pending, schedulingapi.Pipelined} {
for _, taskInfo := range job.TaskStatusIndex[status] {
statusTasks := job.TaskStatusIndex[status]
workerNum := 16
taskInfos := make([]*schedulingapi.TaskInfo, 0, len(statusTasks))
for _, task := range statusTasks {
taskInfos = append(taskInfos, task)
}

workqueue.ParallelizeUntil(context.TODO(), workerNum, len(taskInfos), func(index int) {
taskInfo := taskInfos[index]

// The pod of a scheduling gated task is given
// the ScheduleGated condition by the api-server. Do not change it.
if taskInfo.SchGated {
continue
return
}

reason, msg, nominatedNodeName := job.TaskSchedulingReason(taskInfo.UID)
if len(msg) == 0 {
msg = baseErrorMessage
}

if err := sc.taskUnschedulable(taskInfo, reason, msg, nominatedNodeName); err != nil {
klog.ErrorS(err, "Failed to update unschedulable task status", "task", klog.KRef(taskInfo.Namespace, taskInfo.Name),
"reason", reason, "message", msg)
}
}
})
}
}

Expand Down

0 comments on commit 084b4bd

Please sign in to comment.