Centos7服務器內存使用過高排查


Centos7服務器內存使用過高排查

查看內存使用情況

[root@VM-16-17-centos ~]# free -h
              total        used        free      shared  buff/cache   available
Mem:           3.7G        3.1G        152M        772K        413M        338M
Swap:            0B          0B          0B

$ free -m
$ top //shift+m按內存占用比排序
  • 1、total:總的物理內存

    2、used:系統使用的內存,包括buff+cache。並非系統真正使用的內存。系統真正使用的內存=used-buff/cache

    3、free:空閑的內存,系統未使用的內存,並不是系統啟動應用程序可以真正使用的內存。

    4、shared:共享內存

    5、buff/cache:磁盤緩存的大小

    6、available:在舊版free中,沒有這個選項。這個選項指的是,系統啟動程序時可以利用的內存,當這個選項很小或者不夠啟動程序所需的內存,會提示系統內存不足,無法啟動,此時就需要處理問題,是物理內存真的不足,還是清理系統緩存。

內存占用高的前10

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

從上看內存使用較多的是MySQL

# 登錄MySQL查看-----顯示系統中正在運行的所有進程,也就是當前正在執行的查詢
mysql> show processlist;  沒有可疑的進程
# 就是這個玩意占用的  1558*2048/1024 就是現在使用的內存
[root@node01 ~]# cat /proc/meminfo | grep -iE "HugePages_Total|Hugepagesize"
HugePages_Total:       1558
Hugepagesize:       2048 kB

# 關閉
/etc/sysctl.conf 
添加解決
vm.nr_hugepages=0
sysctl -p 

解決 cached 占用過高問題

buffer,cached的作用:

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

解決方法:

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

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

#常用方法是

sync

echo 1 > /proc/sys/vm/drop_caches

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

#查看設置
sysctl -a | grep drop_caches


免責聲明!

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



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