Siddhant Sangwan created HDDS-9596:
--------------------------------------
Summary: Determine the criteria for calling a container empty in
the SCM
Key: HDDS-9596
URL: https://issues.apache.org/jira/browse/HDDS-9596
Project: Apache Ozone
Issue Type: Sub-task
Components: SCM
Reporter: Siddhant Sangwan
This is the current apache master logic for identifying an empty container:
{code}
private boolean isContainerEmptyAndClosed(final ContainerInfo container,
final Set<ContainerReplica> replicas) {
return container.getState() == HddsProtos.LifeCycleState.CLOSED &&
!replicas.isEmpty() &&
replicas.stream().allMatch(
r -> r.getState() == ContainerReplicaProto.State.CLOSED &&
r.isEmpty());
}
{code}
What happens if: For an open container, a write is successful in 2 replicas,
but not in the 3rd one. Now the pipeline is broken and closed and this
container moves to quasi closed. The replicas are also quasi closed. It has two
replicas on unique origins, so then the container is closed. At this stage, the
quasi closed replicas go down and we’re only left with the 3rd empty replica.
Won’t we be wrong in marking this container as empty now?
--
This message was sent by Atlassian Jira
(v8.20.10#820010)
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]