sar命令

目录

前言

一、概述

命令格式

 参数说明

性能数据

二、CPU资源监控

 1、整体CPU使用统计(-u)

输出项说明

2、各个CPU实用统计(-P)

 三、内存监控

1、内存和交换空间的监控(-r)

输出项说明

2、内存分页监控(-B)

 输出项说明

四、I/O监控

1、I/O整体情况监控(-b)

​编辑

输出项说明

2、各个I/O设备情况监控(-d)

 输出项说明

3、进程队列长度和平均负载状态监控(-q)

 输出项说明

4、系统交换活动信息监控(-W)

 输出项说明

5、设备使用情况监控(-d)

 输出项说明

总结


前言

sar是用于监控Linux系统各个性能的优秀工具,包括:文件的读写情况、系统调用的使用情况、磁盘I/O、CPU效率、内存使用状况、进程活动及IPC有关的活动等。

一、概述

命令格式

sar [命令行选项] [<采样周期>][<采样次数>]

 参数说明

选项

说明

-A

所有报告的总和

-u

输出整体CPU使用情况的统计信息

-v

输出inode、文件和其他内核表的统计信息

-d

输出每一个块设备的活动信息

-r

输出内存和交换空间的统计信息

-b

显示I/O和传送速率的统计信息

-a

文件读写情况

-c

输出进程统计信息,每秒创建的进程数

-R

输出内存页面的统计信息

-y

终端设备活动情况

-w

输出系统交换活动信息

性能数据

  1. 整体CPU使用统计
  2. 各个CPU使用统计
  3. 内存使用情况统计
  4. 整体I/O情况
  5. 各个I/O设备情况
  6. 网络统计

sar -n DEV  2 3
-n:类型————要获取的类型的指标数据
DEV:类型参数
2:时间间隔————多少秒采集一次数据
3:检测次数

二、CPU资源监控

 1、整体CPU使用统计(-u)

使用-u选项,sar输出整体CPU的使用情况,不加选项时,默认使用的就是-u选项。以下命令显示采样时间为3s,采样次数为2次,整体CPU的使用情况:
sar 3 2 (或者 sar -u 3 2)

输出项说明

    输出项 说明

CPU

all表示统计信息为所有CPU的平均值。

%usr

CPU在用户态执行进程的时间百分比。

%nice

CPU在用户态模式下,用于nice操作,所占用CPU总时间的百分比。

%system

CPU处在内核态执行进程的时间百分比。

%iowait

CPU用于等待I/O操作占用CPU总时间的百分比。

%steal

 管理程序(hypervisor)为另一个虚拟进程提供服务而等待虚拟CPU的百分比。

%idle

CPU空闲时间百分比。  

若 %iowait 的值过高,表示硬盘存在I/O瓶颈
若 %idle 的值高但系统响应慢时,有可能是 CPU 等待分配内存,此时应加大内存容量
若 %idle 的值持续低于1,则系统的 CPU 处理能力相对较低,表明系统中最需要解决的资源是 CPU

2、各个CPU实用统计(-P)

使用-P ALL选项指示对每个内核输出统计信息,这里显示一共有4个CPU,分别是0、1、2、3对应指定每一个CPU的使用情况和信息

 也可以通过指定CPU的核数来查询单独每个内核的显示(从0开始计算第一个内核)

 可以将CPU的使用情况保存到文件中(test文件是提前创建好的)

 三、内存监控

1、内存和交换空间的监控(-r)

使用-r选项可显示内存统计信息,以下命令显示以1秒为采样时间,显示2次内存信息:

输出项说明

输出项

说明

kbmemfree

这个值和free命令中的free值基本一致,所以它不包括buffer和cache的空间

kbmemused

这个值和free命令中的used值基本一致,所以它包括buffer和cache的空间

%memused

这个值是kbmemused和内存总量(不包括swap)的一个百分比

kbbuffers

这个值就是free命令中的buffer

kbcached

这个值就是free命令中的cache

kbcommit

保证当前系统所需要的内存,即为了确保不溢出而需要的内存(RAM+swap)

%commit

这个值是kbcommit与内存总量(包括swap)的一个百分比

2、内存分页监控(-B)

使用-B选项可以分页监控内存,每5秒采样一次,连续3次,显示如下:

 输出项说明

选项

说明

