容器內存

一、容器內存概述

容器本質上還是一個進程,是一個被隔離和限制的進程。因此容器內存和進程內存在表現形式上其實是一樣的,這塊主要涉及三部分內容:RSS,page cache和swap這三部分,容器基于memory Cgroup對內存進行限制,但是具體限制的什么呢?又有哪些參數可以對其進行控制呢?

二、容器進程被莫名kill掉

在linux中當一個進程使用malloc申請分配內存的時候,操作系統并不會立即給該進程分配真實的物理存,此時分配的其實是虛擬內存。因此進程是可以申請超過物理內存上限的內存。為啥要這么設計呢?因為空閑內存空間是不斷變化的,有進程申請必然有進程歸還,此時申請的時候不夠,誰能保證下一個時刻還不夠呢?因此才有這個overcommit機制。
但是當一個進程在不斷向內存中寫數據的時候,如果內存還是不夠用,此時就會OOM,被操作系統kill掉,畢竟不能把數據寫到別的進程的內存空間中去,也算是一種保護機制。
當然kill掉是容器的默認行為,具體的這個行為是可以通過參數設置的。
其中43fxxxxxx 是容器的id,也就是每個容器都可以對其進行控制
image.png
還有幾個比較重要的參數
image.png
從文件名稱也可以看出來分別是最大限制,和當前使用。
每個運行的容器下面都有這些文件,可以自定義合適的參數值。

三、容器與page cache

進程除了有自己獨立的RSS內存,如果涉及到文件的讀寫,linux還會為進程分配page cache,什么是page cache呢,page cache是操作系統在讀寫磁盤上的文件的時候,操作系統為了提升性能會預加載一部分內容到空閑的內存中來,而這部分空閑的內存則稱為page cache。
但是如果沒有空閑內存,而進程由要申請新的內存,則會回收page cache。保證內存供進程使用。
而上面提到的memory.usage.in_bytes = RSS + page cache
因此在某些情況下,memory.usage.in_bytes 是大于memory_limit_in_bytes的,但是不用擔心,因為page cache是自動回收的。
因此查看容器的真實的內存占用,查看memory.usage.in_bytes 是不準的,需要看:
image.png
page cache不屬于傳統的內存限制范疇,是操作系統用來緩存文件的,不屬于用戶,屬于操作系統內核,每個容器都可以使用page cache。
image.png
紅色的部分就是page cache。
在關注容器的內存占用的時候,主要關注RSS。

四、容器和swap

swap其實并不是一塊內存空間,而是一塊磁盤空間,不過操作系統有時會將這塊磁盤空間當作內存使用而已。當內存寫滿的時候,操作系統可以將一部分不用的數據暫時存放到swap空間上,待需要的時候再從swap中加載進來。
那么當內存緊張的時候,操作系統是會選擇先釋放page cache呢還是先把冷數據放到swap中去呢?
這個可以針對每一個容器進行定制化,具體修改下面這個配置文件:
image.png
swappiness的取值范圍在0到100之間,

  • 值為100的時候, 釋放Page Cache和寫冷數據到swap是同等優先級的。
  • 值為60,這是大多數Linux系統的缺省值,這時候Page Cache的釋放優先級高于寫冷數據到swap。
  • 值為0的時候,會限制該容器中的進程使用swap空間,僅對該容器生效

容器級別的swappiness會覆蓋操作系統級別的。
因此swap也不屬于傳統內存的限制范疇,每個容器都可以使用。

五、總結

memory cgroup 限制的是容器真正使用到的內存,對于swap和page cache 都是內核級別的,是由操作系統進行管理的,是所有進程共享的,是不能被memory cgroup所限制的。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/39463.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/39463.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/39463.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

用國內鏡像安裝docker 和 docker-compose (ubuntu)

替代方案,改用國內的鏡像站(網易鏡像) 1.清除舊版本(可選操作) for pkg in docker.io docker-doc docker-compose podman-docker containerd runc; do apt-get remove $pkg; done 2.安裝docker apt-get update 首先安裝依賴 apt-g…

