jiaomrswang 2019-06-29
kafka 0.9 之前的版本偏移量信息是通过 zookeeper 管理的;为了避免对 zookeeper 的过度依赖,每次从 kafka 上读取 topic 偏移量信息,连接消耗还是比较大的,从 kafka 0.9 开始,kafka 已接管了偏移量信息管理功能,并将各消费组的偏移量写入了 __consumer_offsets 主题(默认50个分区);
api 方式获取某消费组的消费偏移量信息:
通过 ConsumerGroupCommand 作为入口,然后调用 ConsumerGroupService接口,该接口有如下两个实现:
该接口如下方法:
val listStrZk = "--zookeeper 192.168.xx.xx:2181 --list" //列出所有的消费组 val listStr = "--bootstrap-server 192.168.xx.xx:9092 --list --new-consumer" val listArgs = listStr.split(" ") val describeStrzk = "--zookeeper 192.168.xx.xx:2181 --describe --group 3" // 描述消费组信息 val describeStr = "--bootstrap-server 192.168.xx.xx:9092 --describe --group 6 --new-consumer" val describeArgs = describeStr.split(" ") val args = Array[String](topic,bootstrap,group,describe) // ConsumerGroupCommand.main(listArgs) ConsumerGroupCommand.main(describeArgs) /* 主题 分区 消费位移 最高日志位移 消费滞后offset * TOPIC PARTITION CURRENT-OFFSET LOG-END-OFFSET LAG CONSUMER-ID HOST CLIENT-ID test 0 2282954 2743178 460224 - - - test 1 1500 860230 858730 - - - test 4 500 860231 859731 - - - test 3 0 860228 860228 - - - test 2 0 860226 860226 - - - * */