nandakumar131 commented on code in PR #7985:
URL: https://github.com/apache/ozone/pull/7985#discussion_r1975349739


##########
hadoop-hdds/server-scm/src/main/java/org/apache/hadoop/hdds/scm/container/replication/health/MismatchedReplicasHandler.java:
##########
@@ -57,35 +58,28 @@ public MismatchedReplicasHandler(
    */
   @Override
   public boolean handle(ContainerCheckRequest request) {
-    ContainerInfo containerInfo = request.getContainerInfo();
-    Set<ContainerReplica> replicas = request.getContainerReplicas();
+    if (request.isReadOnly()) {
+      return false;
+    }
+
+    final ContainerInfo containerInfo = request.getContainerInfo();
+    final Set<ContainerReplica> replicas = request.getContainerReplicas();
+
     if (containerInfo.getState() != HddsProtos.LifeCycleState.CLOSED &&
         containerInfo.getState() != HddsProtos.LifeCycleState.QUASI_CLOSED) {
       // Handler is only relevant for CLOSED or QUASI-CLOSED containers.
       return false;
     }
-    LOG.debug("Checking container {} in MismatchedReplicasHandler",
-        containerInfo);
 
-    if (request.isReadOnly()) {
-      return false;
-    }
-    // close replica if needed
-    for (ContainerReplica replica : replicas) {
-      if (shouldBeClosed(containerInfo, replica)) {
-        LOG.debug("Sending close command for mismatched replica {} of " +
-            "container {}.", replica, containerInfo);
+    LOG.debug("Checking container {} in MismatchedReplicasHandler", 
containerInfo);
 
-        if (containerInfo.getState() == HddsProtos.LifeCycleState.CLOSED) {
-          replicationManager.sendCloseContainerReplicaCommand(
-              containerInfo, replica.getDatanodeDetails(), true);
-        } else if (containerInfo.getState() ==
-            HddsProtos.LifeCycleState.QUASI_CLOSED) {
-          replicationManager.sendCloseContainerReplicaCommand(
-              containerInfo, replica.getDatanodeDetails(), false);
-        }
-      }
-    }
+    final Predicate<ContainerReplica> shouldSendClose = (r) -> 
shouldSendClose(containerInfo, r);
+
+    replicas.stream().filter(shouldSendClose).forEach(r -> {
+      LOG.debug("Sending close command for mismatched replica {} of container 
{}.", r, containerInfo);
+      replicationManager.sendCloseContainerReplicaCommand(
+          containerInfo, r.getDatanodeDetails(), 
shouldForceClose(containerInfo, r));

Review Comment:
   Yes, if the BCSID matches we are sending force close command to that 
Container replica.
   
   This is not different from the previous behaviour, we were sending force 
close for open/closing replica even without checking the sequence Id. With this 
change we will only send force close if the sequence Id matches.
   
   We believe  that the BCSID of a CLOSED container is the highest (correct).



-- 
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]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to