从矩阵中打印出值

时间:2012-12-11 22:58:17

标签: python regex linux bash

我有一项任务,随着时间的推移消耗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中获取位于第4列和第3行a [3] [4]的值,即每20秒获取78.22。 所以我想要的脚本将执行mpstat命令并打印出指定列中的值,并根据它创建图形的值。我想在.dat文件中附加所需的值并运行创建图形的gnuplot或app。

有关如何去的任何建议吗?

2 个答案:

答案 0 :(得分:4)

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

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

每20秒运行一次此命令:

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

然后用gnuplot

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

答案 1 :(得分:0)

尝试以下

#!/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]}" echo array index 3
  • sleep 20睡20秒
  • >> file.txt将stdout发送到while循环块中的文件。
  • _mpstat &将该功能发送到后台进程&
  • echo "_mpstat PID: $!返回函数的PID

您可以grep PID显示其父级并在需要时终止它们。