自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一文帶你搞懂 Mmap 技術(shù)

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

大家好,我是樹哥。

相信大家在面試的時(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ì)檢測(cè)到這一操作,然后根據(jù)不同場(chǎng)景去做讀磁盤或者寫磁盤的操作。

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

責(zé)任編輯:武曉燕 來源: 樹哥聊編程
相關(guān)推薦

2021-09-07 09:46:40

JavaScriptGenerator函數(shù)

2021-09-11 10:41:27

PythonPickle模塊

2024-11-19 13:20:55

2021-08-05 06:54:05

觀察者訂閱設(shè)計(jì)

2021-12-01 11:40:14

Python 輸入輸出

2021-11-06 10:18:30

Python變量常量

2024-04-12 12:19:08

語言模型AI

2022-03-24 08:51:48

Redis互聯(lián)網(wǎng)NoSQL

2021-09-28 07:12:10

avaScriptCurrying柯里化

2021-07-21 09:24:25

MongoDB數(shù)據(jù)庫 Python

2021-03-22 10:05:59

netstat命令Linux

2023-09-08 08:20:46

ThreadLoca多線程工具

2023-09-15 12:00:01

API應(yīng)用程序接口

2022-08-03 08:01:16

CDN網(wǎng)站服務(wù)器

2022-09-27 08:00:00

零售商數(shù)據(jù)數(shù)據(jù)匹配

2020-02-21 20:10:13

搞懂事務(wù)隔離級(jí)別

2021-11-20 10:27:43

Python數(shù)據(jù)類型

2021-11-22 06:21:31

Python數(shù)據(jù)類型Python基礎(chǔ)

2020-05-11 14:35:11

微服務(wù)架構(gòu)代碼

2021-03-06 08:04:46

NginxHttpHttps
點(diǎn)贊
收藏

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