kafka基础

http://kafka.apache.org/quickstart

kafka笔记 
1/kafka是一个分布式的消息缓存系统
2/kafka集群中的服务器都叫做broker
3/kafka有两类客户端,一类叫producer(消息生产者),一类叫做consumer(消息消费者),客户端和broker服务器之间采用tcp协议连接
4/kafka中不同业务系统的消息可以通过topic进行区分,而且每一个消息topic都会被分区,以分担消息读写的负载
5/每一个分区都可以有多个副本,以防止数据的丢失
6/某一个分区中的数据如果需要更新,都必须通过该分区所有副本中的leader来更新
7/消费者可以分组,比如有两个消费者组A和B,共同消费一个topic:order_info,A和B所消费的消息不会重复
比如 order_info 中有100个消息,每个消息有一个id,编号从0-99,那么,如果A组消费0-49号,B组就消费50-99号
8/消费者在具体消费某个topic中的消息时,可以指定起始偏移量


集群安装
1、解压
2、修改server.properties(分别在3台机器上修改此文件)
broker.id=1
zookeeper.connect=wuke01:2181,wuke01:2181,wuke01:2181


broker.id=2
zookeeper.connect=wuke01:2181,wuke01:2181,wuke01:2181


broker.id=2
zookeeper.connect=wuke01:2181,wuke01:2181,wuke01:2181


3、将zookeeper集群启动


4、在每一台节点上启动broker(kafka的服务器)
bin/kafka-server-start.sh config/server.properties


5、在kafka集群中创建一个topic
bin/kafka-topics.sh –create –zookeeper weekend05:2181 –replication-factor 3 –partitions 1 –topic order


6、用一个producer向某一个topic中写入消息
bin/kafka-console-producer.sh –broker-list weekend:9092 –topic order


7、用一个comsumer从某一个topic中读取信息
bin/kafka-console-consumer.sh –zookeeper weekend05:2181 –from-beginning –topic order


8、查看一个topic的分区及副本状态信息
bin/kafka-topics.sh –describe –zookeeper weekend05:2181 –topic order


查看topic myson的结果

myson有两个partition(逻辑概念)paritition0和partition1,partition0的leader是broker0,partition1的leader是broker1,每个partition都有3个副本,Isr表示当前处于同步状态的副本




kafka命令

查看所有topic

bin/kafka-topics.sh –list –zookeeper  weekend05:2181


删除kafka数据

1、删除kafka存储目录(server.properties文件log.dirs配置,默认为”/tmp/kafka-logs”)相关topic目录

2、Kafka 删除topic的命令是:

     ./bin/kafka-topics  –delete –zookeeper 【zookeeper server】  –topic 【topic name】

     如果kafaka启动时加载的配置文件中server.properties没有配置delete.topic.enable=true,那么此时的删除并不是真正的删除,而是把topic标记为:marked for deletion

     你可以通过命令:./bin/kafka-topics –zookeeper 【zookeeper server】 –list 来查看所有topic


     此时你若想真正删除它,可以如下操作:

     (1)登录zookeeper客户端:命令:./bin/zookeeper-client

     (2)找到topic所在的目录:ls /brokers/topics

     (3)找到要删除的topic,执行命令:rmr /brokers/topics/【topic name】即可,此时topic被彻底删除。


    另外被标记为marked for deletion的topic你可以在zookeeper客户端中通过命令获得:ls /admin/delete_topics/【topic name】,

    如果你删除了此处的topic,那么marked for deletion 标记消失

    zookeeper 的config中也有有关topic的信息: ls /config/topics/【topic name】暂时不知道有什么用


总结:

彻底删除topic:

 1、删除kafka存储目录(server.properties文件log.dirs配置,默认为”/tmp/kafka-logs”)相关topic目录

 2、如果配置了delete.topic.enable=true直接通过命令删除,如果命令删除不掉,直接通过zookeeper-client 删除掉broker下的topic即可。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值