Obtendo “awk: cmd. linha: 1: token inesperado ”

0

Quando eu corro abaixo do cmd na máquina do Controlador

Controller> echo DateTime Rd_avgMsec Wr_avgMsec; stats --diff --sho --int 60 --perf e2lxsplunkinx02-Hotdata --iosize --from 2016-10-11,00:00:00 --to 2016-10-11,00:03:00 | awk 'BEGIN{c=0} /^[0-9]|_avg/ {if (/^[0-9]/){printf "%s", $1;c++}else{ printf " %s", $NF/1000; c++ ; if(c==3){print ""; c=0}}}'

Eu recebo abaixo da saída:

DateTime Rd_avgMsec Wr_avgMsec
2016-10-11,00:01:00 2.732 0.21
2016-10-11,00:02:00 1.919 0.294
2016-10-11,00:03:00 1.856 0.22

Mas quando estou tentando executar o mesmo cmd remotamente na máquina controladora, estou recebendo um erro "awk: cmd. line:1: Unexpected token" . Eu estou tentando executar o cmd remotamente da máquina linux launchpad01. Alguém pode me ajudar a corrigir o erro?

[root@launchpad01 ~]# ssh admin@Controller "echo DateTime Rd_avgMsec Wr_avgMsec; stats --diff --sho --int 60 --perf e2lxsplunkinx02-Hotdata --iosize --from 2016-10-11,00:00:00 --to 2016-10-11,00:03:00 | awk 'BEGIN{c=0} /^[0-9]|_avg/ {if (/^[0-9]/){printf "%s", $1;c++}else{ printf " %s", $NF/1000; c++ ; if(c==3){print ""; c=0}}}'"
Warning: Permanently added 'Controller' (RSA) to the list of known hosts.
Password:
DateTime Rd_avgMsec Wr_avgMsec
awk: cmd. line:1: Unexpected token
    
por Bharat 13.10.2016 / 01:47

2 respostas

1

Este é um problema de citação. Mais simplesmente resolvido neste caso, executando o cachimbo awk localmente:

ssh admin@Controller "stats --diff --sho --int 60 --perf e2lxsplunkinx02-Hotdata --iosize --from 2016-10-11,00:00:00 --to 2016-10-11,00:03:00" |\
  awk 'BEGIN{c=0; print "DateTime","Rd_avgMsec","Wr_avgMsec";} /^[0-9]|_avg/ {if (/^[0-9]/){printf "%s", $1;c++}else{ printf " %s", $NF/1000; c++ ; if(c==3){print ""; c=0}}}'
    
por 13.10.2016 / 02:10
0

Se você não quiser rodar o awk pipe localmente como sugerido na resposta do rudimeier , tente escapar as aspas duplas dentro do seu comando:

ssh admin@Controller "echo DateTime Rd_avgMsec Wr_avgMsec; \
stats --diff --sho --int 60 --perf e2lxsplunkinx02-Hotdata --iosize --from 2016-10-11,00:00:00 --to 2016-10-11,00:03:00 | \
awk 'BEGIN{c=0} /^[0-9]|_avg/ {if (/^[0-9]/){printf \"%s\", $1;c++}else{ printf \" %s\", $NF/1000; c++ ; if(c==3){print \"\"; c=0}}}'"
    
por 13.10.2016 / 10:45

Tags