日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

大家好,我是樹哥。

相信大家在面試的時(shí)候會(huì)被問到:Kafka 為啥會(huì)這么快?其中我們都會(huì)說是因?yàn)?zero-copy 的緣故,但 zero-copy 中其實(shí)有很多種實(shí)現(xiàn)方式,例如:mmap + write、sendfile 等等。這其中的 mmap 到底是咋回事呢?今天我們就來講講 mmap 技術(shù)。

mmap 是一種內(nèi)存映射文件的方法,即將一個(gè)文件或者其它對(duì)象映射到進(jìn)程的地址空間,實(shí)現(xiàn)文件磁盤地址和進(jìn)程虛擬地址空間中一段虛擬地址的一一對(duì)映關(guān)系。

那么 mmap 技術(shù)有啥用呢?

答案是:減少數(shù)據(jù)文件復(fù)制,提高效率。

想一下我們讀取文件,然后將其通過網(wǎng)卡發(fā)送出去的流程,其整體流程如下所示:

圖片

圖片來自知乎博主艾小仙

上述數(shù)據(jù)讀取和發(fā)送過程發(fā)生了 4 次用戶態(tài)和內(nèi)核態(tài)的上下文切換和 4 次拷貝,具體流程如下:

  1. 用戶進(jìn)程通過 read () 方法向操作系統(tǒng)發(fā)起調(diào)用,此時(shí)進(jìn)程從用戶態(tài)轉(zhuǎn)向內(nèi)核態(tài)。
  2. DMA 控制器把數(shù)據(jù)從硬盤中拷貝到讀緩沖區(qū)。
  3. CPU 把讀緩沖區(qū)數(shù)據(jù)拷貝到應(yīng)用緩沖區(qū),上下文從內(nèi)核態(tài)轉(zhuǎn)為用戶態(tài),read () 返回
  4. 用戶進(jìn)程通過 write () 方法發(fā)起調(diào)用,上下文從用戶態(tài)轉(zhuǎn)為內(nèi)核態(tài)
  5. CPU 將應(yīng)用緩沖區(qū)中數(shù)據(jù)拷貝到 socket 緩沖區(qū)
  6. DMA 控制器把數(shù)據(jù)從 socket 緩沖區(qū)拷貝到網(wǎng)卡,上下文從內(nèi)核態(tài)切換回用戶態(tài),write () 返回

可以看到數(shù)據(jù)要從內(nèi)核空間的讀緩沖區(qū)讀取到用戶空間的用戶緩沖區(qū),再拷貝到內(nèi)核空間的 socket 緩沖區(qū),這個(gè)過程其實(shí)是很浪費(fèi)時(shí)間的。而 mmap 技術(shù)的出現(xiàn),就是為了提高這個(gè)效率。 使用 mmap 技術(shù)進(jìn)行文件讀寫操作的過程如下圖所示:

圖片

圖片來自知乎博主艾小仙

整個(gè)過程發(fā)生了 4 次用戶態(tài)和內(nèi)核態(tài)的上下文切換和 3 次拷貝,具體流程如下:

  1. 用戶進(jìn)程通過 mmap () 方法向操作系統(tǒng)發(fā)起調(diào)用,上下文從用戶態(tài)轉(zhuǎn)向內(nèi)核態(tài)
  2. DMA 控制器把數(shù)據(jù)從硬盤中拷貝到讀緩沖區(qū)
  3. 上下文從內(nèi)核態(tài)轉(zhuǎn)為用戶態(tài),mmap 調(diào)用返回
  4. 用戶進(jìn)程通過 write () 方法發(fā)起調(diào)用,上下文從用戶態(tài)轉(zhuǎn)為內(nèi)核態(tài)
  5. CPU 將讀緩沖區(qū)中數(shù)據(jù)拷貝到 socket 緩沖區(qū)
  6. DMA 控制器把數(shù)據(jù)從 socket 緩沖區(qū)拷貝到網(wǎng)卡,上下文從內(nèi)核態(tài)切換回用戶態(tài),write () 返回

使用了 mmap 方式的文件讀寫節(jié)省了一次 CPU 拷貝,我們不需要再次從內(nèi)核空間拷貝到用戶空間,然后再從用戶空間拷貝到內(nèi)核空間。

此時(shí)我們會(huì)想:那這到底是怎么實(shí)現(xiàn)的呢?

其實(shí)這一切的背后都是操作系統(tǒng)的功勞。操作系統(tǒng)在這背后為我們做好了所有的映射和回寫工作。當(dāng)我們對(duì)內(nèi)存特定區(qū)域進(jìn)行讀寫時(shí),操作系統(tǒng)便會(huì)檢測到這一操作,然后根據(jù)不同場景去做讀磁盤或者寫磁盤的操作。

看到這里,對(duì)于 mmap 的理解基本上足夠我們應(yīng)用開發(fā)人員使用了。

分享到:
標(biāo)簽:map
用戶無頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績?cè)u(píng)定