-
命令基本语法和参数
- 基本语法:
vmstat [选项] [延迟时间(秒)] [次数]
。例如,vmstat 2 5
表示每隔 2 秒输出一次系统资源信息,总共输出 5 次。 - 常用选项:
-a
:显示活跃和非活跃内存。活跃内存是指最近被访问的内存,非活跃内存是指较长时间未被访问的内存。-n
:只在启动时显示一次表头信息,之后的输出不再显示表头,使输出更加简洁。-s
:显示内存相关的统计信息汇总,如总的内存大小、已使用的内存量、交换空间大小等。
- 基本语法:
-
理解输出结果中的内存相关列
- swpd(交换空间使用量):
- 这一列显示了已经被交换到磁盘交换空间(swap)中的内存大小,单位是 KB。如果这个值不为 0 且持续增加,通常表示系统内存不足,系统正在将内存中的数据交换到磁盘上,以腾出空间给其他进程。例如,在一个运行多个大型应用程序的服务器上,如果
swpd
的值从 0 开始逐渐上升,可能需要考虑增加物理内存或者优化应用程序的内存使用。
- 这一列显示了已经被交换到磁盘交换空间(swap)中的内存大小,单位是 KB。如果这个值不为 0 且持续增加,通常表示系统内存不足,系统正在将内存中的数据交换到磁盘上,以腾出空间给其他进程。例如,在一个运行多个大型应用程序的服务器上,如果
- free(空闲物理内存):
- 表示系统中尚未被使用的物理内存量,单位是 KB。不过需要注意的是,Linux 系统会尽量利用空闲内存来进行缓存,以提高系统性能,所以
free
的值较低并不一定意味着系统内存紧张。
- 表示系统中尚未被使用的物理内存量,单位是 KB。不过需要注意的是,Linux 系统会尽量利用空闲内存来进行缓存,以提高系统性能,所以
- buff(缓冲区内存):
- 这部分内存用于存储块设备(如磁盘)的读写缓存。例如,当系统从磁盘读取数据时,会先将数据存储在缓冲区中,下次再读取相同的数据时,如果数据还在缓冲区,就可以直接从缓冲区获取,而不需要再次从磁盘读取,从而提高了磁盘 I/O 的效率。
- cache(缓存内存):
- 主要用于文件系统的缓存。它缓存了文件系统中的文件数据和目录结构等信息。比如,当一个应用程序频繁访问某些文件时,这些文件的内容会被缓存到
cache
中,这样后续的访问速度就会加快。
- 主要用于文件系统的缓存。它缓存了文件系统中的文件数据和目录结构等信息。比如,当一个应用程序频繁访问某些文件时,这些文件的内容会被缓存到
- inact(非活跃内存)和 active(活跃内存):
- 如果使用了
-a
选项,就会显示这两列。inact
表示最近一段时间内未被访问的内存,active
表示最近被访问过的内存。系统会根据内存的活跃程度来决定是否将其交换到磁盘或者回收用于其他用途。
- 如果使用了
- swpd(交换空间使用量):
-
实际应用场景和案例分析
- 性能监测场景:
- 假设你在管理一个 Web 服务器,在服务器负载高峰期,你可以使用
vmstat
来监控内存。如果发现swpd
值快速上升,同时free
值接近 0,可能是因为同时访问网站的用户过多,导致内存不足。此时,可以考虑优化 Web 服务器的配置,如调整 Apache 或 Nginx 的工作进程数量,或者增加服务器的物理内存。
- 假设你在管理一个 Web 服务器,在服务器负载高峰期,你可以使用
- 内存泄漏检测场景:
- 对于一个长期运行的应用程序,你可以定期运行
vmstat
来观察内存使用情况。如果swpd
和used
(已使用内存,可通过计算得到:used = total - free - buff - cache
)的值在没有明显负载增加的情况下持续上升,可能是应用程序存在内存泄漏。例如,一个 Java 应用程序在运行过程中,不断分配新的对象,但没有及时释放不再使用的对象,就会导致内存占用越来越高,通过vmstat
可以初步发现这种异常的内存增长情况。
- 对于一个长期运行的应用程序,你可以定期运行
- 性能监测场景:
06-14
2626

04-11
378
