【fps系统重构】-观察cpu、memroy、io -iostat

当您使用iostat命令监控磁盘I/O情况时,可以查看以下指标:

  • rrqm/s:每秒发生的读请求被合并的次数。如果该指标很低,说明读请求较少或未被合并,可能会导致磁盘I/O负载过重。
  • wrqm/s:每秒发生的写请求被合并的次数。如果该指标很低,说明写请求较少或未被合并,可能会导致磁盘I/O负载过重。
  • r/s:每秒完成的读操作次数。如果该指标很高,说明应用程序正在频繁地读取数据,可能需要优化读取逻辑或增加缓存等。
  • w/s:每秒完成的写操作次数。如果该指标很高,说明应用程序正在频繁地写入数据,可能需要优化写入逻辑或减少写入操作等。
  • rkB/s:每秒读取的数据量,单位为KB。如果该指标很高,说明应用程序正在读取大量数据,可能需要优化读取逻辑或增加缓存等。
  • wkB/s:每秒写入的数据量,单位为KB。如果该指标很高,说明应用程序正在写入大量数据,可能需要优化写入逻辑或减少写入操作等。
  • avgrq-sz:平均I/O请求的大小。如果该指标很小,说明应用程序正在频繁地进行小的I/O请求,可能需要优化I/O操作或增加缓存等。
  • avgqu-sz:平均I/O请求队列长度。如果该指标很高,说明I/O请求排队等待处理,可能会导致磁盘I/O负载过重。
  • await:平均I/O请求的等待时间和处理时间。如果该指标很高,说明I/O请求等待时间较长,需要优化I/O操作或增加缓存等。
  • svctm:平均I/O请求的处理时间。如果该指标很高,说明I/O请求的处理时间较长,需要优化I/O操作或增加缓存等。
  • %util:如下解释

以下是一个具体的案例,假设您正在运行一个Spring Boot应用程序,并且发现磁盘I/O负载较高。您可以使用iostat命令来分析问题:

shCopy Code

iostat -x 5

我的系统想看我的服务io使用情况,iotop 我的系统中没有安装这个命令,所以看不到,因为我的服务就是专门做解析文件的,所以大概能从每隔5输出日志可以看出 wkb/s  12515.60  很高  %util 11.9 这两个指标不是成正比的 

另外解释:%util指标

iostat 工具是一个常用的系统性能监测工具,可以通过它来获取磁盘 I/O 的相关信息,包括 %util 指标。

%util 是 iostat 工具中的一个指标,用于表示设备(如硬盘或分区)的繁忙程度。该指标的取值范围为 0 到 100,表示设备的使用率百分比。当设备处于繁忙状态时,其 %util 值会接近或达到 100;而在设备空闲时,其 %util 值则会接近或等于 0。

通常,高 %util 值意味着设备正在处理大量的 I/O 请求,这可能会导致性能下降。如果某个磁盘分区持续地出现高 %util 值,说明该分区存在 I/O 瓶颈,需要进一步优化。

需要注意的是,不同的设备在处理相同数量的 I/O 请求时,其 %util 值可能会不同。例如,固态硬盘(SSD)通常比机械硬盘具有更高的并发处理能力,因此即使处理相同数量的 I/O 请求,其 %util 值也可能更低。

因此,在使用 %util 指标进行性能分析时,需要结合实际场景和设备特性进行综合考虑,以便得出更准确的结论

你可能感兴趣的:(重构)