从矩阵中打印出值

2024-09-26 17:52:35 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个任务,它会随着时间的推移消耗大量的CPU和内存。它为我提供了一个执行以下linux命令的输出:

mpstat -u 1 -P ALL

输出如下:

02:22:14 PM  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest   %idle
02:22:15 PM  all    4.51    0.00    0.11    0.00    0.00    0.00    0.00    0.00   95.37
02:22:15 PM    0    0.00    0.00    1.00    0.00    0.00    0.00    0.00    0.00   99.00
02:22:15 PM    1   **78.22**    0.00    0.99    0.00    0.00    0.00    0.00    0.00   20.79

02:22:15 PM    2    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
02:22:15 PM    3    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
02:22:15 PM    4    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM    5    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM    6    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
02:22:15 PM    7    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM    8    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM    9    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   10    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   11    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   12    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   13    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   14    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   15    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
02:22:15 PM   16    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   17    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   18    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   19    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
02:22:15 PM   20    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   21    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   22    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00
02:22:15 PM   23    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00

我想在bash/python/perl中每隔20秒获取位于第4列和第3行a[3][4]的值,即78.22。 所以我想要的脚本,将执行mpstat命令并打印出指定列中的值,并基于这些值创建一个图形。我在考虑将所需的值附加到.dat文件中,然后运行gnuplot or and app来创建图形。在

有什么建议吗?在


Tags: 内存命令图形linuxusrsys时间cpu
2条回答

您可以使用awk获得第3行和第4行单元格。下面的代码从mpstat的输出中获取此单元格,并将其与当前UNIX时间戳一起附加到统计文件中。在

mpstat -u 1 -P ALL | awk 'NR==4 {print systime(), $4}' >> stats.txt

要每隔20秒运行此命令:

^{pr2}$

然后用gnuplot绘制:

cat stats.txt | gnuplot -p -e 'set datafile separator " "; plot "-" using 1:2 with lines'

试试下面的方法

#!/bin/bash
function _mpstat() {
    while :; do
        arr=( $(mpstat -P 1 | tail -n 1) )
        echo "${arr[3]}"
        sleep 20
    done >> file.txt
}
_mpstat &
echo "_mpstat PID: $!"

说明

  • while :; do无限循环
  • $(mpstat -P 1 | tail -n 1)Mpstat仅cpu 1-P 1和尾-n 1最后一行,返回值$()
  • arr=( ... )命令将值返回到数组
  • echo "${arr[3]}"回波阵列索引3
  • sleep 20睡眠20秒
  • >> file.txt将stdout发送到while循环块中的文件。在
  • _mpstat &将函数发送到后台进程&
  • echo "_mpstat PID: $!返回函数的PID

您可以grep PID以显示其父进程,并在需要时同时终止这两个进程。在

相关问题 更多 >

    热门问题