KarmaGYZ commented on a change in pull request #11323: [FLINK-16439][k8s] Make 
KubernetesResourceManager starts workers using WorkerResourceSpec requested by 
SlotManager
URL: https://github.com/apache/flink/pull/11323#discussion_r388789563
 
 

 ##########
 File path: 
flink-runtime/src/main/java/org/apache/flink/runtime/resourcemanager/ActiveResourceManager.java
 ##########
 @@ -114,4 +121,42 @@ public ActiveResourceManager(
        protected abstract Configuration loadClientConfiguration();
 
        protected abstract double getCpuCores(final Configuration 
configuration);
+
+       /**
+        * Utility class for counting pending workers per {@link 
WorkerResourceSpec}.
+        */
+       @VisibleForTesting
+       static class PendingWorkerCounter {
+               private final Map<WorkerResourceSpec, Integer> 
pendingWorkerNums;
+
+               @VisibleForTesting
+               PendingWorkerCounter() {
+                       pendingWorkerNums = new HashMap<>();
+               }
+
+               public int getTotalNum() {
+                       return pendingWorkerNums.values().stream().reduce(0, 
Integer::sum);
+               }
+
+               public int getNum(final WorkerResourceSpec workerResourceSpec) {
+                       return 
pendingWorkerNums.getOrDefault(Preconditions.checkNotNull(workerResourceSpec), 
0);
+               }
+
+               public int increateAndGet(final WorkerResourceSpec 
workerResourceSpec) {
+                       return pendingWorkerNums.compute(
+                               Preconditions.checkNotNull(workerResourceSpec),
 
 Review comment:
   The stack trace would be a little different.
   ```
   java.lang.NullPointerException
        at 
org.apache.flink.util.Preconditions.checkNotNull(Preconditions.java:58)
        at increateAndGet
   ```
   vs
   ```
   java.lang.NullPointerException
        at 
org.apache.flink.util.Preconditions.checkNotNull(Preconditions.java:58)
        at Test.lambda$increateAndGet$0
        at java.util.HashMap.compute(HashMap.java:1197)
        at increateAndGet
   ```
   I just think there would be two useless lines. I do not have a strong 
opinion though.

----------------------------------------------------------------
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.
 
For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


With regards,
Apache Git Services

Reply via email to