1、总体情况
如果只是用kafka-topics.sh的delete命令删除topic,会有两种情况:
./bin/kafka-topics --delete --zookeeper 【zookeeper server】 --topic 【topic name】
-
如果当前topic没有使用过即没有传输过信息:可以彻底删除
-
如果当前topic有使用过即有过传输过信息:并没有真正删除topic只是把这个topic标记为删除(marked for deletion)
注意说明
如果kafaka启动时加载的配置文件中server.properties没有配置"delete.topic.enable=true",那么此时的删除并不是真正的删除,而是把topic标记为删除:marked for deletion
2、查看topic
你可以通过命令如下来查看所有topic:
kafka/bin/kafka-topics.sh --list --zookeeper Zookeeper地址
3、彻底删除topic
3.1登录zookeeper客户端的命令:
zookeeper/bin/zkCli.sh
3.2找到topic所在的目录:
ls /brokers/topics
3.3找到要删除的topic,执行如下命令即可,此时topic被彻底删除:
rmr /brokers/topics/topic名称
另外被标记为marked for deletion的topic你可以在zookeeper客户端中通过命令获得:
ls /admin/delete_topics/topic名称
如果你删除了此处的topic,那么marked for deletion 标记消失
zookeeper的config中也有有关topic的信息, 暂时不知道有什么用:
ls /config/topics/topic名称
4、从新创建topic
topic创建语句
bin/kafka-topics.sh --create --zookeeper IP:2181 -replication-factor 2 --partitions 3 --topic [TOPICNAME]
Due to limitations in metric names, topics with a period (’.’) or underscore (’’) could collide. To avoid issues it is best to use either, but not both.
由于度量名称的限制,带有句点(’.’)或下划线(’’)的主题可能会发生冲突。为了避免问题,最好也可以使用,但不能同时使用。
5、总结
彻底删除topic:
1、删除kafka存储目录(server.properties文件log.dirs配置,默认为"/tmp/kafka-logs")相关topic目录
2、如果配置了delete.topic.enable=true直接通过命令删除,如果命令删除不掉,直接通过zookeeper客户端删除掉broker下的topic即可。