Linux

將時間戳添加到“top”命令輸出

  • March 21, 2017

我正在從“頂部”中提取一些性能指標並將它們保存到文件中

top -b | grep 'tesseract\|node\|java\|beam.smp\|dockerd' > testm.txt

所以每一秒我都會得到下一個輸出:

  535 rabbitmq  20   0 1246756 128432   5536 S   1.3  3.4 618:33.41 beam.smp
  589 root      20   0  351040  47836  25740 S   0.0  1.3  12:38.72 dockerd
 1980 root      20   0 2236796  36844  15980 S   0.0  1.0   6:11.59 java
 1995 root      20   0 1766008 241428  21844 S   0.0  6.4  11:26.85 java
29965 root      20   0 1107460  63732  19328 S   0.0  1.7   0:01.69 node

我很好奇如何為這個輸出的每個塊添加時間戳,因為當長時間執行這個腳本時,不可能找出何時收集了一些隨機數據塊。

提前致謝!

使用而不是 grep 進行過濾top -b可以輕鬆地為單個執行的頂部輸出的每一行添加時間戳,因為它具有內置的時間函式,並且可以將它們注入到它的輸出中。awkawk

我沒有執行大多數這些程序,所以我在我的範例中添加了bash和過濾器……ssh

您可以使用簡單的紀元時間戳(自 1970 年 1 月 1 日以來的秒數)來做到這一點:

top -b | awk '/bash|ssh|tesseract|node|java|beam.smp|dockerd/ {print systime(), $0}'

哪個更小儲存,更清潔:

bash-$ top -b | awk '/bash|ssh|tesseract|node|java|beam.smp|dockerd/ {print systime(), $0}'
1490018813  1229 root      20   0  891536  42868  28348 S   0.0  0.3  15:07.30 dockerd
1490018813  1240 root      20   0   65520   6208   5488 S   0.0  0.0   0:00.01 sshd
1490018813  2666 tim       20   0   24336   7136   3492 S   0.0  0.0   0:00.05 bash
1490018813  2710 tim       20   0   46984   5324   4644 S   0.0  0.0   0:09.08 ssh
1490018813  2783 root      20   0  105988   7184   6184 S   0.0  0.0   0:00.00 sshd
1490018813  2804 root      20   0  105988   7404   6408 S   0.0  0.0   0:00.00 sshd

或者使用更易於閱讀的時間戳。

top -b | awk '/bash|ssh|tesseract|node|java|beam.smp|dockerd/ {print strftime("%Y-%m-%d-%H:%M:%S", systime(), $0}'

哪個更容易理解:

bash-[541]$ top -b -n 3 | awk '/ssh|bash|java|dockerd/ {print strftime("%Y-%m-%d-%H:%M:%S", systime()), $0}'
2017-03-20-10:04:23  1229 root      20   0  891536  42868  28348 S   0.0  0.3  15:07.24 dockerd
2017-03-20-10:04:23  1240 root      20   0   65520   6208   5488 S   0.0  0.0   0:00.01 sshd
2017-03-20-10:04:23  2666 tim       20   0   24336   7136   3492 S   0.0  0.0   0:00.05 bash
2017-03-20-10:04:23  2710 tim       20   0   46984   5324   4644 S   0.0  0.0   0:09.08 ssh
2017-03-20-10:04:23  2783 root      20   0  105988   7184   6184 S   0.0  0.0   0:00.00 sshd
2017-03-20-10:04:23  2804 root      20   0  105988   7404   6408 S   0.0  0.0   0:00.00 sshd
2017-03-20-10:04:23  2909 tim       20   0  105988   5072   4072 S   0.0  0.0   0:00.20 sshd
2017-03-20-10:04:23  2931 tim       20   0  105988   4252   3224 S   0.0  0.0   0:00.00 sshd

引用自:https://unix.stackexchange.com/questions/352594