Linux性能分析工具sar篇
简介
sar(System Activity Report)是Linux系统中常用的性能分析工具,可以从多方面对系统的活动进行报告,包括:文件的读写情况、系统调用的使用情况、磁盘 I/O、CPU 效率、内存使用状况、进程活动及 IPC 有关的活动等。
我们可以使用sar
命令来获得整个系统性能的报告。这有助于我们定位系统性能的瓶颈,并且有助于我们找出这些烦人的性能问题的解决方法。
Linux 内核维护着一些内部计数器,这些计数器包含了所有的请求及其完成时间和 I/O 块数等信息,sar
命令从所有的这些信息中计算出请求的利用率和比例,以便找出瓶颈所在。
安装使用
sar工具通常是通过安装sysstat包来获取的。在Ubuntu系统中,可以使用以下命令来安装sysstat包:
sudo apt-get install sysstat
安装完成后,就可以使用sar命令来查看系统的性能指标了。sar命令的常用选项如下:
- -u:CPU使用率
- -r:内存使用情况
- -b:磁盘I/O情况
- -n:网络流量情况
- -q:系统负载情况
以下是一些常用的sar命令实例:
- 查看CPU使用率:
sar -u 1 3
每隔1秒钟记录一次系统负载情况,共记录3次,然后输出统计结果。
- 查看内存使用情况:
sar -r
- 查看磁盘I/O情况:
sar -b
- 查看网络流量情况:
sar -n DEV
- 查看系统负载情况:
sar -q
以上命令将会输出系统的性能指标,可以根据需要自行选择查看。另外,sar命令还支持输出到文件,可以使用以下命令将输出保存到文件中:
sar -u -o cpu.log
这将会将CPU使用率的输出保存到cpu.log文件中。
实时记录
sar工具默认是以系统启动时间为基准来记录性能数据的,如果想要让sar实时记录系统性能数据,可以使用以下命令:
sar -u 1 10
这个命令将会每秒钟记录一次CPU使用率,记录10次后自动退出。可以根据需要修改参数,比如记录内存使用情况可以使用以下命令:
sar -r 1 10
这个命令将会每秒钟记录一次内存使用情况,记录10次后自动退出。
如果想要将实时记录的数据保存到文件中,可以在命令中加上-o选项,比如:
sar -u 1 10 -o cpu.log
这个命令将会每秒钟记录一次CPU使用率,记录10次后将数据保存到cpu.log文件中。
另外,如果想要让sar工具在系统启动时自动记录性能数据,可以将以下命令添加到/etc/rc.local文件中:
/usr/lib64/sa/sa1 1 1 &
/usr/lib64/sa/sa2 -A &
这样每隔一分钟就会记录一次性能数据,并保存到/var/log/sa目录下。如果需要修改记录的时间间隔,可以修改命令中的参数。
查看指定时间段的内存使用率
sar -r -s HH:MM:SS -e HH:MM:SS
其中,-r选项表示查看内存使用率,-s选项指定开始时间,-e选项指定结束时间,HH:MM:SS表示具体的时间。注意,-s和-e选项必须同时指定。
例如,要查看2022年1月1日下午2点到下午3点之间的内存使用率,可以使用以下命令:
sar -r -s 14:00:00 -e 15:00:00
这个命令将会输出2022年1月1日下午2点到下午3点之间的内存使用率数据。
查看指定时间段的CPU使用率
sar -u -s HH:MM:SS -e HH:MM:SS
其中,-u选项表示查看CPU使用率,-s选项指定开始时间,-e选项指定结束时间,HH:MM:SS表示具体的时间。注意,-s和-e选项必须同时指定。
例如,要查看2022年1月1日下午2点到下午3点之间的CPU使用率,可以使用以下命令:
sar -u -s 14:00:00 -e 15:00:00
这个命令将会输出2022年1月1日下午2点到下午3点之间的CPU使用率数据。
sar -r -s 14:00:00 -e 15:00:00
这个命令将会输出2022年1月1日下午2点到下午3点之间的内存使用率数据。