当前位置: 首页 > news >正文

消息队列kafka

消息队列解决的问题

1. 解耦,通过消息队列实现应用之间解耦,模块儿之间解耦

2. 跨线程/进程通信,通过消息队列传递数据,实现不同线程/进程间通信

3. 提升系统稳定性,在高并发场景通过消息队列缓冲,可以实现削峰填谷,使系统稳定运行,避免突发流量冲击

4. 一写多读的广播模型

kafka时延小于1ms

测试条件:producer部署在腾讯云主机,consumer部署在腾讯云主机,kafka集群使用腾讯云kafka服务,测试数据大小500字节,数据发送频率20Hz,测试时常10分钟

测试结果:26分位值时间差为0ms,98分位置为1ms,99.9分为值为2ms,最长时间4ms

kafka高性能原理

1. Kafka采用分布式集群架构,通过分区(Partition)实现并行处理。通过分区机制实现对同一队列的并发读和并发写,kafka多个分区可以分布在集群的多台机器上,从而通过充分发挥硬件资源的性能提升系统吞吐和性能,通过多消费者、多生产者并发处理大大提升了系统的吞吐量;

2. kafka数据落盘采用顺序写,大大提升了数据持久化的性能,顺序写相比随机写来说,在机械硬盘上效率顺序写要快上千倍,顺序读的效率比随机读的效率快几百倍;在固态硬盘上顺序读写也比随机读写效率高几倍到几十倍;

3. 零拷贝技术,Kafka 使用了操作系统级的零拷贝特性来减少数据在用户态和内核态之间的拷贝,从而提高了数据传输的效率;

4. Kafka使用高性能的异步网络传输技术,通过Reactor模式(事件驱动模式)来处理大量的网络连接和请求。这种设计使得Kafka能够充分利用系统资源,实现高并发、低延迟的数据传输;

5. kafka支持批量操作,Kafka的批量操作包括批量写入、批量发布、以及消费端批量读取,通过批量操作大大提升了系统吞吐量;

总结:

在分布式架构中,消息队列选型时kafka可以满足大部分场景的要求,在低时延、吞吐量、一致性、高可用等方面都表现优异。

http://www.lryc.cn/news/309522.html

相关文章:

  • 复盘成长——2024.2月复盘
  • Kafka安全模式之身份认证
  • 3、Redis-List【常用】
  • 黑马c++ STL部分 笔记(7) list容器
  • 关于使用Mxnet GPU版本运行DeepAR报错解决方案
  • 【STM32】江科大STM32学习笔记汇总(50)
  • LabVIEW非接触式电阻抗层析成像系统
  • 蓝桥杯备战刷题three(自用)
  • 密码学——二次剩余
  • 10.7、华为数通HCIP-DataCom H12-821单选题:121-140
  • 多租户篇 | MatrixOne与MySQL全面对比
  • python Matplotlib Tkinter-->导出pdf报表
  • react-组件基础
  • The authenticity of host ‘github.com (20.205.243.166)‘ can‘t be established.
  • arduino uno R3驱动直流减速电机(蓝牙控制)
  • 智能家居控制系统(51单片机)
  • 软考高级系统分析师之 URL 知识点和例题
  • vmware虚拟机centos中/dev/cl_server8/root 空间不够
  • C++/数据结构:AVL树
  • Mysql数据库_max_allowed_packet参数详解
  • 【数仓】Hadoop集群配置常用参数说明
  • 【go从入门到精通】什么是go?为什么要选择go?
  • MySQL篇—执行计划介绍(第二篇,总共三篇)
  • nest.js使用nest-winston日志一
  • LeetCode刷题笔记之二叉树(四)
  • 【MATLAB源码-第150期】基于matlab的开普勒优化算法(KOA)机器人栅格路径规划,输出做短路径图和适应度曲线。
  • 最佳实践:Websocket 长连接状态如何保持
  • Unity AStar寻路算法与导航
  • JavaScript最新实现城市级联操作,json格式的数据
  • SD NAND:为车载显示器注入智能与安全的心脏