?Kafka自带常用工具
Kafka的bin目录下shell脚本是kafka自带的管理工具,提供topic的创建/删除/配置修改、消费者的监控、分区重载、集群健康监控、收发端TPS压测、跨机房同步等能力,Kafka运维者可以使用这些工具进行集群的管理。
Kafka节点的启/停
###kafka 运行
bin/kafka-server-start.sh -daemon ../config/server.properties &
###kafka 停止
bin/kafka-server-stop.sh
如果上面命令并未停止掉相应的进程,建议执行kill –s TERM $pid,完成进程关闭。
Topic的创建/删除/配置修改
Kafka的bin目录下有若干shell脚本,提供很多工具,完成kafka的元数据的监控和管理。
##创建topic
./kafka-topics.sh --zookeeper xxxx --replication-factor 3 --partitions 10 --create --topic xxxx
##查看topic
./kafka-topics.sh --zookeeper xxxx --describe –topic xxxx
##-删除topic
./kafka-topics.sh --delete --zookeeper xxxx--topic xxxx
## 查看集群中的topic
./kafka-topics.sh --zookeeper xxxx –list
## 查看指定topic配置
./kafka-topics.sh --zookeeper xxxx --describe --topic xxx
## 修改超时时长
./kafka-topics.sh --zookeeper xxxx --alter --topic xxxx --config retention.ms=864000
## 增加topic分区数
./kafka-topics.sh --zookeeper xxxx --alter --partitions 5 --topic xxxx
Topic的生产/消费
## kafka生产消息
./kafka-console-producer.sh --broker-list xxxx --topic xxxx
## 消费kafka 若不需要重头消费,去掉from-beginning
./kafka-console-consumer.sh --zookeeper xxxx --topic xxxx -from-beginning
查看/修改消费偏移量
## kafka_0.10前查看kafka的消费积压
./kafka-run-class.sh kafka.tools.ConsumerOffsetChecker --zookeeper xxxx --topic xx -group xx
## kafka_1.0新版本后查看kafka的消费积压
./kafka-consumer-groups.sh --bootstrap-server xxxx --describe --group xxx
## 修改zk中保存的偏移量
./zkCli.sh –server xxxx:xxset /consumer/xxx/xx
## 修改kafka中保存的偏移量 kafka_0.10前版本不支持修改偏移量操作,0.11后版本支持
./kafka-consumer-groups.sh --bootstrap-server xxxx –group xxx –topic xxx:xx –shift-by xxxx --execute
Topic的分区重载
一般分区重载在集群新加节点(kafka集群增加节点后,旧topic不会进行数据的重载)和分区备份列表扩增的时候需要用到,分区重载需要预先设定重载的json配置文件;
##指定需要分配的broker列表
./bin/kafka-reassign-partitions.sh --zookeeper xxxx --topics-to-move-json-file xx.json --broker-list "1,2,3,4,5" --generate b
##执行重载计划
./kafka-reassign-partitions.sh --zookeeper xxxx --reassignment-json-file xxx.json –execute
##验证重载计划
./kafka-reassign-partitions.sh --zookeeper xxxx --reassignment-json-file xxx.json --verify
Kafka常见问题
处理Kafka常见问题的思路是首先检查集群健康,在实时监控集群节点运行日志的基础上找出影响集群状态的问题,broker状态不正常会导致发端问题和消费积压,确认集群节点正常后,发送端和消费端的问题可以通过调优解决.
Broker常见问题
1、分区ISR列表出现频繁Expanding, Shinking,导致broker不可用:
Kafka的集群中有节点日志出现大量的ISR列表频繁Expanding, Shinking问题造成当前节点不可用问题,该问题出现的原因为:Kafka的每个topic有若干个分区partition,每个partiton可能有多个备份,这样就单个分区而言,多个备份中有leader和follower两种角色,follower会定时从leader同步数据,每个分区都有一个ISR列表,该列表表征了分区的多个备份是否在同步中,若follower挂掉或者网络抖动,则被移除ISR列表,若恢复正常,则加入到ISR列表。
若出现ISR频繁的Expanding和 Shinking表明可能是单个分区的数据量过大导致部分分区的follower无法及时备份,或者follower无法及时同步足够的消息已满足ISR判定条件,从而被Shinking清除出ISR列表,瞬间又追上复制速度,从而Expanding加入到ISR列表。
解决方法:修改kafka的配置文件,增加单个broker的复制数据的线程数,降低ISR列表判定条件(时长+条数)。
本文暂时没有评论,来添加一个吧(●'◡'●)