0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

關于虛擬內核和物理內存的那些事

Linux閱碼場 ? 來源:唯美學編程 ? 作者:唯美學編程 ? 2021-05-28 15:25 ? 次閱讀

一、讓有意義的事情變的有意思

二、物理內存、虛擬內存

三、Linux 中的換頁機制

一、讓有意義的事情變的有意思昨天,看到下面這句話,送給您:

讓有意思的事情變的有意義,讓有意義的事情變的有意思!

不敢說這是一句人生哲學,但是我們可以從這句話中找到我們做一件事情時的導向。

比如:在學習 Linux 操作系統的過程中,很多枯燥無味的知識點,都是不好玩、沒有意思的事情。

但是為什么我們還要逼著自己,靜下心來啃那些大部頭書籍呢?因為這件事情有意義!

所以啊,如果能夠在這件有意義的事情上,再變得更有意思,那就可以調動我們潛在的很多積極性。

這篇文章,我們用簡單、輕松的方式,來聊一下老生常談的虛擬內核和物理內存的那些事。

二、物理內存、虛擬內存1. 從 x86 硬件角度看

在 x86 平臺上,主存儲器(也就是我們說說的內存)負責存儲指令和數據,它的作用僅次于 CPU。

離開了內存,性能再好的 CPU 也無法工作。

就像人類的大腦一樣,如果沒有了記憶功能,再怎么聰明都無法施展。

內存被劃分為若干個存儲單元,從 0 開始編號,一直到最大的那個存儲單元。

CPU 通過地址總線來定位一個內存的空間,通過數據總線從內存中讀取數據、或者向內存中寫入數據。

我們都知道,同一個 x86 平臺的硬件,既可以安裝 Windows 操作系統,也可以安裝 Linux 操作系統。

也就是說,在生產硬件的時候,它并不知道: 在自己的硬件之上,將會運行什么樣的程序。

也許會有高手直接寫一個牛逼的程序,直接來管理各種硬件資源、實現自己特定的功能呢???

不管如何,x86 平臺處理器架構定義了自己的一套規(guī)則來訪問內存。

因此,從 x86 平臺硬件角度看,只有(物理)內存這個東西,它壓根不知道什么是虛擬內存。

2. 從操作系統的角度看

操作系統最重要的功能就是:向應用程序屏蔽了各種硬件資源,提供更加友好的接口,讓程序開發(fā)變得更容易。

所以,操作系統會充分利用硬件的各種運行機制,然后進行抽象、包裝,面向應用程序開發(fā)者提供一個穩(wěn)定的環(huán)境。

那么對于內存來說,操作系統向下對物理內存進行管理,向上對應用程序提供虛擬內存。

虛擬內存,就是操作系統在應用程序與物理內存之間加入的一層抽象,加入這個抽象層之后,有很多的好處。

3. 從應用程序開發(fā)者的角度看

在很久以前,各種單片機、嵌入式 MCU 上,編寫應用程序的時候,經常會面對內存很緊張的情況,這是就要很好的來優(yōu)化自己的程序,利用有限的硬件資源來實現一些功能。

