Adicionar um timestamp a cada linha da saída principal para uma execução individual de top -b
pode ser feito facilmente usando awk
em vez de grep para sua filtragem, porque awk
tem funções de hora incorporadas e pode injetá-las na saída.
Não estou executando a maioria desses programas, então adicionei bash
e ssh
ao filtro em meus exemplos ...
Você pode fazer isso com um timestamp de época simples (segundos desde 01-JAN-1970):
top -b | awk '/bash|ssh|tesseract|node|java|beam.smp|dockerd/ {print systime(), $0}'
Qual é menor para armazenar e mais limpo para olhar:
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
Ou com um timestamp mais legível para humanos.
top -b | awk '/bash|ssh|tesseract|node|java|beam.smp|dockerd/ {print strftime("%Y-%m-%d-%H:%M:%S", systime(), $0}'
O que é mais rápido de entender:
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