Linux free 命令详解

free 命令用来查看系统中已用的和可用的内存。

命令选项及输出简介

关于各种命令的功能和命令选项,还是推荐英语比较好的同学直接看手册 RTFM:man free。这里简单总结一下一些重点:

功能及输出简介

free 命令显示系统中可用和使用的物理内存和交换内存的总量,以及内核所使用的缓冲区 (buffers) 和缓存 (caches) 。通过解析 /proc/meminfo 收集信息。显示的列包括:

  • total:所有的内存
  • used:使用的内存
  • free:未使用的内存
  • shared:经常被 tmpfs 使用的内存
  • buffers:内存中被内核用作缓冲区(buffers)的部分
  • cache:内存中被用作页缓存(page cache)和 slabs 的部分
  • buff/cache:buffers 和 cache 的和
  • available:估计的无需交换即可为新启动的应用程序所用的内存量。

注意有这样一个等式: used = total - free - buffers - cache

参数选项

常用的选项用红色标出来了。

  • -b :以Byte为单位显示内存使用情况。

  • -k :以KB为单位显示内存使用情况。

  • -m:以MB为单位显示内存使用情况。

  • -h:以合适的单位显示内存使用情况,最大为三位数,自动计算对应的单位值。单位有:

    B = bytes, K = kilos, M = megas, G = gigas, T = teras
    
  • -o: 不显示缓冲区调节列。

  • -s<间隔秒数>: 持续观察内存使用状况。

  • -t :显示内存总和列。

  • -V: 显示版本信息。

一般就是 free -h

              total        used        free      shared  buff/cache   available
Mem:            46G         38G        400M        2.3G        7.4G        4.9G
Swap:          2.0G        2.0G          0B

我想只有在理解了一些基本概念之后,上面的输出才能帮助我们了解系统的内存状况。

关于Linux内存的一些知识

以下内容参考自博客:https://www.cnblogs.com/ultranms/p/9254160.html

buff/cache

先来提一个问题: buffer 和 cache 应该是两种类型的内存,但是 free 命令为什么会把它们放在一起呢?要回答这个问题需要我们做些准备工作。让我们先来搞清楚 buffer 与 cache 的含义。

buffer 在操作系统中指 buffer cache, 中文一般翻译为 “缓冲区”。要理解缓冲区,必须明确另外两个概念:“扇区” 和 “块”。扇区是设备的最小寻址单元,也叫 “硬扇区” 或 “设备块”。块是操作系统中文件系统的最小寻址单元,也叫 “文件块” 或 “I/O 块”。每个块包含一个或多个扇区,但大小不能超过一个页面,所以一个页可以容纳一个或多个内存中的块。当一个块被调入内存时,它要存储在一个缓冲区中。每个缓冲区与一个块对应,它相当于是磁盘块在内存中的表示(下图来自互联网):

注意,buffer cache 只有块的概念而没有文件的概念,它只是把磁盘上的块直接搬到内存中而不关心块中究竟存放的是什么格式的文件。

cache 在操作系统中指 page cache,中文一般翻译为 “页高速缓存”。页高速缓存是内核实现的磁盘缓存。它主要用来减少对磁盘的 I/O 操作。具体地讲,是通过把磁盘中的数据缓存到物理内存中,把对磁盘的访问变为对物理内存的访问。页高速缓存缓存的是内存页面。缓存中的页来自对普通文件、块设备文件(这个指的就是 buffer cache 呀)和内存映射文件的读写

页高速缓存对普通文件的缓存我们可以这样理解:当内核要读一个文件(比如 /etc/hosts)时,它会先检查这个文件的数据是不是已经在页高速缓存中了。如果在,就放弃访问磁盘,直接从内存中读取。这个行为称为缓存命中。如果数据不在缓存中,就是未命中缓存,此时内核就要调度块 I/O 操作从磁盘去读取数据。然后内核将读来的数据放入页高速缓存中。这种缓存的目标是文件系统可以识别的文件(比如 /etc/hosts)。
页高速缓存对块设备文件的缓存就是我们在前面介绍的 buffer cahce。因为独立的磁盘块通过缓冲区也被存入了页高速缓存(缓冲区最终是由页高速缓存来承载的)。

