• 内存还剩余很多,却使用 swap 分区


    内存还剩余很多,却使用 swap 分区

    作者:张首富
    时间:2020-06-18
    w x:y18163201
    

    原因

    今天早上 AI 部门工程师来找我说,你会给 ubuntu 设置 swap 分区吗,我们机器内存好像不咋够用了,给我搞个 swap 分区吧!我说好的,这么简单分分钟钟的事情,我三下五除二的就给他搞定了,给他说好了,你用吧,但是过一会他就跑来说,你给我弄好 swap 分区之后这台机器就特别特别卡,你能帮我看看什么问题吗?

    排查

    我登录到机器上,查看机器内存free -h结果如下图

    image-20200618110616351

    从结果可以看出来,机器在内存还剩 148G 但是 swap 分区却完全被使用完了,这说明我给他创建好 swap 分区之后完全他完全不使用内存了,这是什么情况,查阅资料得到如下解决办法

    解决问题

    swappiness的值的大小对如何使用swap分区是有着很大的联系的。

    swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,swappiness=100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。

    当该参数= 0,表示只要有可能就尽力避免交换进程移出物理内存; 该 参数=100,这告诉内核疯狂的将数据移出物理内存移到swap缓存中。

    这个值只是一个Linux在判断是否交换内存(swap)的一个“倾向”参考值,而并不是说,设置为0以后,Linux就完全不会使用内存交换空间

    然后 ubuntu 和 centos 一般默认都是 60 ,就是当内存使用=(100%-60%)*内存总量

    cat /proc/sys/vm/swappiness
    60
    

    所以才会出现我们上面那种情况,这个时候我们只需要调整这个值即可,

    sysctl vm.swappiness=10 #临时修改
    echo "vm.swappiness=10" >> /etc/sysctl.conf #永久修改
    sysctl -p #生效
    

    改完之后就会使用物理内存了,刚才卡的情况也解决了

  • 相关阅读:
    将博客搬至CSDN
    java面试题(一)
    大数据面试题(二)
    大数据面试题(一)
    现在有T1、T2、T3三个线程,你怎样保证T2在T1执行完后执行,T3在T2执行完后执行?
    java序列化与反序列化总结
    Hashmap,Set,Map,List,ArrayList的区别
    Windows下安装Scrapy
    Eclipse java上手
    lucene文件检索(1)-linux java环境配置
  • 原文地址:https://www.cnblogs.com/shoufu/p/13156534.html
Copyright © 2020-2023  润新知