• 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

  • 相关阅读:
    【转】return 使用示例
    java基础_二维数组的行和列
    新版SQL授权用户时报错 near 'IDENTIFIED BY '密码' with grant option' at line 1
    GO kafka sarama 生产者 消费者 简单 实现
    Windows 安装kafka
    windows 连接nsq
    reflect: call of reflect.Value.NumField on ptr Value
    django 数据库 mysql 事务 处理
    python 类的继承
    python 中 insert 返回 None
  • 原文地址:https://www.cnblogs.com/shanheyongmu/p/6002690.html
Copyright © 2020-2023  润新知