xleoken commented on code in PR #2119:
URL: 
https://github.com/apache/incubator-celeborn/pull/2119#discussion_r1458785382


##########
master/src/main/scala/org/apache/celeborn/service/deploy/master/Master.scala:
##########
@@ -678,16 +679,9 @@ private[celeborn] class Master(
         if (requestSlots.maxWorkers <= 0) slotsAssignMaxWorkers
         else Math.min(slotsAssignMaxWorkers, requestSlots.maxWorkers)),
       numAvailableWorkers)
-    val startIndex = Random.nextInt(numAvailableWorkers)
-    val selectedWorkers = new util.ArrayList[WorkerInfo](numWorkers)
-    selectedWorkers.addAll(availableWorkers.subList(
-      startIndex,
-      Math.min(numAvailableWorkers, startIndex + numWorkers)))
-    if (startIndex + numWorkers > numAvailableWorkers) {
-      selectedWorkers.addAll(availableWorkers.subList(
-        0,
-        startIndex + numWorkers - numAvailableWorkers))
-    }
+    Collections.rotate(availableWorkers, Random.nextInt(numAvailableWorkers))

Review Comment:
   > Oh I means we could also skip `rotate` in case which numWorkers == 
numAvailableWorkers is true.
   
   Emm, I prefer to keep it as it is, because we can not make sure the logic in 
`SlotsAllocator` will always offer slots randomly. 
   
   like this?
   ```
   val selectedWorkers =
     if (numWorkers == numAvailableWorkers) availableWorkers
     else {
       Collections.rotate(availableWorkers, Random.nextInt(numAvailableWorkers))
       availableWorkers.subList(0, numWorkers)
     }
   ```
   



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to