国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

圖解|什么是缺頁錯誤Page Fault

開發 前端
上周大白有事停更1次,最近在想如何讓大家在10分鐘中有所收獲,于是準備搞一個"什么是xxx"系列,寫一些精悍的知識點。

 

[[332325]]

本文轉載自微信公眾號「后端技術指南針 」,作者程序員大白啊 。轉載本文請聯系公眾號。

1.號外號外

各位老鐵,大家好!

上周大白有事停更1次,最近在想如何讓大家在10分鐘中有所收獲,于是準備搞一個"什么是xxx"系列,寫一些精悍的知識點。

先拋一道阿里面試題給大家熱熱身,引出今天的主角-缺頁異常Page Fault。

談談對缺頁異常Page Fault的理解。

話不多說,集合上車。

 

2. 術語約定

  • VA:Virtual Address 虛擬地址
  • PA:Physical Address 物理地址
  • MMU:Memory Manage Unit 內存管理單元
  • TLB:Translation Lookaside Buffer 旁路快表緩存/地址變換高速緩存
  • PTE:Page Table Entry 分頁表項

3. 內存的惰性分配

以32位的Linux系統為例,每個進程獨立擁有4GB的虛擬地址空間,根據局部性原理沒有必要也不可能為每個進程分配4GB的物理地址空間。

64位系統也是一樣的道理,只不過空間尋址范圍大了很多很多倍,進程的虛擬地址空間會分為幾個部分:

 

實際上只有程序運行時用到了才去內存中尋找虛擬地址對應的頁幀,找不到才可能進行分配,這就是內存的惰性(延時)分配機制。

 

對于一個運行中的進程來說,不是所有的虛擬地址在物理內存中都有對應的頁,如圖展示了部分虛擬地址存在對應物理頁的情況:

 

虛擬地址空間根據固定大小一般是4KB進行劃分,物理內存可以設置不同的頁面大小,通常物理頁大小和虛擬頁大小是一樣的,本文按照物理頁4KB大小展開。

經過前面的分析,我們將面臨一個問題:如何將虛擬地址準確快速地映射到物理頁呢?

>>>高能預警 敲黑板 本段小結<<<

  • 1. Linux的虛擬地址空間就是空頭支票,看著很大但是實際對應的物理空間只有很少的一部分。
  • 2.內存的惰性分配是個有效的機制,可以保證內存利用率和服務器利用率,是資源合理配置的方法。
  • 3.大量的虛擬地址到物理地址的快速準確地查詢轉換是一個難題。

4. CPU如果獲取內存中的數據

CPU并不直接和物理內存打交道,而是把地址轉換的活外包給了MMU,MMU是一種硬件電路,其速度很快,主要工作是進行內存管理,地址轉換只是它承接的業務之一。

 

一起看看MMU是如何搞定地址轉換的。

4.1 MMU和Page Table

每個進程都會有自己的頁表Page Table,頁表存儲了進程中虛擬地址到物理地址的映射關系,所以就相當于一張地圖,MMU收到CPU的虛擬地址之后開始查詢頁表,確定是否存在映射以及讀寫權限是否正常,如圖:

 

對于4GB的虛擬地址且大小為4KB頁,一級頁表將有2^20個表項,頁表占有連續內存并且存儲空間大,多級頁表可以有效降低頁表的存儲空間以及內存連續性要求,但是多級頁表同時也帶來了查詢效率問題。

 

我們以2級頁表為例,MMU要先進行兩次頁表查詢確定物理地址,在確認了權限等問題后,MMU再將這個物理地址發送到總線,內存收到之后開始讀取對應地址的數據并返回。

 

MMU在2級頁表的情況下進行了2次檢索和1次讀寫,那么當頁表變為N級時,就變成了N次檢索+1次讀寫。

可見,頁表級數越多查詢的步驟越多,對于CPU來說等待時間越長,效率越低,這個問題還需要優化才行。

>> 本段小結 敲黑板 劃重點 <<

  • 1.頁表存在于進程的內存之中,MMU收到虛擬地址之后查詢Page Table來獲取物理地址。
  • 2.單級頁表對連續內存要求高,于是引入了多級頁表,但是多級頁表也是一把雙刃劍,在減少連續存儲要求且減少存儲空間的同時降低了查詢效率。

4.2 MMU和TLB的故事

MMU和TLB的故事就這樣開始了...

CPU覺得MMU干活雖然賣力氣,但是效率有點低,不太想繼續外包給它了,這一下子把MMU急壞了。

 

