获取kafka消费覆盖比例,最大lag,平均lag的方法

上代码:

public class ConsumerLagApply {

    public static void main(String[] args) {
        String ipPort="kafkaClusterIpPort";
        String consumerGroup="consumerGroup";
        String topic="topic";

        int partitionCount=0 ;
        long totalLag=0;
        long maxLag=0;
        int lagIsNotNull=0;
        BasicInfo basicInfo = new BasicInfo();
        KafkaConsumer consumer = basicInfo.kafkaConsumer(ipPort, consumerGroup);

        List<PartitionInfo> partitions = consumer.partitionsFor(topic);
            for (PartitionInfo partition : partitions) {
            TopicPartition topicPartition = new TopicPartition(partition.topic(), partition.partition());

            // 计算单个分区的lag
            consumer.assign(Collections.singletonList(topicPartition));

            consumer.seekToEnd(Collections.singletonList(topicPartition));
            long endOffset = consumer.position(topicPartition);
            if (endOffset!=0){
                lagIsNotNull++;
            }
            consumer.seek(topicPartition,consumer.position(topicPartition));
            long currentOffset = consumer.position(topicPartition);
            long lag = endOffset - currentOffset;

            maxLag = Math.max(maxLag, lag);
            totalLag += lag;
            partitionCount++;
        }

        double averageLag = totalLag / (double) partitionCount;
        double ratioConsumer = lagIsNotNull / (double) partitionCount;
        DecimalFormat decimalFormat = new DecimalFormat("0.0%");
        String ConsumerRatio = decimalFormat.format(ratioConsumer);
        System.out.println("Consumer coverage ratio: " + ConsumerRatio+",maxLag: "+maxLag+",avgLag: "+averageLag);
        consumer.close();
    }
}
  • 11
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_49457994

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值