到这里我们应该搞清楚了:无论是缓冲区还是页高速缓存,它们的实现方式都是一样的。缓冲区只不过是一种概念上比较特殊的页高速缓存罢了。
那么为什么 free 命令不直接称为 cache 而非要写成 buff/cache? 这是因为缓冲区和页高速缓存的实现并非天生就是统一的。在 linux 内核 2.4 中才将它们统一。更早的内核中有两个独立的磁盘缓存:页高速缓存和缓冲区高速缓存。前者缓存页面,后者缓存缓冲区。当你知道了这些故事之后,输出中列的名称可能已经不再重要了。

有人认为:buffer是用于存放要输出到disk(块设备)的数据的,而cache是存放从disk上读出的数据。这二者是为了提高IO性能的,并由OS管理。

free 与 available

在 free 命令的输出中,有一个 free 列,同时还有一个 available 列。这二者到底有何区别?

free 是真正尚未被使用的物理内存数量。至于 available 就比较有意思了,它是从应用程序的角度看到的可用内存数量。Linux 内核为了提升磁盘操作的性能,会消耗一部分内存去缓存磁盘数据,就是我们介绍的 buffer 和 cache。所以对于内核来说,buffer 和 cache 都属于已经被使用的内存。当应用程序需要内存时,如果没有足够的 free 内存可以用,内核就会从 buffer 和 cache 中回收内存来满足应用程序的请求。所以从应用程序的角度来说,available = free + buffer + cache。请注意,这只是一个很理想的计算方式,实际中的数据往往有较大的误差。

交换空间(swap space)

swap space 是磁盘上的一块区域,可以是一个分区,也可以是一个文件。所以具体的实现可以是 swap 分区也可以是 swap 文件。当系统物理内存吃紧时,Linux 会将内存中不常访问的数据保存到 swap 上,这样系统就有更多的物理内存为各个进程服务,而当系统需要访问 swap 上存储的内容时,再将 swap 上的数据加载到内存中,这就是常说的换出和换入。交换空间可以在一定程度上缓解内存不足的情况,但是它需要读写磁盘数据,所以性能不是很高。

现在的机器一般都不太缺内存,如果系统默认还是使用了 swap 是不是会拖累系统的性能?理论上是的,但实际上可能性并不是很大。并且内核提供了一个叫做 swappiness 的参数,用于配置需要将内存中不常用的数据移到 swap 中去的紧迫程度。这个参数的取值范围是 0~100,0 告诉内核尽可能的不要将内存数据移到 swap 中,也即只有在迫不得已的情况下才这么做,而 100 告诉内核只要有可能,尽量的将内存中不常访问的数据移到 swap 中。在 ubuntu 系统中,swappiness 的默认值是 60。如果我们觉着内存充足,可以在 /etc/sysctl.conf 文件中设置 swappiness:

vm.swappiness=10

如果系统的内存不足,则需要根据物理内存的大小来设置交换空间的大小。具体的策略网上有很丰富的资料,这里笔者不再赘述。

/proc/meminfo 文件

其实 free 命令中的信息都来自于 /proc/meminfo 文件。/proc/meminfo 文件包含了更多更原始的信息,只是看起来不太直观。

cat /proc/meminfo

输出(输出很长,这是一部分):

MemTotal:       49033996 kB
MemFree:          381080 kB
MemAvailable:    5110936 kB
Buffers:           74580 kB
Cached:          7273148 kB
SwapCached:       591112 kB
...
DirectMap1G:           0 kB

总结

free 命令是一个既简单又复杂的命令。简单是因为这个命令的参数少,输出结果清晰。说它复杂则是因为它背后是比较晦涩的操作系统中的概念,如果不清楚这些概念,即便看了 free 命令的输出也 get 不到多少有价值的信息。

Ref:

https://www.cnblogs.com/ultranms/p/9254160.html

https://blog.csdn.net/sunansheng/article/details/51942522