MMU于是找來了一些精通統計的朋友,經過一番研究之后發現CPU用的數據經常是一小搓,但是每次MMU都還要重復之前的步驟來檢索,害,就知道埋頭干活了,也得講究方式方法呀!

找到瓶頸之后,MMU引入了新武器,江湖人稱快表的TLB,別看TLB容量小,但是正式上崗之后干活還真是不含糊。

 

當CPU給MMU傳新虛擬地址之后,MMU先去問TLB那邊有沒有,如果有就直接拿到物理地址發到總線給內存,齊活。

TLB容量比較小,難免發生Cache Miss,這時候MMU還有保底的老武器頁表 Page Table,在頁表中找到之后MMU除了把地址發到總線傳給內存,還把這條映射關系給到TLB,讓它記錄一下刷新緩存。

 

TLB容量不滿的時候就直接把新記錄存儲了,當滿了的時候就開啟了淘汰大法把舊記錄清除掉,來保存新記錄,彷佛完美解決了問題。

 

在TLB和Page Table加持之下,CPU感覺最近MMU比較給力了,就問MMU怎么做到的?MMU就一五一十告訴了CPU。

CPU說是個不錯的路子,隨后說出了自己的建議:TLB還是有點小,緩存不命中也是經常發生的,要不要搞個大的,這樣存儲更多訪問更快?

MMU一臉苦笑說道大哥TLB很貴的,要不你給漲點外包費?話音未落,CPU就說漲工資是不可能了,這輩子都不可能了。

>>>高能預警 敲黑板 本段小結<<<

1. CPU要根據用戶進程提供的虛擬地址來獲取真實數據,但是它并不自己做而是交給了MMU。

2. MMU也是個聰明的家伙,集成了TLB來存儲CPU最近常用的頁表項來加速尋址,TLB找不到再去全量頁表尋址,可以認為TLB是MMU的緩存。

3. TLB的容量畢竟有限,為此必須依靠Page Table一起完成TLB Miss情況的查詢,并且更新到TLB建立新映射關系。

5.缺頁異常Page Fault大揭秘

設想CPU給MMU的虛擬地址在TLB和Page Table都沒有找到對應的物理頁幀或者權限不對,該怎么辦呢?

沒錯,這就是缺頁異常Page Fault,它是一個由硬件中斷觸發的可以由軟件邏輯糾正的錯誤。

 

5.1 PageFault,它來了

假如目標內存頁在物理內存中沒有對應的頁幀或者存在但無對應權限,CPU 就無法獲取數據,這種情況下CPU就會報告一個缺頁錯誤。

由于CPU沒有數據就無法進行計算,CPU罷工了用戶進程也就出現了缺頁中斷,進程會從用戶態切換到內核態,并將缺頁中斷交給內核的 Page Fault Handler 處理。

 

缺頁異常并不可怕,只要CPU要的虛擬地址經過MMU的一番尋址之后沒有找到或者找到后無權限,就會出現缺頁異常,因此觸發異常后的處理流程將是重點內容。

5.2 缺頁錯誤的分類處理

缺頁中斷會交給PageFaultHandler處理,其根據缺頁中斷的不同類型會進行不同的處理:

  • Hard Page Fault

也被稱為Major Page Fault,翻譯為硬缺頁錯誤/主要缺頁錯誤,這時物理內存中沒有對應的頁幀,需要CPU打開磁盤設備讀取到物理內存中,再讓MMU建立VA和PA的映射。

  • Soft Page Fault

也被稱為Minor Page Fault,翻譯為軟缺頁錯誤/次要缺頁錯誤,這時物理內存中是存在對應頁幀的,只不過可能是其他進程調入的,發出缺頁異常的進程不知道而已,此時MMU只需要建立映射即可,無需從磁盤讀取寫入內存,一般出現在多進程共享內存區域。

  • Invalid Page Fault

翻譯為無效缺頁錯誤,比如進程訪問的內存地址越界訪問,又比如對空指針解引用內核就會報segment fault錯誤中斷進程直接掛掉。

 

5.3 缺頁錯誤出現的原因

不同類型的Page Fault出現的原因也不一樣,常見的幾種原因包括:

  • 非法操作訪問越界

這種情況產生的影響也是最大的,也是Coredump的重要來源,比如空指針解引用或者權限問題等都會出現缺頁錯誤。

  • 使用malloc新申請內存

malloc機制是延時分配內存,當使用malloc申請內存時并未真實分配物理內存,等到真正開始使用malloc申請的物理內存時發現沒有才會啟動申請,期間就會出現Page Fault。

  • 訪問數據被swap換出

