专业IT网络知识平台,分享IT百科知识、生活百科知识解答!

易企推科技
易企推科技

Kafka是什么

来源:小易整编  作者:小易  发布时间:2023-08-17 04:58
摘要:Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者在网站中的所有动作流数据。这种动作是在现代网络上的许多社会功能的一个关键因素。这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。Kafka是一种高吞吐量的分...

Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者在网站中的所有动作流数据。 这种动作是在现代网络上的许多社会功能的一个关键因素。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

Kafka是什么

Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者在网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是在现代网络上的许多社会功能的一个关键因素。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

对于像 Hadoop 一样的日志数据和离线分析系统,但又要求实时处理的限制,这是一个可行的解决方案。Kafka 的目的是通过 Hadoop 的并行加载机制来统一线上和离线的消息处理,也是为了通过集群来提供实时的消息。

Kafka 是由 Apache 软件基金会开发的一个开源流处理平台,由 Scala 和 Java 编写。

Kafka 最初是由领英开发,并随后于 2011 年初开源,并于 2012 年 10 月 23 日由 Apache Incubator 孵化出站。2014 年 11 月,几个曾在领英为 Kafka 工作的工程师,创建了名为 Confluent 的新公司,并着眼于 Kafka。根据 2014 年 Quora 的帖子,Jay Kreps 似乎已经将它以作家弗朗茨·卡夫卡命名。Kreps 选择将该系统以一个作家命名是因为,它是“一个用于优化写作的系统”,而且他很喜欢卡夫卡的作品。

Kafka 存储的消息来自任意多被称为“生产者”(Producer)的进程。数据从而可以被分配到不同的“分区”(Partition)、不同的“Topic”下。在一个分区内,这些消息被索引并连同时间戳存储在一起。其它被称为“消费者”(Consumer)的进程可以从分区查询消息。Kafka 运行在一个由一台或多台服务器组成的集群上,并且分区可以跨集群结点分布。

Kafka 高效地处理实时流式数据,可以实现与 Storm、HBase 和 Spark 的集成。作为聚类部署到多台服务器上,Kafka 处理它所有的发布和订阅消息系统使用了四个 API,即生产者 API、消费者 API、Stream API 和 Connector API。它能够传递大规模流式消息,自带容错功能,已经取代了一些传统消息系统,如 JMS、AMQP 等。

Kafka 架构的主要术语包括 Topic、Record 和 Broker。Topic 由 Record 组成,Record 持有不同的信息,而 Broker 则负责复制消息。Kafka 有四个主要 API:

生产者 API:支持应用程序发布 Record 流。消费者 API:支持应用程序订阅 Topic 和处理 Record 流。Stream API:将输入流转换为输出流,并产生结果。Connector API:执行可重用的生产者和消费者 API,可将 Topic 链接到现有应用程序。

相关术语

Topic 用来对消息进行分类,每个进入到 Kafka 的信息都会被放到一个 Topic 下Broker 用来实现数据存储的主机服务器Partition 每个 Topic 中的消息会被分为若干个 Partition,以提高消息的处理效率Producer 消息的生产者Consumer 消息的消费者Consumer Group 消息的消费群组

Kafka 的性能

由于其广泛集成到企业级基础设施中,监测 Kafka 在规模运行中的性能成为一个日益重要的问题。监测端到端性能,要求跟踪所有指标,包括 Broker、消费者和生产者。除此之外还要监测 ZooKeeper,Kafka 用它来协调各个消费者。当前有一些监测平台可以跟踪卡夫卡的性能,有开源的,如领英的 Burrow;也有付费的,如 Datadog。除了这些平台之外,收集 Kafka 的数据也可以使用工具来进行,这些工具一般需要 Java,包括 JConsole。


本文地址:网络知识频道 https://www.hkm168.com/jiqiao/1028273.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!


网络知识
小编:小易整编
相关文章相关阅读
  • 某台微机安装的是64位操作系统中,64位指的是什么

    某台微机安装的是64位操作系统中,64位指的是什么

    某台微机安装的是64位操作系统中,64位指的是cpu的字长,即cpu每次能处理64位二进制数据。字长是cpu的主要技术指标之一,指的是cpu一次能并行处理的二进制位数,字长总是8的整数倍,通常pc机的字长为32位,64位。本教程操作环境:w...

  • c语言是什么意思

    c语言是什么意思

    一:c语言是什么意思C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言,以及不需要任何运行环境支持便能运行的高效率程序设计语言。尽管C语言提供了许多低...

  • skype是什么软件

    skype是什么软件

    skype是一种简单的免费软件,使您能够在数分钟之内在世界上的任何角落拨打免费电话,它使用全新的p2p【对等】技术将您与其他skype用户相连接。Skype是一种简单的免费软件,使您能够在数分钟之内在世界上的任何角落拨打免费电话。Sky...

  • 计算机的三类总线分别是什么?

    计算机的三类总线分别是什么?

    计算机的三类总线分别是:控制总线、地址总线和数据总线。控制总线用于将微处理器控制单元的信号,传送到周边设备;地址总线用来指定在ram之中储存的数据的地址;数据总线用于在cpu与ram之间来回传送需要处理或是需要储存的数据。总线(Bus)是计...

  • 2k屏幕是什么意思

    2k屏幕是什么意思

    2k屏幕是指分辨率能够达到2560*1440的屏幕。2k是一个通用术语,指屏幕或者内容的水平分辨率达约2000像素的分辨率等级;又因“16:9”的比例是高清晰度视频规格的国际标准,所以2k分辨率在视频制作、显示屏等领域常见格式为2560*1...

  • mysql中的不等于符号是什么

    mysql中的不等于符号是什么

    mysql中的不等于符号有两种:“!=”和“”;它们都可用于判断数字、字符串、表达式是否不相等。对于“!=”和“”,如果两侧操作数不相等,返回值为1,否则返回值为0;如果两侧操作数有一个是null,那么返回值也是null。本教程操作环境:w...

  • ipad a1822是什么型号

    ipad a1822是什么型号

    ipada1822是苹果ipad第5代的型号;ipad第5代是苹果公司于2017年03月21日在美国加利福尼亚州发布的平板电脑;该机型采用铝镁合金材质一体成型结构;前端外框为白色或黑色;有银色、金色和深空灰色3种外观颜色。本教程操作环境:...

  • html中浮动是什么

    html中浮动是什么

    在html中,浮动就是让元素可以向左或向右移动,直到它的外边距碰到其父级的内边距或者是上一个元素的外边距,只需要给元素设置“float:left|right|none|inherit”样式即可。本教程操作环境:windows7系统、CSS3...

  • 周排行
  • 月排行
  • 年排行

精彩推荐