pgpgin/s

表示每秒从磁盘或SWAP置换到内存的字节数(KB)

pgpgout/s

表示每秒从内存置换到磁盘或SWAP的字节数(KB)

fault/s

每秒钟系统产生的缺页数,即主缺页与次缺页之和(major + minor)

majflt/s

每秒钟产生的主缺页数

pgfree/s

每秒被放入空闲队列中的页个数

pgscank/s

每秒被kswapd扫描的页个数

pgscand/s

每秒直接被扫描的页个数

pgsteal/s

每秒钟从cache中被清除来满足内存需要的页个数

%vmeff

每秒清除的页(pgsteal)占总扫描页(pgscank+pgscand)的百分比

四、I/O监控

1、I/O整体情况监控(-b)

使用-b选项,可以显示磁盘I/O的使用情况:

输出项说明

选项

说明

tps

每秒钟物理设备的 I/O 传输总量

rtps

每秒钟从物理设备读入的数据总量

wtps

每秒钟向物理设备写入的数据总量

bread/s

每秒钟从物理设备读入的数据量,单位为 块/s

bwrtn/s

每秒钟向物理设备写入的数据量,单位为 块/s

2、各个I/O设备情况监控(-d)

使用-d选项可以显示各个磁盘的统计信息,再增加-p选项可以以sdX的形式显示设备名称(DEV显示的是设备名称)

 输出项说明

选项

说明

rd_sec/s

每秒从设备读取的扇区数

wr_sec/s

每秒往设备写入的扇区数

avgrq-sz

发送给设备的请求的平均大小(以扇区为单位)

avgqu-sz

发送给设备的请求队列的平均长度

await 

服务等待I/O请求的平均时间,包括请求队列等待时间 (单位毫秒)

svctm

设备处理I/O请求的平均时间,不包括请求队列等待时间 (单位毫秒)

%util

一秒中有百分之多少的时间用于 I/O 操作,即被io消耗的cpu百分比。

  • 如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈
  • 如果 svctm 比较接近 await,说明 I/O 几乎没有等待时间;如果 await 远大于 svctm,说明I/O 队列太长,io响应太慢,则需要进行必要优化
  • 如果avgqu-sz比较大,也表示有大量io在等待

3、进程队列长度和平均负载状态监控(-q)

每3秒采样一次,连续采样3次,监控进程队列长度和平均负载状态:

 输出项说明

输出项说明

runq-sz

运行队列的长度(等待运行的进程数)

plist-sz

进程列表中进程(processes)和线程(threads)的数量

ldavg-1

最后1分钟的系统平均负载(System load average)

ldavg-5

过去5分钟的系统平均负载

ldavg-15

过去15分钟的系统平均负载

4、系统交换活动信息监控(-W)

每5秒采样一次,连续采样3次,监控系统交换活动信息:

 输出项说明

输出项说明

pswpin/s

每秒系统换入的交换页面(swap page)数量

pswpout/s

每秒系统换出的交换页面(swap page)数量

5、设备使用情况监控(-d)

每2秒采样一次,连续采样1次,报告设备使用情况,需键入如下命令:

sar -d -p 2 1  #-d表示输出每一块设备的信息,参数-p可以打印出sda,hdc等磁盘设备名称,如果不用参数-p,设备节点则有可能是dev8-0,dev22-0

 输出项说明

输出项

说明

tps

每秒从物理磁盘I/O的次数.多个逻辑请求会被合并为一个I/O磁盘请求,一次传输的大小是不确定的

rd_sec/s

每秒读扇区的次数

wr_sec/s

每秒写扇区的次数

avgrq-sz

平均每次设备I/O操作的数据大小(扇区)

avgqu-sz

磁盘请求队列的平均长度

await

从请求磁盘操作到系统完成处理,每次请求的平均消耗时间,包括请求队列等待时间,单位是毫秒(1秒=1000毫秒)

svctm

系统处理每次请求的平均时间,不包括在请求队列中消耗的时间

%util

I/O请求占CPU的百分比,比率越大,说明越饱和

  • avgqu-sz 的值较低时,设备的利用率较高
  • 当%util的值接近 1% 时,表示设备带宽已经占满

总结

sar命令的监控项很多,他可以监控:整体CPU使用统计;各个CPU使用统计;内存使用情况统计;整体I/O情况;各个I/O设备情况;网络统计

