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

 更新时间:2023年05月30日 08:53:39   作者:slyybw  
这篇文章主要介绍了linux free命令以及系统内存占用过高的处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

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

  • 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 字符串 > 文件 就是把字符串内容从定向到文件中

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • ubuntu中实现定时弹窗的提醒脚本

    ubuntu中实现定时弹窗的提醒脚本

    最近的项目是在ubuntu的环境下工作的,因为长时间工作身体不适,所以想写个脚本定时提醒自己喝水,伸懒腰,这篇文章记录了整个开发的过程,有需要的朋友们可以来一起看看。
    2016-10-10
  • 如何使用shell在多服务器上批量操作

    如何使用shell在多服务器上批量操作

    日常工作中,我们常需要同时在多台服务器上执行同样的命令,如对比日志、检查服务等。这就需要我们有服务器批量操作的能力,我们可以借用 ssh公钥登陆的能力,方便地实现在多个服务器上批量执行命令。
    2021-05-05
  • Linux apache实现https的配置方法

    Linux apache实现https的配置方法

    http协议主要是用来是实现万维网站点资源的访问,http协议+ssl协议,默认使用tcp的443端口,这篇文章主要介绍了Linux apache实现https的配置,需要的朋友可以参考下
    2022-10-10
  • Linux中dd命令使用实例教程

    Linux中dd命令使用实例教程

    dd命令用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。下面这篇文章主要给大家介绍了关于Linux中dd命令使用的相关资料,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-05-05
  • 解决linux下大量TIME WAIT的方法详解

    解决linux下大量TIME WAIT的方法详解

    本篇文章是对linux下大量TIME WAIT的解决方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • CentOS下采用Crontab实现PHP脚本定时任务

    CentOS下采用Crontab实现PHP脚本定时任务

    本篇文章主要介绍了CentOS下采用Crontab实现PHP脚本定时任务,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • linux更改目录显示颜色实例详解

    linux更改目录显示颜色实例详解

    这篇文章主要介绍了linux更改目录显示颜色实例详解的相关资料,需要的朋友可以参考下
    2017-04-04
  • Apache Spark 2.0 在作业完成时却花费很长时间结束

    Apache Spark 2.0 在作业完成时却花费很长时间结束

    大家在使用 Apache Spark 2.x 的时候可能会遇到这种现象:虽然我们的 Spark Jobs 已经全部完成了,但是我们的程序却还在执行。怎么回事呢?下面小编通过实例代码给大家介绍下
    2019-06-06
  • centos6超20TB磁盘的分区格式化的示例代码

    centos6超20TB磁盘的分区格式化的示例代码

    这篇文章主要介绍了centos6超20TB磁盘的分区格式化的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Linux ps和pstree命令知识点总结

    Linux ps和pstree命令知识点总结

    在本篇文章里小编给大家分享的是关于Linux ps和pstree命令知识点总结内容,需要的朋友们可以学习参考下。
    2020-02-02

最新评论