• 03-Kafka之基本概念


    Kafka是最初由Linkedin公司开发,是一个分布式、支持分区的、多副本的,基于zookeeper协调的分布式消息系统,它的最大的特性就是可以实时的处理大量数据以满足各种需求场景:比如基于hadoop的批处理系统、低延迟的实时系统、Storm/Spark流式处理引擎,web/nginx日志、访问日志,消息服务等等,用scala语言编写,Linkedin于2010年贡献给了Apache基金会并成为顶级开源项目。
    一、kafka的使用场景
    1、日志收集
    一个公司可以用Kafka收集各种服务的log,通过kafka以统一接口服务的方式开放给各种consumer,例如hadoop、Hbase、Solr等
    2、消息系统
    解耦生产者和消费者、缓存消息等
    3、用户活动跟踪
    Kafka经常被用来记录web用户或者app用户的各种活动,如浏览网页、搜索、点击等活动,这些活动信息被各个服务器发布到kafka的topic中,然后订阅者通过订阅这些topic来做实时的监控分析,或者装载到hadoop、数据仓库中做离线分析和挖掘
    4、运营指标
    Kafka也经常用来记录运营监控数据。包括收集各种分布式应用的数据,生产各种操作的集中反馈,比如报警和报告

    二、Kafka基本概念
    1、Broker
    消息中间件处理节点,一个Kafka节点就是一个broker,一个或者多个Broker可以组成一个Kafka集群
    2、Topic
    Kafka根据topic对消息进行归类,发布到Kafka集群的每条消息都需要指定一个topic
    3、Producer
    消息生产者,向Broker发送消息的客户端
    4、Consumer
    消息消费者,从Broker读取消息的客户端
    5、ConsumerGroup
    每个Consumer属于一个特定的Consumer Group,一条消息可以被多个不同的Consumer Group消费,但是一个Consumer Group中只能有一个Consumer能够消费该消息
    6、Partition
    物理上的概念,一个topic可以分为多个partition,每个partition内部消息是有序的

    三、主题Topic和消息日志Log
    Topic是一个类别的名称,同类消息发送到同一个Topic下面。对于每一个Topic,下面可以有多个分区(Partition)日志文件

    Partition是一个有序的message序列,这些message按顺序添加到一个叫做commit log的文件中。每个partition中的消息都有一个唯一的编号,称之为offset,用来唯一标示某个分区中的message。每个partition,都对应一个commit log文件。一个partition中的message的offset都是唯一的,但是不同的partition中的message的offset可能是相同的
    kafka一般不会删除消息,不管这些消息有没有被消费。只会根据配置的日志保留时间(log.retention.hours)确认消息多久被删除,默认保留最近一周的日志消息。kafka的性能与保留的消息数据量大小没有关系,因此保存大量的数据消息日志信息不会有什么影响
    每个consumer是基于自己在commit log中的消费进度(offset)来进行工作的。在kafka中,消费offset由consumer自己来维护;一般情况下按照顺序逐条消费commit log中的消息,当然可以通过指定offset来重复消费某些消息,或者跳过某些消息。这意味kafka中的consumer对集群的影响是非常小的,添加一个或者减少一个consumer,对于集群或者其他consumer来说,都是没有影响的,因为每个consumer维护各自的消费offset

    为什么要对Topic下数据进行分区存储?

    • commit log文件会受到所在机器的文件系统大小的限制,分区之后可以将不同的分区放在不同的机器上,相当于对数据做了分布式存储,理论上一个topic可以处理任意数量的数据
    • 提高并行度
  • 相关阅读:
    Java中抽象类与抽象方法、abstract的使用
    Android 设计模式—模板方法模式
    Python内置函数(55)——round
    大数据之DStream 转换 完整使用 (第十四章)
    go操作mysql
    Linux C/C++ 处理命令行参数
    c++中的deque容器和queue容器
    零基础数模之回归专题
    在安卓项目中使用 FFmpeg 实现 GIF 拼接(可扩展为实现视频会议多人同屏效果)
    [python]centos7安装python
  • 原文地址:https://blog.csdn.net/qq_39234967/article/details/126451953