如何判断什么时候是用什么参数选项?

  • 怀疑CPU存在瓶颈,可用 sar -u 和 sar -q 等来查看
  • 怀疑内存存在瓶颈,可用 sar -B、sar -r 和 sar -W 等来查看
  • 怀疑I/O存在瓶颈,可用 sar -b、sar -u 和 sar -d 等来查看

  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: sar(System Activity Reporter)命令是一个系统性能分析工具,它可以用来监控系统的各项指标,如CPU、内存、磁盘、网络等。sar命令通常需要与其他工具配合使用,如awk、sed、grep等,以便对sar输出的数据进行进一步处理。 sar命令的基本用法如下: ``` sar [options] [interval [count]] ``` 其中,options为sar命令的选项,interval为每次统计的时间间隔,count为统计的次数。如果不指定interval和count,则默认每隔1秒钟输出一次统计数据,直到用户手动中断为止。 以下是一些常用的sar命令选项: - -u:显示CPU使用情况 - -r:显示内存使用情况 - -b:显示磁盘I/O使用情况 - -n:显示网络使用情况 - -q:显示系统负载情况 例如,要查看系统CPU使用情况,可以使用以下命令: ``` sar -u 1 5 ``` 该命令将会每隔1秒钟输出一次CPU使用情况,共输出5次。输出结果包括CPU的各项指标,如用户时间、系统时间、空闲时间、等待I/O时间、硬件中断时间、软件中断时间等。 sar命令还可以将输出数据保存到文件中,以供后续分析。例如,要将CPU使用情况输出保存到文件中,可以使用以下命令: ``` sar -u 1 5 > cpu.log ``` 该命令将会将CPU使用情况输出到cpu.log文件中。保存的数据可以使用其他工具进行进一步处理和分析,如awk、sed、grep等。 ### 回答2: sar是一个在Linux系统中常用的性能收集和分析工具。它能够收集并报告系统的各种性能相关的数据,如CPU使用率、内存使用情况、磁盘和网络活动等。 sar命令的基本用法是通过在终端中输入"sar",然后加上相应的选项来获取不同类型的数据。常用的选项包括"-u"用于获取CPU使用率的数据,"-r"用于获取内存使用情况的数据,"-d"用于获取磁盘活动的数据,"-n"用于获取网络活动的数据等。 通过sar命令收集到的数据可以用来分析系统的性能瓶颈和优化调整。比如,可以通过查看CPU使用率的数据来确定是否存在CPU过载的问题,通过查看内存使用情况的数据来确定是否需要增加内存容量,通过查看磁盘活动的数据来确定磁盘性能是否足够等。 sar命令还支持将收集到的数据保存到文件中,以便日后进行分析。可以通过"-o"选项指定保存文件的路径,通过"-f"选项指定读取文件的路径,然后使用"-d"等选项来获取相应的数据并进行分析。 总之,sar命令是一个非常实用的性能监测工具,它能够帮助我们了解系统的运行状况,定位问题并进行优化。通过合理利用sar命令,我们可以更好地管理和维护Linux系统。 ### 回答3: sar命令是一个系统性能监测工具,用于收集和报告系统资源使用情况。它可以记录CPU利用率、内存使用、磁盘活动、网络流量和其他关键系统指标。sar命令通过对系统关键指标进行监测和记录,帮助管理员识别系统中的瓶颈和性能问题。 使用sar命令可以查看系统在给定时间段内的性能情况。可以指定特定时间间隔和持续时间以收集所需的数据。sar命令的输出可在终端以文本格式显示,也可以以二进制文件的形式进行存储,以供稍后分析和查看。 sar命令提供了各种选项,可以根据不同的需求来显示不同的系统性能数据。例如,可以使用"-u"选项来显示CPU的利用率和状态,"-r"选项用于显示内存的使用情况,"-b"选项用于显示磁盘活动等等。 此外,sar命令还可以生成报告和图表,以更直观地显示系统性能数据。通过加入"-o"选项,可以将数据保存到指定的文件中,然后使用sar命令的"-f"选项来分析这些数据。 总之,sar命令是一个功能强大的系统性能监测工具,可以帮助管理员实时监控和分析系统性能,及时解决性能问题,从而提高系统的稳定性和性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值