物理內存是有限資源,當運行很多進程時并不是每個進程都活躍,對此OS會啟動內存頁面置換將長時間未使用的物理內存頁幀放到swap分區來騰空資源給其他進程,當存在于swap分區的頁面被訪問時就會觸發Page Fault從而再置換回物理內存。

>>> 敲黑板 劃重點 本段小結:<<<

觸發Page Fault的原因可能有很多,歸根到底也只有幾種大類:

1. 如使用共享內存區域,沒有存儲VA->PA的映射但是存在物理頁幀的軟缺頁錯誤,在Page Table/TLB中建立映射關系即可。

2. 訪問的地址在物理內存中確實不存在,需要從磁盤/swap分區讀入才能使用,這種性能影響會比較大,因為磁盤太慢了,盡量使用高性能的SSD來降低延時。

3. 訪問的地址內存非法,缺頁錯誤會升級觸發SIGSEGV信號結束進程,這種屬于可以導致進程掛掉的一種缺頁錯誤。

 

 

 

 

6.全文總結

本文粗淺地和大家一起學習了Page Fault的相關知識點,包括Linux虛擬地址和物理地址的關系、CPU獲取內存數據的過程、MMU和TLB&頁表的協同配合、缺頁異常產生的原因和分類處理。

本文并沒有對MMU的內部機制、內核態&用戶態缺頁異常、缺頁異常處理函數等內容進行展開,主要是因為這部分內容相對晦澀,還得靠自己深入研究。

 

本文旨在把火點燃而不是把桶填滿,對于文中相關知識點,歡迎交流溝通學習。

 

責任編輯:武曉燕 來源: 后端技術指南針
相關推薦

2020-09-28 06:48:15

HTTP協議版本

2021-02-14 19:51:04

車聯網5G4G

2020-08-31 06:41:52

RSA算法

2020-08-31 07:43:58

二叉堆大頂堆存儲

2020-09-21 06:53:41

NoSQL高并發面試

2020-07-27 07:55:51

條件概率

2020-09-10 07:04:30

JSJavaScript 原型鏈

2022-07-10 21:33:31

DNS存儲公網

2021-07-06 08:59:38

頁緩存PageCache

2022-07-10 20:48:36

DHCP互聯網網絡

2020-07-13 07:54:20

緩存系統高并發

2020-07-20 08:30:37

算法哈希分布式系統

2020-12-28 11:19:06

鴻蒙HarmonyOSPage Abilit

2015-10-29 14:29:48

javascriptthis指向

2022-07-03 10:22:00

VRRPIEEE協議

2021-03-20 22:46:22

IaaSSaaSPaaS

2023-09-01 13:49:00

內存進程線程

2020-07-14 14:59:00

控制反轉依賴注入容器

2021-09-06 10:32:16

云計算云安全錯誤配置

2017-12-19 21:29:58

物聯網區塊鏈大數據
點贊
收藏

51CTO技術棧公眾號