Linux驅動開發實戰寶典:設備模型、模塊編程、I2C/SPI/USB外設精講

摘要: 本文將帶你走進 Linux 驅動開發的世界,從設備驅動模型、內核模塊開發基礎開始,逐步深入 I2C、SPI、USB 等常用外設的驅動編寫,結合實際案例,助你掌握 Linux 驅動開發技能。 關鍵詞: Linux 驅動,設備驅動模型,內核模塊,I2C,SPI,USB 一、Linux 設備驅動模型 Li…

mysql創建表的規范

名稱 建表的時候,給表,字段和索引起個好名字 見名知意:好的名字能夠降低溝通和維護的成本名字不宜過長,盡量控制在30個字符以內 大小寫 名字盡量都用小寫字母,因為從視覺上,小寫字母更容易讓人讀懂全部大寫…

Linux嵌入式中MQTT的使用

MQTT是什么? MQTT(Message Queuing Telemetry Transport,消息隊列遙測傳輸協議),是一種基于發布/訂閱(Publish/Subscribe)模式的輕量級通訊協議,該協議構建于TCP/IP協議上&#xff0…

駕馭npm更新之力:深入掌握npm update命令的精髓

駕馭npm更新之力:深入掌握npm update命令的精髓 在JavaScript和Node.js的世界中,npm(Node Package Manager)作為默認的包管理器,扮演著至關重要的角色。它不僅用于安裝和管理項目依賴,還提供了更新這些依賴…

SpringBoot3.3集成knif4j-swagger文檔方式和使用案例

springboot3 集成 knif4j &#xff1a; 訪問地址&#xff1a; swagger 接口文檔默認地址&#xff1a;http://localhost:8080/swagger-ui.html# Knife4j 接口文檔默認地址&#xff1a;http://127.0.0.1:8080/doc.html Maven: <dependency><groupId>com.github.x…

2024 COMMUNITY DAY User Group 社區嘉年華 云計算與 AI 技術交融盛會共筑多元智慧未來

亞馬遜云科技User Group&#xff0c;深圳 Community Day 活動流程搶先知道&#xff01; ? 7月7日 &#x1f3e0; 深圳南山區香港中文大學 &#x1f4e3;主論壇國際大咖云集&#xff0c;共襄科技盛宴&#xff01; &#x1f389;三大主題論壇&#xff1a;人工智能、大數據、動…

MyBatis系列三: XxxMapper.xml-SQL映射文件

XxxMapper.xml-SQL映射文件 官方文檔基本介紹詳細說明基本使用parameterType(輸入參數類型)傳入HashMapresultMap(結果集映射) 官方文檔 文檔地址: https://mybatis.org/mybatis-3/zh_CN/sqlmap-xml.html 基本介紹 1.MyBatis的真正強大在于它的語句映射(在XxxMapper.xml配置…

2024年06月CCF-GESP編程能力等級認證Python編程一級真題解析

本文收錄于專欄《Python等級認證CCF-GESP真題解析》,專欄總目錄:點這里,訂閱后可閱讀專欄內所有文章。 一、單選題(每題 2 分,共 30 分) 第 1 題 小楊父母帶他到某培訓機構給他報名參加CCF組織的GESP認證考試的第1級,那他可以選擇的認證語言有幾種?( ) A. 1 B. 2 C…

React@16.x(45)路由v5.x(10)源碼(2)- history

目錄 1&#xff0c;作用1.1&#xff0c;createBrowserHistory1.2&#xff0c;createHashHistory1.3&#xff0c;createMemoryHistory 2&#xff0c;history 對象的屬性2.1&#xff0c;action2.2&#xff0c;push / replace / go / goBack / goForward2.3&#xff0c;location2.…

網絡配線架的隱藏功能