(突然想起多年之前的以為老工程師對我說,面對那么有限的一點資源,都會想哭?。?/p>

隨著硬件的快速發(fā)展,這種硬件資源緊張的情況好像很少遇到了,給我們的感覺是:內存我可以隨便用,想要多少就 malloc 多少。

當然了,操作系統會給出一些限制的,這只是操作系統層面的限制,因為它有自己的考量因素。

當應用程序提出申請一塊內存空間時,操作系統為了滿足應用程序的需求,就會從虛擬內存中“劃分”出一塊空間,然后把這個空間的開始地址返回給應用程序。

因此,從應用程序開發(fā)的角度看,我們并不關心物理內存、虛擬內存。

只要我 malloc 了,操作系統給我一個足夠的空間就行!至于這個空間是從哪里分配的,I don‘t care!

也就是說,應用程序是面向虛擬內存編寫的,而不是面向物理內存編寫的。

當然了,最終存儲數據的肯定是物理內存,至于虛擬內存如何與物理內存建立對應的映射關系,這就是由操作系統操心的事情了。

每個應用程序只能看到自己的虛擬內存空間,這是一塊連續(xù)的空間,從而保證了不同應用程序之間的隔離,達到安全目的。

三、Linux 中的換頁機制如今,我們去攢一臺 PC 機,內存條最少都是 8G、16G吧!但是在多年之前,這是非常、非常奢侈的一件事情,主要還是價格的因素。

我記得自己在做畢業(yè)設計的時候,為了保存代碼,去南京珠江路買了一個 U 盤,64G,好像是 70 塊錢。

相比內存來說,硬盤的價格就便宜多了!

因此,Linux 操作系統就充分利用硬盤來糊弄應用程序,讓應用程序覺得有永遠也用不完的內存資源。

在一個 32 位的系統中,應用程序可以訪問的最大內存空間是 2 的 32 次方,也就是 4 GB,即使此時實際的物理內存并沒有這么大。

其實這就類似于一家旅館,假如有一個老板,開了一家旅館,一共有 1000 個房間。

同時,老板還有一個空間更大的倉庫,倉庫里可以放 10000 個床鋪。這個老板很聰明,他明白 2 個事實情況:

旅行團或顧客只能看到這個旅館的門頭和大廳,并不知道旅館里面的房間布局;

旅行團并不會在同一時刻、扎堆的同時來住宿;

因此老板在對外宣傳的時候,就說:我的旅館很大,有 10000 個房間,歡迎前來入??!

為了簡化問題,我們假設每個旅行團有 100 人。

在某個時間,當有第一批的 3 個旅行團入住的時候,老板覺得房間足夠,于是把這 300 人都安排在旅館的房間中。

過了一會,又來了第二批 4 個旅行團,此時總的住宿人數變成了 700 人。

老板開始計算:一共就 1000 個房間,現在消耗掉 700 個了,還剩 300 個,還能撐一會。

沒多久,第三批顧客上門了,這回是 5 個旅行團的人數:500 人 。因為老板宣傳說:有 10000 個房間,充足的很。

老板在面對這新的 500 個人時,只見他從容的把第一批和第二批的 700 個人,從房間中轉移到倉庫。

我們假設顧客都處于睡眠狀態(tài),僅僅需要一張床而已,不需要消耗其他的資源。

然后把這新的 500 人,安排在房間中入住。

此時,一共入住了 300 + 400 + 500 = 1200 人,雖然旅館只有 1000 個房間,但是通過借用倉庫去暫時存放處于睡眠狀態(tài)的顧客,此時旅館中還剩下 500 個空閑的房間。

還可以繼續(xù)接待客人。。

當到了 第一批的 3 個旅行團退房的時間時,老板再把這 300 人從倉庫中 偷偷地轉移到旅館的房間中。這些客人醒來一看,還是我入睡時的那個環(huán)境,很好很好。。。

以上這個過程,就非常類似 Linux 系統中虛擬內存的換頁方式:

虛擬內存 = 對外宣傳的 10000 個房間;

物理內存 = 實際的 1000 個房間;

硬盤 = 只有床鋪的倉庫。

當物理內存不夠的時候,操作系統把一些物理內存頁的內存暫時存儲到空間更大、價格更便宜的硬盤上,然后就可以回收這些物理內存繼續(xù)使用了。

怎么樣,通過這樣的類比方式,是不是對 Linux 系統中的虛擬內存有更加感性的認識?

最后,再向你安利一下文章開頭的那句話:

當你面對一件有意義、但是沒意思的事情時,不妨考慮給它加點意思;而當你面對有意思、但是沒意義的事情時,也可以給它賦予一些意義!

原文標題:Linux系統是如何用虛擬內存來欺騙應用程序的?

文章出處:【微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    87

    文章

    11171

    瀏覽量

    208479
  • 內存
    +關注

    關注

    8

    文章

    2947

    瀏覽量

    73731
  • 操作系統
    +關注

    關注

    37

    文章

    6609

    瀏覽量

    123029

原文標題:Linux系統是如何用虛擬內存來欺騙應用程序的?

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    邏輯內存物理內存的區(qū)別

    邏輯內存物理內存是計算機系統中兩個重要的概念,它們在計算機的運行和數據處理中起著至關重要的作用。 1. 物理內存(Physical Mem
    的頭像 發(fā)表于 09-27 15:38 ?249次閱讀

    輥壓機軸承位磨損修復你不知道的那些

    電子發(fā)燒友網站提供《輥壓機軸承位磨損修復你不知道的那些.docx》資料免費下載
    發(fā)表于 03-12 15:10 ?0次下載

    物理內存模型的演變

    內存管理概述中,主要是以Linux v2.6.11為例進行分析的,但是計算技術在不斷發(fā)展,新的存儲架構、新的指令集架構、新的SoC架構等都對物理內存模型的抽象提出了更高要求。為此,必須抽象一種完全獨立于硬件架構的
    的頭像 發(fā)表于 02-25 10:35 ?383次閱讀

    Linux內核內存管理之內核非連續(xù)物理內存分配

    的主要優(yōu)點是避免了外部碎片,而缺點是需要修改內核頁表。顯然,非連續(xù)內存區(qū)域的大小必須是4096的倍數。Linux使用非連續(xù)物理內存區(qū)的場景有幾種:(1)為swap區(qū)分配數據結構;(2)
    的頭像 發(fā)表于 02-23 09:44 ?806次閱讀
    Linux<b class='flag-5'>內核</b><b class='flag-5'>內存</b>管理之<b class='flag-5'>內核</b>非連續(xù)<b class='flag-5'>物理</b><b class='flag-5'>內存</b>分配

    Linux內核內存管理之ZONE內存分配器

    內核中使用ZONE分配器滿足內存分配請求。該分配器必須具有足夠的空閑頁幀,以便滿足各種內存大小請求。
    的頭像 發(fā)表于 02-21 09:29 ?819次閱讀

    拆解mmap內存映射的本質!

    mmap 內存映射里所謂的內存其實指的是虛擬內存,在調用 mmap 進行匿名映射的時候(比如進行堆內存的分配),是將進程虛擬內存空間中的某一
    的頭像 發(fā)表于 01-24 14:30 ?1165次閱讀
    拆解mmap<b class='flag-5'>內存</b>映射的本質!

    linux內核主要由哪幾個部分組成,作用是什么

    內存。它將內存劃分為不同的區(qū)域,并通過內存管理算法來分配和回收內存。它還提供了虛擬內存功能,允許多個進程共享系統的
    的頭像 發(fā)表于 01-22 14:34 ?2444次閱讀

    Windows服務器虛擬內存的設置建議

    虛擬內存是計算機操作系統用于擴展物理內存的一種機制。在Windows服務器上,虛擬內存的設置對系統性能和穩(wěn)定性至關重要。以下是關于Windo
    的頭像 發(fā)表于 12-25 17:03 ?2026次閱讀

    關于射頻微機電系統開關的那些事兒

    關于射頻微機電系統開關的那些事兒
    的頭像 發(fā)表于 12-06 14:58 ?443次閱讀
    <b class='flag-5'>關于</b>射頻微機電系統開關的<b class='flag-5'>那些</b>事兒

    java虛擬機內存包括遠空間內存

    Java虛擬機(JVM)內存是Java程序執(zhí)行時所使用的內存空間的總稱,包括了Java堆、方法區(qū)、本地方法棧、虛擬機棧和程序計數器等多個部分。在這些
    的頭像 發(fā)表于 12-05 14:15 ?347次閱讀

    關于MLCC(多層陶瓷電容)替代Film Cap (薄膜電容)的那些

    關于MLCC(多層陶瓷電容)替代Film Cap (薄膜電容)的那些
    的頭像 發(fā)表于 12-04 17:35 ?1686次閱讀
    有<b class='flag-5'>關于</b>MLCC(多層陶瓷電容)替代Film Cap (薄膜電容)的<b class='flag-5'>那些</b><b class='flag-5'>事</b>

    Linux內核內存規(guī)整總結

    1.前言 伙伴系統作為內核最基礎的物理內存分配器,具有高效、實現邏輯簡介等優(yōu)點,其原理頁也盡可能降低內存外部碎片產生,但依然無法杜絕碎片問題。外部碎片帶來的最大影響就是
    的頭像 發(fā)表于 11-11 11:17 ?1211次閱讀
    Linux<b class='flag-5'>內核</b><b class='flag-5'>內存</b>規(guī)整總結

    linux內存性能優(yōu)化介紹

    不同;圖示為 32 位和 64 位系統的虛擬地址空間; 內存映射是將虛擬內存地址映射到物理內存地址,內核
    的頭像 發(fā)表于 11-10 15:23 ?627次閱讀
    linux<b class='flag-5'>內存</b>性能優(yōu)化介紹

    內存內核中發(fā)生頁面遷移的典型場景

    頁面遷移(page migrate)最早是為 NUMA 系統提供一種將進程頁面遷移到指定內存節(jié)點的能力用來提升訪問性能。后來在內核中廣泛被使用,如內存規(guī)整、CMA、內存hotplug等
    的頭像 發(fā)表于 11-08 12:28 ?534次閱讀
    <b class='flag-5'>內存</b><b class='flag-5'>內核</b>中發(fā)生頁面遷移的典型場景

    虛擬內存物理地址的轉換

    處理器根據頁表基地址控制寄存器TTBCR和虛擬地址來判斷使用哪個頁表基地址寄存器,是TTBR0還是TTBR1。(一個基值是內核的,一個用戶態(tài)的) 頁表基地址寄存器中存放著一級頁表的基地址。 處理器
    的頭像 發(fā)表于 10-30 17:34 ?636次閱讀
    <b class='flag-5'>虛擬內存</b>到<b class='flag-5'>物理</b>地址的轉換