日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

【Kafka】Kafka高性能原因

發布時間:2023/12/15 综合教程 48 生活家
生活随笔 收集整理的這篇文章主要介紹了 【Kafka】Kafka高性能原因 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Kafka是高吞吐低延遲的高并發、高性能的消息中間件,在大數據領域有極為廣泛的運用。配置良好的Kafka集群甚至可以做到每秒幾十萬、上百萬的超高并發寫入。

那么Kafka到底是如何做到這么高的吞吐量和性能的呢?這篇文章我們來一點一點說一下。


1、頁緩存技術 + 磁盤順序寫

首先Kafka每次接收到數據都會往磁盤上去寫,如下圖所示。

那么在這里我們不禁有一個疑問了,如果把數據基于磁盤來存儲,頻繁的往磁盤文件里寫數據,這個性能會不會很差?大家肯定都覺得磁盤寫性能是極差的。

沒錯,要是真的跟上面那個圖那么簡單的話,那確實這個性能是比較差的。

但是實際上Kafka在這里有極為優秀和出色的設計,就是為了保證數據寫入性能,首先Kafka是基于操作系統的頁緩存來實現文件寫入的。

操作系統本身有一層緩存,叫做page cache,是在內存里的緩存,我們也可以稱之為os cache,意思就是操作系統自己管理的緩存。

你在寫入磁盤文件的時候,可以直接寫入這個os cache里,也就是僅僅寫入內存中,接下來由操作系統自己決定什么時候把os cache里的數據真的刷入磁盤文件中。

僅僅這一個步驟,就可以將磁盤文件寫性能提升很多了,因為其實這里相當于是在寫內存,不是在寫磁盤,大家看下圖。

接著另外一個就是kafka寫數據的時候,非常關鍵的一點,他是以磁盤順序寫的方式來寫的。也就是說,僅僅將數據追加到文件的末尾,不是在文件的隨機位置來修改數據。

普通的機械磁盤如果你要是隨機寫的話,確實性能極差,也就是隨便找到文件的某個位置來寫數據。

但是如果你是追加文件末尾按照順序的方式來寫數據的話,那么這種磁盤順序寫的性能基本上可以跟寫內存的性能本身也是差不多的。

所以大家就知道了,上面那個圖里,Kafka在寫數據的時候,一方面基于了os層面的page cache來寫數據,所以性能很高,本質就是在寫內存罷了。

另外一個,他是采用磁盤順序寫的方式,所以即使數據刷入磁盤的時候,性能也是極高的,也跟寫內存是差不多的。

基于上面兩點,kafka就實現了寫入數據的超高性能。

那么大家想想,假如說kafka寫入一條數據要耗費1毫秒的時間,那么是不是每秒就是可以寫入1000條數據?

但是假如kafka的性能極高,寫入一條數據僅僅耗費0.01毫秒呢?那么每秒是不是就可以寫入10萬條數?

所以要保證每秒寫入幾萬甚至幾十萬條數據的核心點,就是盡最大可能提升每條數據寫入的性能,這樣就可以在單位時間內寫入更多的數據量,提升吞吐量。


2、零拷貝技術

說完了寫入這塊,再來談談消費這塊。

大家應該都知道,從Kafka里我們經常要消費數據,那么消費的時候實際上就是要從kafka的磁盤文件里讀取某條數據然后發送給下游的消費者,如下圖所示。

那么這里如果頻繁的從磁盤讀數據然后發給消費者,性能瓶頸在哪里呢?

假設要是kafka什么優化都不做,就是很簡單的從磁盤讀數據發送給下游的消費者,那么大概過程如下所示:

先看看要讀的數據在不在os cache里,如果不在的話就從磁盤文件里讀取數據后放入os cache。

接著從操作系統的os cache里拷貝數據到應用程序進程的緩存里,再從應用程序進程的緩存里拷貝數據到操作系統層面的Socket緩存里,最后從Socket緩存里提取數據后發送到網卡,最后發送出去給下游消費。

整個過程,如下圖所示:

大家看上圖,很明顯可以看到有兩次沒必要的拷貝吧!

一次是從操作系統的cache里拷貝到應用進程的緩存里,接著又從應用程序緩存里拷貝回操作系統的Socket緩存里。

而且為了進行這兩次拷貝,中間還發生了好幾次上下文切換,一會兒是應用程序在執行,一會兒上下文切換到操作系統來執行。

所以這種方式來讀取數據是比較消耗性能的。

