Kafka基本原理
Kafka的使用场景
日志收集:一个公司可以用Kafka收集各种服务的log,通过kafka以统一接口服务的方式开放给各种consumer,例如hadoop、Hbase、Solr等。
消息系统:解耦和生产者和消费者、缓存消息等。
用户活动跟踪:Kafka经常被用来记录web用户或者app用户的各种活动,如浏览网页、搜索、点击等活动,这些活动信息被各个服务器发布到kafka的topic中,然后订阅者通过订阅这些topic来做实时的监控分析,或者装载到hadoop、数据仓库中
做离线分析和挖掘。
运营指标:Kafka也经常用来记录运营监控数据。包括收集各种分布式应用的数据,生产各种操作的集中反馈,比如报警和报告。

Kafka基本概念
基础的消息(Message)相关术语
|
名称
|
解释
|
|
Broker
|
消息中间件处理节点,一个Kafka节点就是一个broker,一个或者多个Broker可以组成一个Kafka集群
|
|
Topic
|
Kafka根据topic对消息进行归类,发布到Kafka集群的每条消息都需要指定一个topic
|
|
Producer
|
消息生产者,向Broker发送消息的客户端
|
|
Consumer
|
消息消费者,从Broker读取消息的客户端
|
|
ConsumerGroup
|
每个Consumer属于一个特定的Consumer Group,一条消息可以被多个不同的Consumer Group消费,但是一个Consumer Group中只能有一个Consumer能够消费该消息
|
|
Partition
|
物理上的概念,一个topic可以分为多个partition,每个partition内部消息是有序的
|
因此,从一个较高的层面上来看,producer通过网络发送消息到Kafka集群,然后consumer来进行消费,如下图:


浙公网安备 33010602011771号