Linux free 命令详解相关推荐

  1. linux mingetty 命令详解

    linux mingetty 命令详解 功能说明:精简版的getty. 语 法:mingetty [--long-hostname][--noclear][tty] 补充说明:mingetty适用于本 ...

  2. linux zip 命令详解

    功能说明:压缩文件.  语 法:zip [-AcdDfFghjJKlLmoqrSTuvVwXyz$][-b <工作目录>][-ll][-n <字尾字符串>][-t <日期 ...

  3. linux zipinfo 命令详解

    linux zipinfo 命令详解 功能说明:列出压缩文件信息. 语 法:zipinfo [-12hlmMstTvz][压缩文件][文件...][-x <范本样式>] 补充说明:执行zi ...

  4. Linux chkconfig命令详解

    Linux chkconfig命令详解 (2011-03-07 15:49:04) 转载 标签: linux shell chkconfig 杂谈 分类: 工作*Linux chkconfig:    ...

  5. linux uname 命令详解

    linux uname 命令详解 功能说明:显示系统信息. 语 法:uname [-amnrsv][--help][--version] 补充说明:uname可显示电脑以及操作系统的相关信息. 参 数 ...

  6. linux mread 命令详解

    linux mread 命令详解 功能说明:将MS-DOS文件复制到Linux/Unix的目录中. 语 法:mread [MS-DOS文件...][Linux文件或目录] 补充说明:mread为mto ...

  7. linux sort 命令详解

    linux sort 命令详解 sort命令的功能是对文件中的各行进行排序.sort命令有许多非常实用的选项,这些选项最初是用来对数据库格式的文件内容进行各种排序操作的.实际上,sort命令可以被认为 ...

  8. linux arpwatch 命令详解

    linux arpwatch 命令详解 功能说明:监听网络上ARP的记录. 语 法:arpwatch [-d][-f<记录文件>][-i<接口>][-r<记录文件> ...

  9. linux awk命令详解,使用system来内嵌系统命令,批量github,批量批下载视频, awk合并两列...

    linux awk命令详解 简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分 ...

  10. linux kill命令信号,linux kill命令详解

    kill 命令的用途 kill 命令很容易让人产生误解,以为它仅仅就是用来杀死进程的.我们来看一下 man page 对它的解释:kill - send a signal to a process. ...

最新文章

  1. 自学笔记——1.Pyhton保留关键字
  2. 识别手写字体app_我如何构建手写识别器并将其运送到App Store
  3. file的getPath getAbsolutePath和getCanonicalPath的不同
  4. 深度解读!时序数据库HiTSDB:分布式流式聚合引擎
  5. jQuery-DOM
  6. Exchange 2016 批量添加X500地址,解决迁移后退信的问题
  7. Jmeter进行分布式性能测试
  8. dump解析入门-用VS解析dump文件进行排障
  9. 对Java的URL类支持的协议进行扩展的方法
  10. 微型计算机作为载体的部件是,大工11秋《计算机应用基础》辅导资料二
  11. Java----前端验证之验证码额实现
  12. 服务器存档修改,云服务器存档修改器
  13. MV从命令行同时移动多种文件类型的小技巧
  14. springMVC+Mybatis实现查询分页
  15. 编程科普书籍推荐(Java)
  16. 红米 刷机 android7.1,有没有红米note3全网通的android7.1刷机包
  17. VS-RK3399 and VS-RK3288 Audio 开发指南
  18. AOP切面编程的理解
  19. 零基础步入数据分析岗,应该怎么开始?
  20. 2015 iMac如何绕过TMP安装Windows11(不用Parallels虚拟机实现macOS与Windows11双系统)

热门文章

  1. Flowable 数据库表结构 ACT_GE_PROPERTY
  2. Redis-6.2.5 安装 Linux环境(单机)
  3. JS键盘字母相应的keyCode值
  4. linux操作系统环境变量的配置
  5. postgresql定义访问ip与用户_PostgreSQL 设置允许访问IP的操作
  6. mysql统计每周每个学校新增学生数量_深入学习之mysql(四)聚合函数
  7. python中is和 的区别_Python中is和==的区别
  8. system.argumentnullexception值不能为null_MySQL NULL 值如何处理?
  9. 编译期java_java编译期和运行期
  10. python在城市规划中的运用_城市设计在城市规划管理中的运用