Linux 內存 占用較高問題排查


一 查看內存情況

#按 k 查看

free 

#按兆M查看

free -m

  • total:總計物理內存的大小。
  • used:已使用多大。
  • free:可用有多少。
  • Shared:多個進程共享的內存總額。
  • Buffers/cached:磁盤緩存的大小。
  • #所以空閑內存=free+buffers+cached=total-used

內存的使用情況

cat /proc/meminfo

查看進程的內存占用

pidstat -r -p 24427 1 5 

內存占用高的前20

ps aux | head -1;ps aux |grep -v PID |sort -rn -k +4 | head -20

動態查看內存占用

slabtop

二 問題定位

 

 cached 占用過高問題

buffer,cached的作用:

     cached主要負責緩存文件使用, 日志文件過大造成cached區內存增大把內存占用完 .
     Free中的buffer和cache:(它們都是占用內存):
     buffer : 作為buffer cache的內存,是塊設備(磁盤)的緩沖區,包括讀、寫磁盤
     cache: 作為page cache的內存, 文件系統的cache,包括讀、寫文件
     如果 cache 的值很大,說明cache住的文件數很多。

linux服務器會自動釋放內存,保障系統運行,但只會釋放夠用的內存,而不會去釋放更多的內存。

解決方法:

手動釋放cached方法有三種(系統默認值是0,釋放之后你需要再改回0值):
釋放前最好sync一下,防止丟數據

sync 在啟動機器或關機之前一定要運行sync命令。記住在任何情況下,慎重地執行sync命令決不會有任何壞處,sync命令強制把磁盤緩沖的所有數據寫入磁盤


To free pagecache: #echo 1 > /proc/sys/vm/drop_caches

To free dentries and inodes: #echo 2 > /proc/sys/vm/drop_caches

To free pagecache, dentries and inodes: #echo 3 > /proc/sys/vm/drop_caches

#常用方法是

sync

echo 1 > /proc/sys/vm/drop_caches

#清除后要還原系統默認配置:
echo 0 > /proc/sys/vm/drop_caches

#查看設置
 sysctl -a | grep drop_caches
補充: echo 字符串 > 文件  就是把字符串內容從定向到文件中

這時查看 free  可以看到 cached 降低了很多


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM