要想实时查看系统内存的情况,首先要知道 free 命令作用是什么。
free 命令显示系统内存的使用情况,包括物理内存、交换内存**(swap)**和内核缓冲区内存等。(默认为 kb)
命令效果如图所示:
free [选项]
使用man命令、–help命令、info命令可查询free命令的所有选项,以–help为例,如:
具体显示内存时候的语法:
free [-hbkmotV][-s <间隔秒数>]
参数表:
参 数:
-b 以Byte为单位显示内存使用情况。
-k 以KB为单位显示内存使用情况。
-m 以MB为单位显示内存使用情况。
-h 以比较人性化的方式显示内存使用情况。
-o 不显示缓冲区调节列。
-s <间隔秒数> 持续观察内存使用状况。
-t 显示内存总和列。
-V 显示版本信息。
-w wide output
free -b:以 Bytes 为单位来显示内存的信息
free -k:以 KB 为单位来显示内存的信息
free -m:以 M 为单位来显示内存的信息
free -g:以 G 为单位来显示内存的信息
free -h:以适于人类可读方式显示内存信息。-h 与其他命令最大不同是 -h 选项会在数字后面加上适于人类可读的单位
在大于** 1 数字后是 G(GB) 字母。当数字并没有达到 GB **时,**free **足够聪明来知道并在每个数字后面跟上合适的单位。
free -l:显示高低内存的利用率
free -t:显示 linux 的全部内存
free -s N:表示每隔 N 秒打印一次内存信息,直到用 ctrl+c 结束
free -V :显示版本信息
注意 V 一定要大写
free -w :wide output
-w 选项表示以宽格式显示结果,使得输出更易读
free 命令的选项是可以组合的:
为了方便下面的说明,在此从左到右依次解释显示的输出内容:
行:
列:
理解了一些基本概念之后,上面的输出才能帮助我们了解系统的内存状况。
buffer 和 cache 应该是两种类型的内存,但是 free 命令把它们放在一起,那么需要先来搞清楚 buffer 与 cache 的含义。buffer 在操作系统中指 buffer cache,即 “缓冲区”。cache 在操作系统中指 page cache,中文一般翻译为 “页高速缓存”。
要理解 buffer 缓冲区,须明确另外两个概念:“扇区” 和 “块”。
每个块包含一个或多个扇区,但大小不能超过一个页面,所以一个页可以容纳一个或多个内存中的块。当一个块被调入内存时,它要存储在一个缓冲区中。每个缓冲区与一个块对应,它相当于是磁盘块在内存中的表示(下图来自互联网)
注意,buffer cache 只有块的概念而没有文件的概念,它只是把磁盘上的块直接搬到内存中而不关心块中究竟存放的是什么格式的文件。(可以理解为快递件打包后整件运送,但是包裹里面东西可能完整、也可能细碎)
cache 页高速缓存是内核实现的磁盘缓存。它主要用来减少对磁盘的 I/O 操作。具体地讲,是通过把磁盘中的数据缓存到物理内存中,把对磁盘的访问变为对物理内存的访问。页高速缓存缓存的是内存页面。缓存中的页来自对普通文件、块设备文件(这个指的就是 buffer cache 呀)和内存映射文件的读写。
页高速缓存对普通文件的缓存可以这样理解:当内核要读一个文件(比如 /etc/hosts)时,它会先检查这个文件的数据是不是已经在页高速缓存中了。如果在,就放弃访问磁盘,直接从内存中读取。这个行为称为缓存命中。如果数据不在,就是未命中缓存,此时内核就要调度块 I/O 操作从磁盘去读取数据,然后内核将读来的数据放入页高速缓存中。
这种缓存的目标是文件系统可以识别的文件(比如 /etc/hosts)。
页高速缓存对块设备文件的缓存就是在前面的 buffer cahce。因为独立的磁盘块通过缓冲区也被存入了页高速缓存(缓冲区最终是由页高速缓存来承载的)。
所以缓冲区和页高速缓存,实现方式都是一样的。缓冲区只不过是一种概念上比较特殊的页高速缓存。
free 命令显示的是 buff/cache, 是因为缓冲区和页高速缓存的实现并非天生就是统一的。在 linux 内核 2.4 中才将它们统一。更早的内核中有两个独立的磁盘缓存:页高速缓存和缓冲区高速缓存。前者缓存页面,后者缓存缓冲区。只不过现在这两个差不多了,不用太过纠结。
这两个数据意义比较相近,但时存在不同
free 是真正尚未被使用的物理内存数量。
available 是从应用程序的角度看到的可用内存数量。
Linux 内核为了提升磁盘操作的性能,会消耗一部分内存去缓存磁盘数据,即 buffer 和 cache。所以对于内核来说,buffer 和 cache 都属于已经被使用的内存。当应用程序需要内存时,如果没有足够的 free 内存可以用,内核就会从 buffer 和 cache 中回收内存来满足应用程序的请求。所以从应用程序的角度来说,available = free + buffer + cache。
请注意,这只是一个很理想的计算方式,实际中的数据往往有较大的误差。
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
free 命令中的信息都来自于 /proc/meminfo 文件。/proc/meminfo 文件包含了更多更原始的信息,只是看起来不太直观:
也可以通过查看这个文件里面的数据,查看额定值。