奇米777国产一区国产二区| 黄网站在线播放| 色视频一区二区三区| 欧美aaaaa成人免费观看视频| 韩国一区二区三区美女美女秀| 国产精品性做久久久久久| 天堂中文在线视频| 国产性猛交xxxx免费看久久| 亚洲色图二区| av观看免费在线| 亚洲综合视频在线| 91成人在线| 91精品国产色综合久久不卡98口| 欧美尿孔扩张虐视频| 日本亚洲欧美成人| 欧美精品麻豆| 国产精品久久久久久久久久直播| 欧美另类极品| 国外成人在线直播| 欧美日韩另类一区| 欧美特大特白屁股xxxx| 5278欧美一区二区三区| 久久精品国产秦先生| 国产亚洲人成a在线v网站| 国产91热爆ts人妖在线| 国产九九精品| 亚洲欧美久久久久| 夜夜躁日日躁狠狠久久88av| 国产伦精品一区二区三区视频 | 日av中文字幕| 国产女人水真多18毛片18精品视频 | 99精品中文字幕在线不卡| 欧美精品人人做人人爱视频| 香港日本韩国三级| 中文字幕一区二区三中文字幕| www.日日操| 亚洲国产精品欧美一二99| 中文在线а天堂av| 国模叶桐国产精品一区| 高清不卡一区二区在线| 春色校园综合激情亚洲| 国产v亚洲v天堂无码| 久久精品欧美一区二区三区不卡 | 成人激情视频网站| caoporn免费在线视频| 91精品国产高清自在线| 国产亚洲成av人在线观看导航 | 色老头一区二区三区| 水蜜桃久久夜色精品一区的特点| 日本v片在线免费观看| 欧美综合久久久| 另类激情亚洲| av在线导航| 成人小视频在线观看免费| 伊人成人开心激情综合网| 国产三级精品视频| 综合激情婷婷| а√在线天堂官网| 九七伦理97伦理手机| 国产高清精品一区| 日韩国产在线播放| 亚洲视频你懂的| 日韩精品91亚洲二区在线观看 | 久久精品国产2020观看福利| 亚洲麻豆国产自偷在线| 蜜桃视频在线观看一区| 免费成人av| 免费在线小视频| 传媒视频在线| 免费看国产曰批40分钟| 亚洲精品免费一区二区三区| 在线视频欧美日韩精品| 日韩欧美在线视频| av成人免费在线观看| 狠狠久久婷婷| 欧美亚洲国产日韩| 98色花堂精品视频在线观看| 免费福利影院| 久久婷婷五月综合色国产香蕉| 成人18视频| 欧洲亚洲妇女av| 欧美超级乱淫片喷水| 精品精品欲导航| 在线欧美日韩国产| 亚洲国产成人高清精品| 成人精品小蝌蚪| 蜜桃专区在线| 亚洲女优视频| 狠狠干一区二区| 国产精品自产拍高潮在线观看| 亚洲小视频在线| 亚洲精品福利资源站| 精品国产成人系列| 亚洲国产欧美一区| 日韩精品一区二区三区中文不卡| 在线精品视频小说1| 欧美视频不卡中文| 欧美精品色综合| 亚洲欧美成人在线| 性色av香蕉一区二区| 国产精品yjizz| 亚洲人成77777| 男女高潮又爽又黄又无遮挡| 一区二区三区国产免费| 色婷婷成人在线| 国产主播福利在线| 日本伦理一区二区| 青草综合视频| 禁断一区二区三区在线| 日韩综合精品| 亚洲无线视频| 处破女av一区二区| 国产精品99久久不卡二区| 国产aⅴ精品一区二区三区色成熟| 国产福利一区二区| 国产精品一区免费在线观看| 成人动漫av在线| 国产美女在线精品| 激情综合五月天| 成人午夜私人影院| 中文幕一区二区三区久久蜜桃| 午夜精品久久一牛影视| 日韩视频免费观看高清完整版| www.欧美免费| 国产精品一区二区久久国产| 三级三级久久三级久久18| 亚洲午夜精品久久久久久人妖| 深夜影院在线观看| 欧美9999| 亚洲成av人片乱码色午夜| 99国产精品视频免费观看| 777a∨成人精品桃花网| 国产精品91一区| 91好吊色国产欧美日韩在线| 久草.com| 欧美三区四区| 一区三区视频| 国产亚洲精品7777| 亚洲精品v天堂中文字幕| 91香蕉亚洲精品| 亚洲精品成人a8198a| 免费看日本毛片| 麻豆视频网站在线观看| 日韩av黄色在线| 日本不卡123| 亚洲亚洲精品在线观看| 久久成人精品视频| 国产精品区一区二区三在线播放| 亚洲精品久久区二区三区蜜桃臀| 手机看片一级片| 国产盗摄在线观看| 中文字幕亚洲欧美一区二区三区| 91亚洲精品视频| 综合久久综合久久| 日韩欧美精品在线| 国产97在线亚洲| 成人黄色影视| 成人在线视频观看| 免费精品视频在线| 91精品国产麻豆国产自产在线| 国产va免费精品高清在线观看| 黄色一级二级三级| 丁香婷婷久久| 国产精品久久久久久久久快鸭 | 91美女片黄在线观| 欧美一区二区激情| 精品欧美不卡一区二区在线观看| **在线精品| 国产精品一区2区| 欧美精品乱人伦久久久久久| 久久久久久国产精品| 国产福利片一区二区| 老司机在线看片网av| 亚洲综合五月| 欧美日韩国产大片| 久久九九视频| 久久精品视频免费看| 欧美一区影院| 欧美丝袜一区二区| 57pao国产精品一区| 亚洲一区二区三区涩| 97视频在线观看网站| 在线高清一区| 欧美日韩成人激情| av在线亚洲男人的天堂| 亚洲欧美另类图片| 国产精品成人一区二区不卡| 在线日韩一区二区| 国产成人精品日本亚洲11| 完全免费av在线播放| 欧美成人首页| 亚洲片在线资源| 国产精品免费入口| 美女视频免费精品| 亚洲一区在线观看网站| 5566中文字幕一区二区| av在线电影院| 国内外成人在线视频| 久久久免费精品| 免费黄色网页在线观看|