偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

高并發(fā)場(chǎng)景下,Kafka如何抗住億級(jí)流量?

云計(jì)算 Kafka
順序?qū)懭霑r(shí),磁頭只需要很少的移動(dòng),甚至可以認(rèn)為是“步進(jìn)式”地寫入,避免了隨機(jī)寫入時(shí)大量的磁頭移動(dòng),從而顯著提升寫入速度。

順序?qū)懘疟P

Kafka 之所以能夠?qū)崿F(xiàn)高吞吐量,順序?qū)懘疟P是其核心優(yōu)化策略之一。

如下圖所示:

最新文章最新文章

Partition-0
 ├──00000000000000000000.log
 ├──00000000000000000000.index
 ├──00000000000000000000.timeindex
 ├──00000000000000000100.log
 ├──...

Kafka中每個(gè)主題分區(qū)對(duì)應(yīng)一個(gè)日志文件(Log),消息以二進(jìn)制形式順序?qū)懭朐撐募?/span>

并為每條消息分配唯一偏移量(offset),用于定位和順序讀取。

新的消息總是被追加到日志文件的末尾,就像寫日志一樣,只能在文件尾部添加新的記錄。

順序?qū)懭霑r(shí),磁頭只需要很少的移動(dòng),甚至可以認(rèn)為是“步進(jìn)式”地寫入,避免了隨機(jī)寫入時(shí)大量的磁頭移動(dòng),從而顯著提升寫入速度。

Page Cache

Kafka 寫入消息時(shí),并不是立刻將數(shù)據(jù)同步寫入磁盤,而是先寫入操作系統(tǒng)的 PageCache,再由操作系統(tǒng)異步刷盤。

這種設(shè)計(jì)實(shí)現(xiàn)了高吞吐 + 可持久化保障的完美平衡。

如下圖所示:

最新文章最新文章

Producer-->KafkaBroker(接收消息)-->寫入內(nèi)存頁緩存(PageCache)-->刷寫到磁盤文件(*.log)

Page Cache :是操作系統(tǒng)內(nèi)核利用空閑的物理內(nèi)存,來緩存最近訪問過的磁盤數(shù)據(jù)。

當(dāng)應(yīng)用程序?qū)懭胛募r(shí),數(shù)據(jù)首先被寫入到 Page Cache 中,這個(gè)過程是在內(nèi)存中完成的,速度非???。

為什么快?

因?yàn)閷懭雰?nèi)存(Page Cache),比直接寫入磁盤要快得多。

KafkaProducer 將消息發(fā)送到 Broker,Broker 將消息追加到其分區(qū)日志文件的 Page Cache 中。

從而,無需等待磁盤 I/O 完成,從而實(shí)現(xiàn)了高吞吐量的寫入。

零拷貝

當(dāng) Broker ,需要將消息發(fā)送給 Consumer 時(shí),Kafka 利用操作系統(tǒng)的零拷貝技術(shù)(如 sendfile)。

// Kafka 的 FileRecords 類中
 channel.transferTo(position, count, targetChannel);

最新文章最新文章

底層調(diào)用的就是 FileChannel.transferTo(),而這在 Linux 上最終就是 sendfile。

這允許數(shù)據(jù)直接從 Page Cache ,復(fù)制到網(wǎng)絡(luò)套接字緩沖區(qū),而無需經(jīng)過 Kafka Broker 的用戶空間。

磁盤→內(nèi)核緩沖區(qū)→網(wǎng)卡
 (中間不經(jīng)過用戶態(tài),少兩次拷貝)

從而,減少了數(shù)據(jù)拷貝的次數(shù)和上下文切換,顯著提高了網(wǎng)絡(luò)傳輸效率并降低了 CPU 開銷。

批量發(fā)送

Kafka Producer 會(huì)將多個(gè)消息打包成一個(gè)批次進(jìn)行發(fā)送,Consumer 也會(huì)批量地拉取消息。

最新文章最新文章

這種批量處理的方式可以減少網(wǎng)絡(luò)請(qǐng)求的次數(shù),降低網(wǎng)絡(luò)開銷,并提高吞吐量。

責(zé)任編輯:武曉燕 來源: mikechen互聯(lián)網(wǎng)架構(gòu)
相關(guān)推薦

2025-02-14 03:00:00

2025-10-16 02:11:00

SpingCloudGateway

2025-06-05 01:22:00

SpringGateway高并發(fā)

2019-11-12 09:32:35

高并發(fā)流量協(xié)議

2022-08-04 20:41:42

高并發(fā)流量SQL

2025-05-26 02:11:00

2024-05-27 08:32:45

2019-12-04 09:05:15

千萬級(jí)流量高并發(fā)

2020-07-29 07:28:14

分布式限流系統(tǒng)

2025-09-11 09:11:36

2025-08-20 09:17:41

2025-02-26 03:00:00

2025-02-28 00:03:22

高并發(fā)TPS系統(tǒng)

2025-08-22 09:06:57

2025-07-01 07:21:15

2018-10-23 09:22:06

2023-08-31 07:30:09

AIGC代碼監(jiān)測(cè)

2020-09-01 07:49:14

JVM流量系統(tǒng)

2020-01-14 10:41:45

網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全技術(shù)周刊

2021-10-14 09:51:17

架構(gòu)運(yùn)維技術(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)