cached过高导致内存溢出 java head space
2016-10-27 09:12
441 查看
最近公司线上遇到老是内存溢出检查后发现cached过高
命令:free -m
命令:sync //将缓存写入硬盘
cat /etc/redhat-release 这个是查看系统版本的命令centos or other。
命令:echo 1 > /proc/sys/vm/drop_caches 清理缓存 权限可能是root
由于是搜索查询 的一个系统所以IO写入索引较多所以cached过高且与linux机制有关
# 说明,释放前最好sync一下,防止丢数据
或者
最后还需要
# echo "0 * */1 * * ? root /home/tomcat/clearCached.sh" >> /etc/crondtab
命令: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
相关文章推荐
- Java中subString和split导致的内存溢出和对策
- jvm 内存溢出 在myeclipse中加大tomcat的jvm内存java.lang.OutOfMemoryError: Java heap space
- Java中,String的subString方法易导致内存溢出
- KETTLE java.lang.OutOfMemoryError: Java heap space 内存溢出错误
- Java之JVM调优案例分析与实战(3) - 堆外内存导致的溢出错误
- JceSecurity/BouncyCastleProvider导致JVM内存溢出、CPU过高问题排查
- java-subString方法易导致内存溢出
- java.lang.OutOfMemoryError: Java heap space 内存溢出解决方法
- 安装版的tomcat7 "Java heap space"内存溢出解决办法
- JAVA heap space 内存溢出
- Java堆外内存及导致的溢出错误
- mark/reset方法的使用以及导致内存溢出的原因(java)
- java service wrapper 级别为info导致内存剧增直至溢出
- 应用jacob组件造成的内存溢出解决方案(java.lang.OutOfMemoryError: Java heap space)
- Java之JVM调优案例分析与实战(2) - 集群间同步导致的内存溢出
- java.lang.OutOfMemoryError: Java heap space 内存溢出错误及处理办法(转)
- 不同平台下处理【java.lang.OutOfMemoryError: Java heap space】内存溢出。
- struts2自定义模板内存溢出 java.lang.OutOfMemoryError: Java heap space(问题已解决)
- session不及时释放导致内存溢出的性能问题分析
- java.lang.OutOfMemoryError: Java heap space + myeclipse中分配tomcat启动时所占内存大小