// KafkaProducer缺省的分区器
public class DefaultPartitioner implements Partitioner {
// producer级别的计数器,RoundRobin用
private final AtomicInteger counter = new AtomicInteger(new Random().nextInt());
// 负责在消息中没有明确指定分区编号时,为producer选择合适的分区
public int partition(String topic, Object key, byte[] keyBytes, Object value, byte[] valueBytes, Cluster cluster) {
List<PartitionInfo> partitions = cluster.partitionsForTopic(topic);
int numPartitions = partitions.size();
if (keyBytes == null) {
int nextValue = counter.getAndIncrement();
List<PartitionInfo> availablePartitions = cluster.availablePartitionsForTopic(topic);
// 取模后决定使用哪个分区
int part = DefaultPartitioner.toPositive(nextValue) % availablePartitions.size();
return availablePartitions.get(part).partition();
} else {
// 消息有key就做hash后再取模
return DefaultPartitioner.toPositive(Utils.murmur2(keyBytes)) % numPartitions;
}
}
}
DefaultPartitioner.java
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- org.springframework.beans.factory.UnsatisfiedDependencyEx...
- 1.有很多人是通过自学,比如买些专业的java书籍、或者通过网上免费视频学习、进入相应的java论坛等等。ja...
- 深圳一年的雨差不多都在这个月给下完了,从最开始的惊喜,喜欢到后面下着下着就越来越厌烦了。因为每天外出都要多带...