diff --git a/cws-engine-service/src/main/java/jpl/cws/engine/WorkerService.java b/cws-engine-service/src/main/java/jpl/cws/engine/WorkerService.java index cebb0c1a..333c54fc 100644 --- a/cws-engine-service/src/main/java/jpl/cws/engine/WorkerService.java +++ b/cws-engine-service/src/main/java/jpl/cws/engine/WorkerService.java @@ -724,6 +724,20 @@ public List> claimWithCounter(String limitToProcDefKey) { int queryLimit = Math.min(MaxNumForProcsOnWorker, workerMaxProcQueryLimit); + // Adjust queryLimitForProcSet to ensure total claimed won't exceed workerMaxProcQueryLimit + int totalPossibleClaims = 0; + for (Integer limit : queryLimitForProcSet.values()) { + totalPossibleClaims += limit; + } + if (totalPossibleClaims > queryLimit) { + // Scale down individual limits proportionally + double scaleFactor = (double)queryLimit / totalPossibleClaims; + for (Map.Entry entry : queryLimitForProcSet.entrySet()) { + int newLimit = Math.max(1, (int)(entry.getValue() * scaleFactor)); + queryLimitForProcSet.put(entry.getKey(), Math.min(newLimit, queryLimit)); + } + } + Map> claimRowData = schedulerDbService.claimHighestPriorityStartReq( workerId, currentCounts, queryLimitForProcSet, queryLimit); // pass list of procDefkey and a map of queryLimit per procDefKey