網絡布線是確保現代信息社會高效運轉的關鍵技術之一。在這一領域&#xff0c;網絡配線架扮演著至關重要 的角色。它不僅僅是一個簡單的物理連接點&#xff0c;更擁有許多隱藏功能&#xff0c;這些功能極大地提升了網絡的 效率、穩定性和可管理性。 1、集中管理 網絡配線架提…

【BES2500x系列 -- RTX5操作系統】深入探索CMSIS-RTOS RTX -- 同步與通信篇 -- 消息隊列和郵箱處理 --(四)

&#x1f48c; 所屬專欄&#xff1a;【BES2500x系列】 &#x1f600; 作??者&#xff1a;我是夜闌的狗&#x1f436; &#x1f680; 個人簡介&#xff1a;一個正在努力學技術的CV工程師&#xff0c;專注基礎和實戰分享 &#xff0c;歡迎咨詢&#xff01; &#x1f49…

經典FC游戲web模擬器--EmulatorJS

簡介 EmulatorJS是一個基于JavaScript和Webassembly技術的虛擬環境的實現&#xff0c;可以在網頁中運行各種經典FC游戲系統&#xff0c;支持任天堂、世嘉、雅達利等經典紅白機。EmulatorJS的誕生使得諸如超級瑪麗、坦克大戰、魂斗羅等經典FC游戲能夠以一種全新的方式回歸。本文…

SAP MM模塊的ATP檢查

前面幾篇文章都演示和說明ATP的一些設置和操作&#xff0c;通常情況下ATP的檢查PP模塊&#xff0c;SD模塊用的相對來說是比較多的&#xff0c;但是實際上MM模塊也會遵循ATP的可用性的檢查規則。 當我們在做311、301等移動類型時&#xff0c;系統會根據相應的可用性檢查規則&am…

Linux常用指令匯總

Linux常用指令匯總 Cfilt 功能&#xff1a;解析C程序中被修飾的符號&#xff0c;比如變量與函數名稱。 示例&#xff1a; 解析編譯器 g 修飾的函數名稱。 cfilt -s gnu-v3 _Z5printRKSs print(std::basic_string<char, std::char_traits<char>, std::allocator<…

Django 多對多關系

多對多關系作用 Django 中&#xff0c;多對多關系模型的作用主要是為了表示兩個模型之間的多對多關系。具體來說&#xff0c;多對多關系允許一個模型的實例與另一個模型的多個實例相關聯&#xff0c;反之亦然。這在很多實際應用場景中非常有用&#xff0c;比如&#xff1a; 博…

【每日一個Git命令: cherry-pick】

git cherry-pick 命令的作用是將指定的提交&#xff08;commit&#xff09;應用到其他分支上。這個命令允許你選擇一個或多個已有的提交&#xff0c;并將它們作為新的提交引入到當前分支中。 這個過程不會改變項目的歷史記錄&#xff0c;因為它實際上是創建了這些提交的副本。…

BMA530 運動傳感器

型號簡介 BMA530是博世&#xff08;bosch-sensortec&#xff09;的一款運動傳感器。時尚簡約的可穿戴設備為功能強大的組件提供了很小的空間。具有先進功能集的下一代加速度計是世界上最小的加速度傳感器&#xff08;1.2 x 0.8 x 0.55 mm&#xff09;。它專為緊湊型設備而設計&…

24/07/02數據結構(1.1201)算法效率順序表

數據結構基本內容:1.時間復雜度 空間復雜度2.順序表鏈表3.棧 隊列4.二叉樹5.排序 數據結構是存儲,組織數據的方式.指相互之間存在一種或多種特定關系的數據元素的集合 算法是定義良好的計算過程.取一個或一組值為輸入并產生一個或一組值為輸出. 需要知道雖然選擇題有20-30個…

Leetcode1114 交替打印 FooBar及其測試

題目描述 相關標簽 相關企業 給你一個類&#xff1a; class FooBar { public void foo() { for (int i 0; i < n; i) { print(“foo”); } } public void bar() { for (int i 0; i < n; i) { print(“bar”); } } } 兩個不同的線程將會共用一個 FooBar 實例&#xf…