free:一个在 Linux 中检查内存使用情况的标准命令

摘要: 我们都知道, IT 基础设施方面的大多数服务器(包括世界顶级的超级计算机)都运行在 Linux 平台上,因为和其他操作系统相比, Linux 更加灵活。有的操作系统对于一些微乎其微的改动和补丁更新都需要重启,但是 Linux 不需要,只有对于一些关键补丁的更新, Linux 才会需要重启。

我们都知道, IT 基础设施方面的大多数服务器(包括世界顶级的超级计算机)都运行在 Linux 平台上,因为和其他操作系统相比, Linux 更加灵活。有的操作系统对于一些微乎其微的改动和补丁更新都需要重启,但是 Linux 不需要,只有对于一些关键补丁的更新, Linux 才会需要重启。

Linux 系统管理员面临的一大挑战是如何在没有任何停机时间的情况下维护系统的良好运行。管理内存使用是 Linux 管理员又一个具有挑战性的任务。free 是 Linux 中一个标准的并且被广泛使用的命令,它被用来分析内存统计(空闲和已用)。今天,我们将要讨论 free 命令以及它的一些有用选项。

推荐文章:

Free 命令是什么

free 命令能够显示系统中物理上的空闲free和已用used内存,还有交换swap内存,同时,也能显示被内核使用的缓冲buffers和缓存caches。这些信息是通过解析文件 /proc/meminfo 而收集到的。

显示系统内存

不带任何选项运行 free 命令会显示系统内存,包括空闲free、已用used、交换swap、缓冲buffers、缓存cached和交换swap的内存总数。


  1. # free
  2. total used free shared buffers cached
  3. Mem: 32869744 25434276 7435468 0 412032 23361716
  4. -/+ buffers/cache: 1660528 31209216
  5. Swap: 4095992 0 4095992

输出有三行:

  • 第一行:表明全部内存、已用内存、空闲内存、共用内存(主要被 tmpfs(/proc/meminfo 中的Shmem 项)使用)、用于缓冲的内存以及缓存内容大小。

    • 全部:全部已安装内存(/proc/meminfo 中的 MemTotal 项)
    • 已用:已用内存(全部计算 - 空闲+缓冲+缓存)
    • 空闲:未使用内存(/proc/meminfo 中的 MemFree 项)
    • 共用:主要被 tmpfs 使用的内存(/proc/meminfo 中的 Shmem 项)
    • 缓冲:被内核缓冲使用的内存(/proc/meminfo 中的 Buffers 项)
    • 缓存:被页面缓存和 slab 使用的内存(/proc/meminfo 中的 Cached 和 SSReclaimable项)
  • 第二行:表明已用和空闲的缓冲/缓存
  • 第三行:表明总交换内存(/proc/meminfo 中的 SwapTotal 项)、空闲内存(/proc/meminfo 中的 SwapFree 项)和已用交换内存。

以 MB 为单位显示系统内存

默认情况下, free 命令以 KB - Kilobytes 为单位输出系统内存,这对于绝大多数管理员来说会有一点迷糊(当系统内存很大的时候,我们中的许多人需要把输出转化为以 MB 为单位,从而才能够理解内存大小)。为了避免这个迷惑,我们在 free 命令后面加上 -m 选项,就可以立即得到以 MB - Megabytes为单位的输出。


  1. # free -m
  2. total used free shared buffers cached
  3. Mem: 32099 24838 7261 0 402 22814
  4. -/+ buffers/cache: 1621 30477
  5. Swap: 3999 0 3999

如何从上面的输出中检查剩余多少空闲内存?主要基于已用used和空闲free两列。你可能在想,你只有很低的空闲内存,因为它只有 10%, 为什么?

  • 全部实际可用内存 = (全部内存 - 第 2 行的已用内存)

    • 全部内存 = 32099
    • 实际已用内存 = 1621 ( = 全部内存 - 缓冲 - 缓存)
  • 全部实际可用内存 = 30477

如果你的 Linux 版本是最新的,那么有一个查看实际空闲内存的选项,叫做可用available ,对于旧的版本,请看显示-/+ buffers/cache 那一行对应的空闲(free)一列。

如何从上面的输出中检查有多少实际已用内存?基于已用used和空闲free一列。你可能想,你已经使用了超过 95%的内存。

  • 全部实际已用内存 = 第一列已用 - (第一列缓冲 + 第一列缓存)

    • 已用内存 = 24838
    • 已用缓冲 = 402
    • 已用缓存 = 22814
  • 全部实际已用内存 = 1621

以 GB 为单位显示内存

