cached过高导致内存溢出 java head space

Posted 山河永慕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cached过高导致内存溢出 java head space相关的知识,希望对你有一定的参考价值。

 最近公司线上遇到老是内存溢出检查后发现cached过高
命令:free -m
命令:sync    //将缓存写入硬盘
  cat /etc/redhat-release 这个是查看系统版本的命令centos or other。
 命令:echo 1 > /proc/sys/vm/drop_caches  清理缓存 权限可能是root
 
 
由于是搜索查询 的一个系统所以IO写入索引较多所以cached过高且与linux机制有关
# 说明,释放前最好sync一下,防止丢数据
#!/bin/bash
#系统分配的区总量  
mem_total=`free -m | awk \'NR==2\' | awk \'{print $2}\'` 
#当前剩余的大小  
mem_free=`free -m | awk \'NR==3\' | awk \'{print $4}\'` 
 
#当前已使用的used大小  
mem_used=`free -m | grep Mem | awk \'{print  $3}\'`  
 
if (($mem_used != 0)); then  
 
#如果已被使用,则计算当前剩余free所占总量的百分比,用小数来表示,要在小数点前面补一个整数位0  
mem_per=0`echo "scale=2;$mem_free/$mem_total" | bc`  
DATA="$(date -d "today" +"%Y-%m-%d-%H-%M") free percent is : $mem_per"
echo $DATA >> /var/log/mem_detect.log
#设置的告警值为20%(即使用超过80%的时候告警)。  
mem_warn=0.20  
 
#当前剩余百分比与告警值进行比较(当大于告警值(即剩余20%以上)时会返回1,小于(即剩余不足20%)时会返回0 )  
mem_now=`expr $mem_per \\> $mem_warn`  
 
#如果当前使用超过80%(即剩余小于20%,上面的返回值等于0),释放内存
if (($mem_now == 0)); then  
sync
echo 3 > /proc/sys/vm/drop_caches
fi 
fi 

或者

#!/bin/bash

used=`free -m | awk \'NR==2\' | awk \'{print $3}\'`
free=`free -m | awk \'NR==2\' | awk \'{print $4}\'`

echo "===========================" >> /var/log/mem.log
date >> /var/log/mem.log
echo "Memory usage | [Use:${used}MB][Free:${free}MB]" >> /var/log/mem.log

if [ $free -le 100 ] ; then
                sync && echo 1 > /proc/sys/vm/drop_caches
                sync && echo 2 > /proc/sys/vm/drop_caches
                sync && echo 3 > /proc/sys/vm/drop_caches
                echo "OK" >> /var/log/mem.log
else
                echo "Not required" >> /var/log/mem.log

最后还需要

# echo "0 * */1 * * ? root /home/tomcat/clearCached.sh" >> /etc/crondtab

以上是关于cached过高导致内存溢出 java head space的主要内容,如果未能解决你的问题,请参考以下文章

centos系统内存 buff/cache 占用过高

记一次线上内存溢出问题排查过程

jmeter性能压测-性能压测常见问题分析之cpu过高/内存使用持续上升

Centos7 cache/buff过高处理方法

solr 全量更新慢,导致cup过高

Linux中Cache内存占用过高解决办法