我的內存都去哪里了?
3. 使用/proc/sys/vm/drop_caches 清理cache

4. 查看清理后內存使用情況

可以看到一大部分cached已被回收。
drop_caches詳細文檔如下:
該文件可以設置的值分別為1、2、3。它們所表示的含義為:
echo 1 > /proc/sys/vm/drop_caches:表示清除 page cache。
echo 2 > /proc/sys/vm/drop_caches:表示清除回收 slab 分配器中的對象(包括目錄項緩存和 inode 緩存)。slab 分配器是內核中管理內存的一種機制,其中很多緩存數據實現都是用的 page cache。
echo 3 > /proc/sys/vm/drop_caches:表示清除 page cache 和 slab 分配器中的緩存對象。
(只有內核在2.6.16以上的才支持)
內核版本查看方法如下:

Slab分配器內存:
"Slab"表示內核Slab所占用的內存大小,slab有的可回收有的不可回收,其中可回收的通過"SReclaimable"表示,不可回收的通過"SUnreclaim"表示。
我們可以查看/proc/meminfo獲取它的值:

所以一般情況下,人工drop_caches操作是不能回收所有page cache的,它有三塊緩存是無法回收的:
1. dirty pages
2. Slab中的不可回收緩存
3. 共享內存和tmpfs,即free命令中的shared部分

在正常的業務數據庫系統中,cached較高是一件比較普遍的事情,盡量不要去手動清緩存,畢竟它是為了提高效率而產生的,如果冒然釋放緩存會造成IO使用率變高,業務系統的效率也會受影響。
美創科技擁有強大的運維中心數據庫服務團隊,其中Oracle ACE 1人、OCM 10余人、數十名Oracle OCP、MySQL OCP、紅帽RHCA、中間件weblogic、tuxedo認證、達夢工程師 ,并著有《Oracle DBA實戰攻略》,《Oracle數據庫性能優化方法和最佳實踐》,《Oracle內核技術揭秘》等多本數據運維優化書籍。
今天的運維小技巧就分享到這了,下期再和美創運維團隊一起學習運維知識吧!
最新活動更多
- 1 AI狂歡遇上油價破百,全球股市還能漲多久? | 產聯看全球
- 2 OpenAI深夜王炸!ChatGPT Images 2.0實測:中文穩、細節炸,設計師慌了
- 3 6000億美元估值錨定:字節跳動的“去單一化”突圍與估值重構
- 4 Tesla AI5芯片最新進展總結
- 5 連夜測了一波DeepSeek-V4,我發現它可能只剩“審美”這個短板了
- 6 熱點丨AI“瑜亮之爭”:既生OpenClaw,何生Hermes?
- 7 AI界的殺豬盤:9秒刪庫跑路,全員被封號,還繼續扣錢!
- 8 2026,人形機器人只贏了面子
- 9 DeepSeek降價90%:價格屠夫不是身份,是戰略
- 10 AI Infra產業鏈卡在哪里了?



分享













