linux free命令以及系统内存占用过高的处理方式

2023-12-07 0 855
目录
  • linux free 命令以及系统内存占用过高的处理
    • free常用参数
  • linux 内存 占用较高问题排查
    • 查看内存情况
    • 问题定位
  • 总结

    linux free 命令以及系统内存占用过高的处理

    [root@localhost ~]# free -m
    total used free shared buff/cache available
    Mem: 3770 228 3270 11 271 3285
    Swap: 8190 0 8190

    第一行Mem,表示物理内存统计

    • total:总内存大小
    • used:已使用内存大小
    • free:当前空闲内存大小
    • shared:多个进程共享的内存总额
    • buffers/cached:缓存内存数据

    第二行-/+ buffers/cache:

    (1)used  实际使用的内存,等于第一行的 used – buffers – cached

    (2)free  实际可用内存,等于第一行的 free + buffers + cached

    内存占用计算公式used/(used+free)

    第三行Swap表示交换区的使用情况,也就是我们通常所说的虚拟内存。

    free常用参数

    • free -b #以Byte为单位显示内存使用情况
    • free -k #以KB为单位显示内存使用情况,也是默认参数
    • free -m #以MB为单位显示内存使用情况
    • free -g #以GB为单位显示内存使用情况
    • free -s<数字> #间隔数字秒数刷新显示内存使用情况
    • free -t #显示内存总和列
    • free -V#显示当前版本

    在Linux系统下,我们一般不需要去释放内存,因为系统已经将内存管理的很好。但是凡事也有例外,有的时候内存会被缓存占用掉,导致系统使用SWAP空间影响性能,此时就需要执行释放内存(清理缓存)的操作了。

    Linux系统的缓存机制是相当先进的,他会针对dentry(用于VFS,加速文件路径名到inode的转换)、Buffer Cache(针对磁盘块的读写)和Page Cache(针对文件inode的读写)进行缓存操作。

    但是在进行了大量文件操作之后,缓存会把内存资源基本用光。但实际上我们文件操作已经完成,这部分缓存已经用不到了。

    这个时候,我们难道只能眼睁睁的看着缓存把内存空间占据掉么?

    所以,我们还是有必要来手动进行Linux下释放内存的操作,其实也就是释放缓存的操作了。

    要达到释放缓存的目的,我们首先需要了解下关键的配置文件/proc/sys/vm/drop_caches。

    这个文件中记录了缓存释放的参数,默认值为0,也就是不释放缓存。他的值可以为0~3之间的任意数字,代表着不同的含义:

    • 0 – 不释放
    • 1 – 释放页缓存
    • 2 – 释放dentries和inodes
    • 3 – 释放所有缓存

    知道了参数后,我们就可以根据我们的需要,使用下面的指令来进行操作。

    首先我们需要使用sync指令,将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件。否则在释放缓存的过程中,可能会丢失未保存的文件。

    #sync

    接下来,我们需要将需要的参数写进/proc/sys/vm/drop_caches文件中,比如我们需要释放所有缓存,就输入下面的命令:

    #echo 3 > /proc/sys/vm/drop_caches

    此指令输入后会立即生效,可以查询现在的可用内存明显的变多了。

    要查询当前缓存释放的参数,可以输入下面的指令:

    cat /proc/sys/vm/drop_caches

    1.清理前内存使用情况

    free -m

    2.开始清理

    echo 1 > /proc/sys/vm/drop_caches

    3.清理后内存使用情况

    free -m

    4.完成

    查看内存条数命令:

    dmidecode | grep -A16 \”Memory Device$\”

    linux 内存 占用较高问题排查

    查看内存情况

    #按 k 查看

    free

    #按兆M查看

    free -m

    linux free命令以及系统内存占用过高的处理方式

    • total:总计物理内存的大小。
    • used:已使用多大。
    • free:可用有多少。
    • Shared:多个进程共享的内存总额。
    • Buffers/cached:磁盘缓存的大小。

    #所以空闲内存=free+buffers+cached=total-used

    内存的使用情况

    cat /proc/meminfo

    查看进程的内存占用

    pidstat -r -p 24427 1 5

    内存占用高的前20

    ps aux | head -1;ps aux |grep -v PID |sort -rn -k +4 | head -20

    动态查看内存占用

    slabtop

    问题定位

    cached 占用过高问题

    buffer,cached的作用:

    cached主要负责缓存文件使用, 日志文件过大造成cached区内存增大把内存占用完 .

    Free中的buffer和cache:(它们都是占用内存):

    • buffer : 作为buffer cache的内存,是块设备(磁盘)的缓冲区,包括读、写磁盘
    • cache: 作为page cache的内存, 文件系统的cache,包括读、写文件

    如果 cache 的值很大,说明cache住的文件数很多。

    linux服务器会自动释放内存,保障系统运行,但只会释放够用的内存,而不会去释放更多的内存。

    解决方法:

    手动释放cached方法有三种(系统默认值是0,释放之后你需要再改回0值):

    释放前最好sync一下,防止丢数据

    sync 在启动机器或关机之前一定要运行sync命令。记住在任何情况下,慎重地执行sync命令决不会有任何坏处,sync命令强制把磁盘缓冲的所有数据写入磁盘

    To free pagecache: #echo 1 > /proc/sys/vm/drop_caches
    To free dentries and inodes: #echo 2 > /proc/sys/vm/drop_caches
    To free pagecache, dentries and inodes: #echo 3 > /proc/sys/vm/drop_caches

    #常用方法是

    sync
    echo 1 > /proc/sys/vm/drop_caches

    #清除后要还原系统默认配置:

    echo 0 > /proc/sys/vm/drop_caches

    #查看设置

    sysctl -a | grep drop_caches

    补充: echo 字符串 > 文件 就是把字符串内容从定向到文件中

    linux free命令以及系统内存占用过高的处理方式

    这时查看 free 可以看到 cached 降低了很多

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源网。

    收藏 (0) 打赏

    感谢您的支持,我会继续努力的!

    打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
    点赞 (0)

    悠久资源 Linux服务器 linux free命令以及系统内存占用过高的处理方式 https://www.u-9.cn/server/linux/114881.html

    常见问题

    相关文章

    发表评论
    暂无评论
    官方客服团队

    为您解决烦忧 - 24小时在线 专业服务