• 记录一次内存耗尽解决过程


    最近登录公司几台比较关键的服务器,发现内存消耗殆尽,使用top查看,应用进程占用的内存并不多,使用free命令查看,发现大部分的内存都被cached占用了。

    只能使用手动的方式清理缓存了:

       echo 3 > /proc/sys/vm/drop_caches   清空所有的缓存

    在使用free命令查看,内存释放了。

    下面说一下:drop_caches:

    清空 pagecache:
        echo 1 > /proc/sys/vm/drop_caches
        或者:
        sysctl -w vm.drop_caches=1

    清空 dentries 和 inodes:
        echo 2 > /proc/sys/vm/drop_caches
        或者:
        sysctl -w vm.drop_caches=2

    清空所有缓存(pagecache、dentries 和 inodes):
        echo 3 > /proc/sys/vm/drop_caches
        或者:
        sysctl -w vm.drop_caches=3

    虽然手动清理缓存,治标不治本,但是暂时解决了缓存耗尽的问题,然后google了一下,通过修改sysctl.conf文件的下面几个参数,可以优化一下系统自动回收缓存:

    vm.vfs_cache_pressure   #系统在进行内存回收时,安装顺序回收page_cache, inode cache, dentry cache和swap_cache,默认值是100 值越大inode cache和dentry cache的回收速度会越快

    vm.min_free_kbytes  #计算开始内存回收的阀值,值越大表示回收也早。

  • 相关阅读:
    HTTP响应状态码整理
    Python通用爬虫,聚焦爬虫概念理解
    HTTP无状态协议理解
    会话与事务知识点总结
    并发一致性知识点整理
    使用隔离级别read committed隐式解决并发冲突
    多并发笔记整理
    git基本使用
    Docker其他
    Docker Bind Mount 与 Volume
  • 原文地址:https://www.cnblogs.com/zhaojonjon/p/5698727.html
Copyright © 2020-2023  润新知