java 進程是如何在Linux服務(wù)器上進行內(nèi)存分配的
眾所周知,Java進程在啟動的時候我們可以通過 -Xms 和-Xmx來設(shè)置內(nèi)存的上限和下限。直到我發(fā)現(xiàn)使用top命令監(jiān)控的Java進程在-Xms設(shè)置4g的情況下占用的內(nèi)存并不是4g,這就產(chǎn)生了一個疑問Linux服務(wù)器的內(nèi)存到底是如何進行分配的。
于是乎,我查閱了一些知乎,課程以及Linux相關(guān)的書籍。這里分享并記錄的一下相關(guān)的知識。
在Linux上運行的進程不僅限于Java。都有一個概念,邏輯內(nèi)存(Logic Memory),而物理機真是持有的內(nèi)存,我們稱為 物理內(nèi)存(Physic Memory)。

進程在開始運行時并不會直接分配物理內(nèi)存,進程只是傻乎乎的以為自己持有了內(nèi)存,也就是邏輯內(nèi)存。當(dāng)程序運行需要內(nèi)存分配的時候,Linux服務(wù)器會以頁的(Page)至小4k的方式分配,并一對一映射物理內(nèi)存和邏輯內(nèi)存的關(guān)系,看到了嗎這里其實用了代理的思想是得內(nèi)存的分配進行了解耦。
這樣做的好處是什么呢? 1進程之間相互隔離 2進程自己認為占有了一段獨立連續(xù)的內(nèi)存 3可以申請比物理內(nèi)存更大的內(nèi)存空間。
第三點怎么理解呢?其實Linux在這里設(shè)計了一種機制叫Swap 就是在進程分配的內(nèi)存空間超過物理內(nèi)存的時候,如果各個進程運行所占的內(nèi)存真的有這么多,超過了物理內(nèi)存就會觸發(fā)Swap,把不持有CPU的部分進程的內(nèi)存數(shù)據(jù)和磁盤進行io數(shù)據(jù)交換。因為CPU一時間不可能超過所有占有的內(nèi)存,所以這種優(yōu)化就造就了能多申請一些內(nèi)存,大概是原來內(nèi)存的2-3倍,這就很可觀了,畢竟內(nèi)存是非常貴的。
Swap雖然好,也帶來了一些問題。
比如頻繁的Swap,這會導(dǎo)致內(nèi)存操作轉(zhuǎn)化為磁盤的的IO操作,拖慢應(yīng)用進程的運行速度。所以說Swap在我的理解里屬于可以應(yīng)急不使進程崩潰,適當(dāng)使用可以減少成本,過分了不當(dāng)人的使用就會被反噬的機制。
當(dāng)然如果太不當(dāng)人,進程還是會崩潰了,Swap是一個類似Buffer的機制,有大小的。超過設(shè)置的上限,Kernel內(nèi)核就會觸發(fā)OOM Killer,殺死一部分進程騰空間。
以上就是java 進程是如何在Linux服務(wù)器上進行內(nèi)存分配的的詳細內(nèi)容,更多關(guān)于java 進程內(nèi)存分配的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Springboot項目出現(xiàn)java.lang.ArrayStoreException的異常分析
這篇文章介紹了Springboot項目出現(xiàn)java.lang.ArrayStoreException的異常分析,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12
Springcloud?feign傳日期類型參數(shù)報錯的解決方案
這篇文章主要介紹了Springcloud?feign傳日期類型參數(shù)報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringBoot集成antlr實現(xiàn)詞法和語法分析
Antlr4 是一款強大的語法生成器工具,可用于讀取、處理、執(zhí)行和翻譯結(jié)構(gòu)化的文本或二進制文件,基本上是當(dāng)前 Java 語言中使用最為廣泛的語法生成器工具,本文給大家介紹了SpringBoot集成antlr實現(xiàn)詞法和語法分析,需要的朋友可以參考下2024-06-06
Jeecg-Boot異常處理'jeecg-boot.QRTZ_LOCKS'?doesn'
這篇文章主要介紹了Jeecg-Boot異常處理'jeecg-boot.QRTZ_LOCKS'?doesn't?exist問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12

