1.Kafka 的设计时什么样的呢?
Kafka将消息以topic为单位进行归纳
将向Kafka topic发布消息的程序成为producers.
将预订topics并消费消息的程序成为consumer.
Kafka以集群的方式运行,可以由一一个或多个服务组成,每个服务叫做一个broker.producers通过网络将消息发送到Kafka集群,集群向消费者提供消息
2数据传输的事物定义有哪三种?
数据传输的事务定义通常有以下三种级别:
(1) 最多一次:消息不会被重复发送,最多被传输一次,但也有可能一-次不传输(2)最少一一次: 消息不会被漏发送,最少被传输一次,但也有可能被重复传输
(3)精确的一次(Exactly once) :不会漏传输也不会重复传输,每个消息都传输被一次而且仅仅被传输一次,这是大家所期望的
3.Kafka判断一个节点是否还活着有那两个条件?
(1)节点必须可以维护和ZooKeeper的连接,Zookeeper 通过心跳机制检查每个节点的连
(2)如果节点是个fllower,他必须能及时的同步leader的写操作,延时不能太久
4 producer是否直接将数据发送到broker的leader(主节点)?
producer直接将数据发送到broker的leader(主节点),不需要在多个节点进行分发,为了帮助producer做到这点,所有的Kafka节点都可以及时的告知:那些节点是活动的,日标topic目标分区的leader在哪,这样producer就可以