成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一文帶你搞懂 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ì)被問(wèn)到:Kafka 為啥會(huì)這么快?其中我們都會(huì)說(shuō)是因?yàn)?zero-copy 的緣故,但 zero-copy 中其實(shí)有很多種實(shí)現(xiàn)方式,例如:mmap + write、sendfile 等等。這其中的 mmap 到底是咋回事呢?今天我們就來(lái)講講 mmap 技術(shù)。

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

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

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

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

圖片

圖片來(lái)自知乎博主艾小仙

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

  1. 用戶進(jìn)程通過(guò) 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)程通過(guò) 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è)過(guò)程其實(shí)是很浪費(fèi)時(shí)間的。而 mmap 技術(shù)的出現(xiàn),就是為了提高這個(gè)效率。 使用 mmap 技術(shù)進(jìn)行文件讀寫操作的過(guò)程如下圖所示:

圖片

圖片來(lái)自知乎博主艾小仙

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

  1. 用戶進(jìn)程通過(guò) 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)程通過(guò) 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)核空間拷貝到用戶空間,然后再?gòu)挠脩艨臻g拷貝到內(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é)任編輯:武曉燕 來(lái)源: 樹哥聊編程
相關(guān)推薦

2024-11-19 13:20:55

2021-09-07 09:46:40

JavaScriptGenerator函數(shù)

2021-09-11 10:41:27

PythonPickle模塊

2021-11-06 10:18:30

Python變量常量

2022-03-24 08:51:48

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

2021-08-05 06:54:05

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

2021-12-01 11:40:14

Python 輸入輸出

2021-07-21 09:24:25

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

2024-04-12 12:19:08

語(yǔ)言模型AI

2021-09-28 07:12:10

avaScriptCurrying柯里化

2022-08-03 08:01:16

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

2020-02-21 20:10:13

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

2020-05-11 14:35:11

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

2021-11-20 10:27:43

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

2021-11-22 06:21:31

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

2021-03-06 08:04:46

NginxHttpHttps

2022-02-14 21:17:21

RPC框架協(xié)議

2023-09-08 08:20:46

ThreadLoca多線程工具

2021-03-22 10:05:59

netstat命令Linux

2023-09-15 12:00:01

API應(yīng)用程序接口
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 人人鲁人人莫人人爱精品 | 国产精品日日夜夜 | 1000部精品久久久久久久久 | 久久噜噜噜精品国产亚洲综合 | 久久99网| 欧美成人a∨高清免费观看 老司机午夜性大片 | 黄色毛片在线观看 | 九九精品热| 久久69精品久久久久久久电影好 | 伊人久久一区二区 | 天天想天天干 | 黄色大片免费网站 | 欧美性一级 | 天天综合天天 | 黄网免费看| 精品久久99 | 国产成人一区二区三区电影 | 日本一区二区不卡 | 欧美美女爱爱视频 | 成年人黄色小视频 | 日韩国产黄色片 | 国产成人99久久亚洲综合精品 | 日本高清不卡视频 | 欧美一区二区三区免费电影 | www.99热这里只有精品 | 精品网 | 国产精品久久久久久久久久 | 国产精品爱久久久久久久 | 成年人黄色一级毛片 | 久久久免费少妇高潮毛片 | 91资源在线 | 人人精品| 久久久久国产精品一区二区 | 日韩一区二区福利视频 | 人人看人人射 | 日本h片在线观看 | 久久新| 久久久网 | 亚洲午夜精品视频 | 九九九久久国产免费 | 成人国产在线视频 |