[ 
https://issues.apache.org/jira/browse/KAFKA-17755?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Jerry Cai resolved KAFKA-17755.
-------------------------------
    Fix Version/s: 3.8.1
         Reviewer: Rajini Sivaram
       Resolution: Fixed

> AbstractPartitionAssignor can not enable RackAwareAssignment base on lead 
> rack mode
> -----------------------------------------------------------------------------------
>
>                 Key: KAFKA-17755
>                 URL: https://issues.apache.org/jira/browse/KAFKA-17755
>             Project: Kafka
>          Issue Type: Bug
>          Components: consumer
>    Affects Versions: 3.7.0, 3.8.0, 3.7.1
>            Reporter: Jerry Cai
>            Assignee: Jerry Cai
>            Priority: Critical
>             Fix For: 3.8.1
>
>
> During my local test and debug, I noticed that the below logical is in 
> correct, it needs to change 
> from   !racksPerPartition.values().stream().allMatch(partitionRacks::equals)  
> to  racksPerPartition.values().stream().allMatch(partitionRacks::equals)
>  
>  
>  
> current logical 
> {code:java}
> protected boolean useRackAwareAssignment(Set<String> consumerRacks, 
> Set<String> partitionRacks, Map<TopicPartition, Set<String>> 
> racksPerPartition) {
>     if (consumerRacks.isEmpty() || Collections.disjoint(consumerRacks, 
> partitionRacks))
>         return false;
>     else if (preferRackAwareLogic)
>         return true;
>     else {
>         return 
> !racksPerPartition.values().stream().allMatch(partitionRacks::equals);
>     }
> }
>  {code}
>  
> expected logical 
> {code:java}
> protected boolean useRackAwareAssignment(Set<String> consumerRacks, 
> Set<String> partitionRacks, Map<TopicPartition, Set<String>> 
> racksPerPartition) {
>     if (consumerRacks.isEmpty() || Collections.disjoint(consumerRacks, 
> partitionRacks))
>         return false;
>     else if (preferRackAwareLogic)
>         return true;
>     else {
>         return 
> racksPerPartition.values().stream().allMatch(partitionRacks::equals);
>     }
> }
>  {code}



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to