Kafka為了解決這個問題,在讀數據的時候是引入零拷貝技術。

也就是說,直接讓操作系統的cache中的數據發送到網卡后傳輸給下游的消費者,中間跳過了兩次拷貝數據的步驟,Socket緩存中僅僅會拷貝一個描述符過去,不會拷貝數據到Socket緩存。

大家看下圖,體會一下這個精妙的過程:

通過零拷貝技術,就不需要把os cache里的數據拷貝到應用緩存,再從應用緩存拷貝到Socket緩存了,兩次拷貝都省略了,所以叫做零拷貝。

對Socket緩存僅僅就是拷貝數據的描述符過去,然后數據就直接從os cache中發送到網卡上去了,這個過程大大的提升了數據消費時讀取文件數據的性能。

而且大家會注意到,在從磁盤讀數據的時候,會先看看os cache內存中是否有,如果有的話,其實讀數據都是直接讀內存的。

如果kafka集群經過良好的調優,大家會發現大量的數據都是直接寫入os cache中,然后讀數據的時候也是從os cache中讀。

相當于是Kafka完全基于內存提供數據的寫和讀了,所以這個整體性能會極其的高。

轉自:http://dwz.date/brzu

總結

以上是生活随笔為你收集整理的【Kafka】Kafka高性能原因的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 在线观看视频免费 | 国产乱码一区 | 轮乱 | 国产一区二区三区久久久 | 黄色在线免费观看 | 我的公把我弄高潮了视频 | 本道久久 | 久久一区二| 天天天天| 奇米影视777第四色 2019中文字幕在线免费观看 | mm131丰满少妇人体欣赏图 | 天堂在线免费观看视频 | 医生强烈淫药h调教小说视频 | 免费一级黄色大片 | 嫦娥性艳史bd | 青苹果av | 日本少妇作爱视频 | 欧美精品久久久久久久久老牛影院 | 在线观看国产精品视频 | 国产免费网址 | 欧美在线视频第一页 | 国产人妻人伦精品1国产丝袜 | 男女爽爽爽 | 91在线精品一区二区三区 | 黑人性高潮 | 国产精品白嫩白嫩大学美女 | 麻豆影视国产在线观看 | 亚洲日本中文字幕在线 | 青青草激情视频 | av在线资源 | 国产馆视频 | 亚洲爽爽爽 | 激情欧美一区二区三区 | 成人欧美视频 | 黄色三级在线视频 | 亚洲啪啪av | 国产黄色录像 | 草比视频在线观看 | 韩国久久久久 | 一二三四区视频 | 亚洲成年人免费观看 | 91色吧 | 国产精自产拍久久久久久蜜 | 成人免费视频网站在线观看 | av波多野吉衣| 成人深夜视频 | 黄色小说在线看 | 美女张开腿让人桶 | 丁香av | 成人欧美一区二区三区黑人孕妇 | 日韩3p| 天天躁日日摸久久久精品 | wwwwww在线观看 | 免费观看黄色网页 | 天天干,夜夜操 | 激情综合视频 | 小柔的淫辱日记(h | 久久99国产精品成人 | 国产熟女一区二区三区四区 | 色婷婷一区二区三区四区 | 一级a性色生活片久久毛片 爱爱高潮视频 | 日韩电影一区二区三区四区 | 欧美资源| 泰剧19禁啪啪无遮挡 | 三级黄色图片 | 久久久久人妻精品一区二区三区 | 亚洲av成人精品一区二区三区 | 国产麻豆免费观看 | 精品一区视频 | 区一区二视频 | 久久精品五月天 | 亚洲视频日韩 | 制服诱惑一区二区三区 | 蜜臀精品一区二区三区 | 免费爱爱视频 | 亚洲免费色图 | 啪视频在线观看 | 艳妇臀荡乳欲伦交换电影 | 日韩av在线网址 | av嫩草 | 久久久男女 | 中文幕无线码中文字蜜桃 | 精品视频一区在线观看 | 久久亚洲AV成人无码国产人妖 | 中日韩欧美在线观看 | 婷婷四房综合激情五月 | 中文字幕第页 | 巨胸爆乳美女露双奶头挤奶 | 草草影院ccyycom| 亚洲熟女乱色一区二区三区 | 欧美国产另类 | 欧洲亚洲国产精品 | 青娱乐极品在线 | 黄色av一级片 | 好吊操精品视频 | 99在线精品免费视频 | 亚洲αv| 欧美中字 | 激情久久av一区av二区av三区 |