默认情况下, free 命令会以 KB - kilobytes 为单位显示输出,这对于大多数管理员来说会有一些迷惑,所以我们使用上面的选项来获得以 MB - Megabytes 为单位的输出。但是,当服务器的内存很大(超过 100 GB 或 200 GB)时,上面的选项也会让人很迷惑。所以,在这个时候,我们可以在 free 命令后面加上 -g 选项,从而立即得到以 GB - Gigabytes 为单位的输出。


  1. # free -g
  2. total used free shared buffers cached
  3. Mem: 31 24 7 0 0 22
  4. -/+ buffers/cache: 1 29
  5. Swap: 3 0 3

显示全部内存行

默认情况下, free 命令的输出只有三行(内存、缓冲/缓存以及交换)。为了统一以单独一行显示(全部(内存+交换)、已用(内存+(已用-缓冲/缓存)+交换)以及空闲(内存+(已用-缓冲/缓存)+交换),在 ‘free’ 命令后面加上 -t 选项。


  1. # free -t
  2. total used free shared buffers cached
  3. Mem: 32869744 25434276 7435468 0 412032 23361716
  4. -/+ buffers/cache: 1660528 31209216
  5. Swap: 4095992 0 4095992
  6. Total: 36965736 27094804 42740676

按延迟运行 free 命令以便更好的统计

默认情况下, free 命令只会显示一次统计输出,这是不足够进一步排除故障的,所以,可以通过添加延迟(延迟是指在几秒后再次更新)来定期统计内存活动。如果你想以两秒的延迟运行 free 命令,可以使用下面的命令(如果你想要更多的延迟,你可以按照你的意愿更改数值)。

下面的命令将会每 2 秒运行一次直到你退出:


  1. # free -s 2
  2. total used free shared buffers cached
  3. Mem: 32849392 25935844 6913548 188 182424 24632796
  4. -/+ buffers/cache: 1120624 31728768
  5. Swap: 20970492 0 20970492
  6. total used free shared buffers cached
  7. Mem: 32849392 25935288 6914104 188 182424 24632796
  8. -/+ buffers/cache: 1120068 31729324
  9. Swap: 20970492 0 20970492
  10. total used free shared buffers cached
  11. Mem: 32849392 25934968 6914424 188 182424 24632796
  12. -/+ buffers/cache: 1119748 31729644
  13. Swap: 20970492 0 20970492

按延迟和具体次数运行 free 命令

另外,你可以按延迟和具体次数运行 free 命令,一旦达到某个次数,便自动退出。

下面的命令将会每 2 秒运行一次 free 命令,计数 5 次以后自动退出。


  1. # free -s 2 -c 5
  2. total used free shared buffers cached
  3. Mem: 32849392 25931052 6918340 188 182424 24632796
  4. -/+ buffers/cache: 1115832 31733560
  5. Swap: 20970492 0 20970492
  6. total used free shared buffers cached
  7. Mem: 32849392 25931192 6918200 188 182424 24632796
  8. -/+ buffers/cache: 1115972 31733420
  9. Swap: 20970492 0 20970492
  10. total used free shared buffers cached
  11. Mem: 32849392 25931348 6918044 188 182424 24632796
  12. -/+ buffers/cache: 1116128 31733264
  13. Swap: 20970492 0 20970492
  14. total used free shared buffers cached
  15. Mem: 32849392 25931316 6918076 188 182424 24632796
  16. -/+ buffers/cache: 1116096 31733296
  17. Swap: 20970492 0 20970492
  18. total used free shared buffers cached
  19. Mem: 32849392 25931308 6918084 188 182424 24632796
  20. -/+ buffers/cache: 1116088 31733304
  21. Swap: 20970492 0 20970492

人类可读格式

为了以人类可读的格式输出,在 free 命令的后面加上 -h 选项,和其他选项比如 -m 和 -g 相比,这将会更人性化输出(自动使用 GB 和 MB 单位)。


  1. # free -h
  2. total used free shared buff/cache available
  3. Mem: 2.0G 1.6G 138M 20M 188M 161M
  4. Swap: 2.0G 1.8G 249M

取消缓冲区和缓存内存输出

默认情况下,缓冲/缓存内存是同时输出的。为了取消缓冲和缓存内存的输出,可以在 free 命令后面加上 -w选项。(该选项在版本 3.3.12 上可用)

注意比较上面有缓冲/缓存的输出。


  1. # free -wh
  2. total used free shared buffers cache available
  3. Mem: 2.0G 1.6G 137M 20M 8.1M 183M 163M
  4. Swap: 2.0G 1.8G 249M

显示最低和最高的内存统计

默认情况下, free 命令不会显示最低和最高的内存统计。为了显示最低和最高的内存统计,在 free 命令后面加上 -l 选项。


  1. # free -l
  2. total used free shared buffers cached
  3. Mem: 32849392 25931336 6918056 188 182424 24632808
  4. Low: 32849392 25931336 6918056
  5. High: 0 0 0
  6. -/+ buffers/cache: 1116104 31733288
  7. Swap: 20970492 0 20970492

阅读关于 free 命令的更过信息

如果你想了解 free 命令的更多可用选项,只需查看其 man 手册


  1. # free --help
  2. or
  3. # man free


原文发布时间为:2017-03-17

本文来自云栖社区合作伙伴“Linux中国”

原文链接

时间: 2024-08-02 00:46:52

free:一个在 Linux 中检查内存使用情况的标准命令的相关文章

Linux中检查内存使用情况的命令

Linux操作系统包含大量工具,所有这些工具都可以帮助您管理系统.从简单的文件和目录工具到非常复杂的安全命令,在Linux上没有太多不能做的事情.而且,虽然普通桌面用户可能不需要在命令行熟悉这些工具,但他们对于Linux管理员来说是强制性的.为什么?首先,你需要在某个时候使用无GUI的Linux服务器.其次,命令行工具通常比其替代方案提供更多的功能和灵活性. 确定内存使用率是一项技能,您可能需要一个特定的应用程序和系统内存.发生这种情况时,知道您有多种工具可以帮助您排除故障,这很方便.或者,也许

linux中tomcat内存溢出解决办法

用命令 tail -f /root/apache-tomcat-6.0.20/logs/catalina.out(需要找到tomcat路径) 查看日志,查看是否有错误 linux中tomcat内存溢出解决办法 常见的一般会有下面三种情况:1.OutOfMemoryError: Java heap space2.OutOfMemoryError: PermGen space3.OutOfMemoryError: unable to create new native thread.前两种通常一起进

LINUX查看CPU内存使用情况

在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等.退出 top 的命令为 q (在 top 运行中敲 q 键一次). top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器 可以直接使用top命

用于监视Linux上的内存使用情况的Bash脚本

用于监视Linux上的内存使用情况的Bash脚本 2019-06-17 11:32:45作者:戴进稿源:云网牛站 在本文中,我们添加了两个shell脚本来监视Linux操作系统上的内存利用率,即用于监视Linux上的内存使用情况的Bash脚本,当系统达到给定阈值时,它将触发并发送电子邮件给你.可以参考脚本在实践中的应用:用脚本的方法解决搜狗拼音占用大量内存的问题. 方法一.Linux Bash脚本监视内存利用率并发送电子邮件 如果只想在系统达到给定阈值时通过邮件获取当前内存利用率百分比,请使用以

linux下查看内存使用情况

http://www.cnblogs.com/skyme/archive/2011/01/04/1925227.html linux下查看内存使用情况

linux 中常见的压缩和解压缩的命令

# linux 中常见的压缩和解压缩的命令 一.tar 1.解压: tar zxvf filename.tar 2.压缩: tar czvf filename.tar dirname 二.gz 1.解压: gunzip filename.gz gzip -d filename.gz 2.压缩: gzip filename 三.tar.gz 和 tgz 1.解压 tar zxvf filename.tar.gz 2.压缩 tar zcvf filename.tar.gz dirname 3.压缩多

Linux中的内存管理(转)

原文:http://blog.chinaunix.net/uid-26611383-id-3761754.html 前一段时间看了<深入理解Linux内核>对其中的内存管理部分花了不少时间,但是还是有很多问题不是很清楚,最近又花了一些时间复习了一下,在这里记录下自己的理解和对Linux中内存管理的一些看法和认识. 我比较喜欢搞清楚一个技术本身的发展历程,简而言之就是这个技术是怎么发展而来的,在这个技术之前存在哪些技术,这些技术有哪些特点,为什么会被目前的技术所取代,而目前的技术又解决了之前的技

转:Linux中的内存管理

前一段时间看了<深入理解Linux内核>对其中的内存管理部分花了不少时间,但是还是有很多问题不是很清楚,最近又花了一些时间复习了一下,在这里记录下自己的理解和对Linux中内存管理的一些看法和认识. 我比较喜欢搞清楚一个技术本身的发展历程,简而言之就是这个技术是怎么发展而来的,在这 个技术之前存在哪些技术,这些技术有哪些特点,为什么会被目前的技术所取代,而目前的技术又解决了之前的技术所存在的哪些问题.弄清楚了这些,我们才能比 较清晰的把握某一项技术.有些资料在介绍某个概念的时候直接就介绍这个概

查看linux中swap内存的相关参数

内容主要来源于:linux的内存回收和交换 各项命令查看的linux环境是:Linux SUSE-33 2.6.32.12-0.7-defaul zone? 内存管理的相关逻辑都是以zone为单位的,这里zone的含义是指内存的分区管理.Linux将内存分成多个区,主要有直接访问区(DMA).一般区(Normal)和高端内存区(HighMemory).内核对内存不同区域的访问因为硬件结构因素会有寻址和效率上的差别.如果在NUMA架构上,不同CPU所管理的内存也是不同的zone. /proc/zo