Linux到底怎樣實現(xiàn)?其實很簡單

2021-02-18    分類: 網(wǎng)站建設(shè)

空間、堆和棧的副本。這種實現(xiàn)方式實在過于簡單,粗暴,效率低下。為什么這么說呢?因為在fork之后,往往緊接著就會跟隨exec。exec之前拷貝完全是無意義的,而且會極大的限制創(chuàng)建進程的速度。

所以Linux引入了寫時拷貝技術(shù)(copy-on-write),簡稱COW。它是一種可以推遲甚至可以免除拷貝數(shù)據(jù)的技術(shù)。fork時,內(nèi)核此時并不復(fù)制整個進程的地址空間,而是讓父進程和子進程共享同一個拷貝。只有在需要寫入的時候,數(shù)據(jù)才會被復(fù)制,從而使各個進程擁有各自的拷貝。也就是說在此之前都是以只讀的方式訪問。這種技術(shù)使地址空間上的頁的拷貝被推遲到真正需要寫入的時候。例如我之前說的情況,fork之后立即調(diào)用exec,他們就不要拷貝。


現(xiàn)在fork之后的實際開銷就是復(fù)制進程的頁表和子進程創(chuàng)建唯一的進程描述符。這是一種極大的優(yōu)化,避免了大量的無意義的拷貝。對于Linux這種強調(diào)快速切換的操作系統(tǒng)來說,這個優(yōu)化有著重大的意義。


注意:fork之后內(nèi)核會通過將子進程放入到運行隊列前面,以讓子進程先運行。以避免父進程先寫入,產(chǎn)生拷貝,而后子進程執(zhí)行exec,導(dǎo)致因而無意義的拷貝。

空間。我們現(xiàn)在考慮一種實際情況,有一個父進程PID1。它的虛擬地址空間大致有:代碼段,數(shù)據(jù)段,堆,棧。內(nèi)核通過頁表為他們映射了虛擬地址到物理地址,為了方便表示,就用物理地址塊表示吧。(4G地址空間

)。

原始fork()

PID1 通過fork()系統(tǒng)調(diào)用創(chuàng)建了一個子進程PID2。下圖簡單的直接的表示,可以看出直接為PID2復(fù)制了PID1的地址空間數(shù)據(jù)。


COW技術(shù)

內(nèi)核只為新生成的子進程創(chuàng)建虛擬空間結(jié)構(gòu),它們來復(fù)制于父進程的虛擬究竟結(jié)構(gòu),但是不為這些段分配物理內(nèi)存,它們共享父進程的物理空間,當(dāng)父子進程中有更改相應(yīng)段的行為發(fā)生時,再為子進程相應(yīng)的段分配物理空間



網(wǎng)站題目:Linux到底怎樣實現(xiàn)?其實很簡單
網(wǎng)頁網(wǎng)址:http://www.muchs.cn/news45/101595.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、品牌網(wǎng)站設(shè)計、全網(wǎng)營銷推廣、網(wǎng)頁設(shè)計公司、品牌網(wǎng)站建設(shè)、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化