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