午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

java 進程是如何在Linux服務器上進行內存分配的

瀏覽:106日期:2022-08-20 17:10:31

眾所周知,Java進程在啟動的時候我們可以通過 -Xms 和-Xmx來設置內存的上限和下限。直到我發現使用top命令監控的Java進程在-Xms設置4g的情況下占用的內存并不是4g,這就產生了一個疑問Linux服務器的內存到底是如何進行分配的。

于是乎,我查閱了一些知乎,課程以及Linux相關的書籍。這里分享并記錄的一下相關的知識。

在Linux上運行的進程不僅限于Java。都有一個概念,邏輯內存(Logic Memory),而物理機真是持有的內存,我們稱為 物理內存(Physic Memory)。

java 進程是如何在Linux服務器上進行內存分配的

進程在開始運行時并不會直接分配物理內存,進程只是傻乎乎的以為自己持有了內存,也就是邏輯內存。當程序運行需要內存分配的時候,Linux服務器會以頁的(Page)至小4k的方式分配,并一對一映射物理內存和邏輯內存的關系,看到了嗎這里其實用了代理的思想是得內存的分配進行了解耦。

這樣做的好處是什么呢? 1進程之間相互隔離 2進程自己認為占有了一段獨立連續的內存 3可以申請比物理內存更大的內存空間。

第三點怎么理解呢?其實Linux在這里設計了一種機制叫Swap 就是在進程分配的內存空間超過物理內存的時候,如果各個進程運行所占的內存真的有這么多,超過了物理內存就會觸發Swap,把不持有CPU的部分進程的內存數據和磁盤進行io數據交換。因為CPU一時間不可能超過所有占有的內存,所以這種優化就造就了能多申請一些內存,大概是原來內存的2-3倍,這就很可觀了,畢竟內存是非常貴的。

Swap雖然好,也帶來了一些問題。

比如頻繁的Swap,這會導致內存操作轉化為磁盤的的IO操作,拖慢應用進程的運行速度。所以說Swap在我的理解里屬于可以應急不使進程崩潰,適當使用可以減少成本,過分了不當人的使用就會被反噬的機制。

當然如果太不當人,進程還是會崩潰了,Swap是一個類似Buffer的機制,有大小的。超過設置的上限,Kernel內核就會觸發OOM Killer,殺死一部分進程騰空間。

以上就是java 進程是如何在Linux服務器上進行內存分配的的詳細內容,更多關于java 進程內存分配的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 国产欧美一区二区三区在线观看视频 | 成人在线观 | 国产麻豆精品一区二区 | 国产成人精品av在线观 | 波多野结衣久久精品 | 91美女片黄| 欧美午夜精品久久久久免费视 | 日韩h视频 | 久久久久一区二区三区 | 懂色av成人一区二区三区 | 91精品在线视频观看 | 日本中文字幕精品 | 精品999视频 | 久久久久久不卡 | 亚洲第一视频 | 国产情侣91 | 女18毛片| 国产91高清| 亚洲精品久久久久久久久久久 | 日本国产一区二区三区 | 国产高清视频一区二区 | 久久伊人影视 | 久色婷婷 | 91久久综合| 丁香婷婷在线 | 欧美黄色三级视频 | 日本黄色大片免费看 | 国产一级二级视频 | 欧美视频在线一区 | 五十路在线视频 | 国产欧美在线观看视频 | 91精品综合久久久 | av网站免费观看 | 免费av在线 | 一级黄色a视频 | 999国产精品视频 | 国产小视频在线免费观看 | 久久久久爱 | 男人的天堂中文字幕 | www.久久久久 | 亚洲精品五月天 |