我的內存都去哪里了?
在疫情期間,小編不得不待在家中遠程辦公。但變的是辦公方式,不變的是美創(chuàng)運維的7*24小時不間斷支持。
這不,一位客戶發(fā)來了一條消息:
客戶:張工,好像我這個數(shù)據(jù)庫服務器的內存使用率有點高啊,你幫我看看?
隨即發(fā)了個linux環(huán)境下的free -g的截圖過來:
小編一看,按照這個截圖的顯示,的確在總共62Gb的內存里,可使用內存只剩1Gb了。但是,我們也可以觀察到,cached顯示的是55Gb,我們再獲取了一下top命令的截圖:
那為什么cached的內存使用這么大呢?這樣的內存使用情況是正常的嗎?
要回答這些問題,我們需要了解一下buffer與cache的含義。buffer 和 cache 是兩個在計算機技術中被用濫的名詞,放在不同語境下會有不同的意義。我們這里都將其放在linux內存這個語境中解釋。
什么是buffer
在 Linux 的內存管理中,這里的buffer 指 Linux 內存的:Buffer cache,中文可以解釋為:緩沖區(qū)緩存。Buffer cache 主要是設計用來在系統(tǒng)對塊設備進行讀寫的時候,對塊進行數(shù)據(jù)緩存的系統(tǒng)來使用。
什么是cache
在Linux的內存管理中,這里的 cache 指 Linux 內存中的:Page cache,中文可以解釋為:頁面緩存。主要用來作為文件系統(tǒng)上的文件數(shù)據(jù)的緩存來用,尤其是針對當進程對文件有 read/write 操作的時候。在當前的系統(tǒng)實現(xiàn)里, page cache 也被作為其它文件類型的緩存設備來用,所以事實上 page cache 也負責了大部分的塊設備文件的緩存工作。
自動回收 cache機制
Linux 內核會在內存將要耗盡的時候,觸發(fā)內存回收的工作,以便釋放出內存給急需內存的進程使用。一般情況下,在內存壓力較大的情況下, buffer/cache 空間可以被釋放,以作為 free 空間分給相關進程使用。
但是由于要回收緩存必須保證 cache 中的數(shù)據(jù)跟對應文件中的數(shù)據(jù)一致,才能對 cache 進行釋放。所以在回收緩存時一般會造成IO使用較高的現(xiàn)象。因為內核要對比 cache 中的數(shù)據(jù)和對應硬盤文件上的數(shù)據(jù)是否一致,如果不一致需要寫回,之后才能回收。
所以一般情況下不需要特意去釋放已經使用的cache。這些cache起來的內容本來就是為了增加文件以及的讀寫速度。
人工觸發(fā)回收cache
除了系統(tǒng)自己觸發(fā)回收緩存機制外,我們也可以通過下面這個腳本來清理緩存:
1. 查看目前內存使用:
2. 執(zhí)行sync同步數(shù)據(jù),防止數(shù)據(jù)或操作丟失(重要),將未寫的系統(tǒng)緩沖區(qū)寫到磁盤中。包含已修改的 i-node、已延遲的塊 I/O 和讀寫映射文件

請輸入評論內容...
請輸入評論/評論長度6~500個字
最新活動更多
推薦專題
- 1 AI 眼鏡讓百萬 APP「集體失業(yè)」?
- 2 大廠紛紛入局,百度、阿里、字節(jié)搶奪Agent話語權
- 3 深度報告|中國AI產業(yè)正在崛起成全球力量,市場潛力和關鍵挑戰(zhàn)有哪些?
- 4 一文看懂視覺語言動作模型(VLA)及其應用
- 5 上海跑出80億超級獨角獸:獲上市公司戰(zhàn)投,干人形機器人
- 6 國家數(shù)據(jù)局局長劉烈宏調研格創(chuàng)東智
- 7 下一代入口之戰(zhàn):大廠為何紛紛押注智能體?
- 8 百億AI芯片訂單,瘋狂傾銷中東?
- 9 Robotaxi新消息密集釋放,量產元年誰在領跑?
- 10 格斗大賽出圈!人形機器人致命短板曝光:頭腦過于簡單