PartitionMap.java 952 字节
Newer Older
1
package com.xiaojukeji.know.streaming.km.persistence.kafka.zookeeper.znode.brokers;
Z
zengqiao 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * 根据/brokers/topics/topic的节点内容定义
 * @author tukun
 * @date 2015/11/10.
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
@ToString
public class PartitionMap implements Serializable {

    /**
     * 版本号
     */
    private int                         version;

    /**
     * Map<PartitionId,副本所在的brokerId列表>
     */
    private Map<Integer, List<Integer>> partitions;

    public List<Integer> getPartitionAssignReplicas(Integer partitionId) {
        if (partitions == null) {
            return new ArrayList<>();
        }

        return partitions.getOrDefault(partitionId, new ArrayList<>());
    }
}