grep comando no script de shell

0

Eu tenho um arquivo de log e estou tentando escrever um script de shell para encontrar várias strings em um arquivo em várias linhas.

Por exemplo, se eu ver as frases "class=com.comcast.parker.GetCurrentAudioLanguageResponse" e "status:OK" juntas nos registros, devo imprimir getAudioLanguage SUCCESSFUL else getAudioLanguage FAILED . Então meu script de shell é assim:

logfile=$1

if grep "{\"class\":\"com.comcast.parker.GetCurrentAudioLanguageResponse\"" jags.txt | grep "{\"status\":\"OK\"" | wc -l ; then
    echo "getAudioLanguage SUCCESSFUL"
fi
if grep "{\"class\":\"com.comcast.parker.GetCurrentAudioLanguageResponse\"" $logfile | grep -q "GENERAL_ERROR" | wc -l ; then
    echo "getAudioLanguage FAILED"
fi

Nos logs, recebo status como GENERAL_ERROR , portanto, deve imprimir FAILED , mas a saída é exibida como getAudioLanguage SUCCESSFUL ..

Arquivo de log:

160125-11:11:28.442500 [mod=SYS, lvl=INFO] [tid=2332] ======= Message is onRPCCall ======>
160125-11:11:28.442614 [mod=SYS, lvl=INFO] [tid=2332] Entering onRPCCallEvent for request ---> getAudioLanguage
160125-11:11:28.442845 [mod=SYS, lvl=INFO] [tid=2332] Received json request = {"event":1,"handler":1,"name":"onRPCCall","params":{"callGUID":"d75a5bab-6b29-4ab4-9f7e-3cf32d4a05b1","callParams":[{"getAudioLanguage":{}}],"class":"com.comcast.xre.events.XRERPCCallInfo","destinationSessionGUID":"ab00ebea-5f63-4619-9877-273a2bceea1d","method":"getAudioLanguage","sourceSessionGUID":"ab00ebea-5f63-4619-9877-273a2bceea1d"},"phase":"STANDARD","source":1}

160125-11:11:28.442920 [mod=SYS, lvl=INFO] [tid=2332] GetCurrentAudioLanguage : Entered
160125-11:11:28.442968 [mod=SYS, lvl=INFO] [tid=2332] pMainPlayer is NULL.
160125-11:11:28.443012 [mod=SYS, lvl=INFO] [tid=2332] getAudioLanguage: Get Audio Language returned ��v'>       T�=     T0~�t
160125-11:11:28.443676 [mod=SYS, lvl=INFO] [tid=2332] ====== Response sending is {"appId":1,"command":"CALL","commandIndex":5,"method":"generateAppEvent","params":[{"class":"com.comcast.xre.events.XREOutgoingEvent","name":"onRPCReturn","params":{"callGUID":"d75a5bab-6b29-4ab4-9f7e-3cf32d4a05b1","class":"com.comcast.xre.events.XRERPCReturnInfo","destinationSessionGUID":"ab00ebea-5f63-4619-9877-273a2bceea1d","method":"getAudioLanguage","returnVal":{"class":"com.comcast.parker.GetCurrentAudioLanguageResponse","status":"GENERAL_ERROR","statusMessage":"Getting Current Audio Language was unsuccessful."},"sourceSessionGUID":"ab00ebea-5f63-4619-9877-273a2bceea1d"}},"ab00ebea-5f63-4619-9877-273a2bceea1d"],"targetId":1,"targetPath":"","timestamp":0}
    
por Jagannath Das 27.01.2016 / 15:25

3 respostas

0

O AWK pode ser um pouco mais fácil de usar:

awk '/GetCurrentAudioLanguageResponse/ && /status\"\:\"GENERAL_ERROR/{ print "FAIL" } /GetCurrentAudioLanguageResponse/ && /status\":\"OK/ {print "SUCCESS"}  ' log.txt

Nesse código, combinamos dois padrões e, se os padrões forem correspondentes, executamos o que está entre as chaves. Para GetCurrentAudioLanguageResponse e status":"GENERAL_ERROR , imprimimos "FAIL" e, para os padrões GetCurrentAudioLanguageResponse e status\":\"OK , imprimimos "SUCCESS"

    
por 27.01.2016 / 17:49
0

você deve verificar o status de retorno do comando grep. Por exemplo, se o meu arquivo contiver -

  a.b.c.d status:FAILED

executando o comando

  [[ $(grep "a.b.c.d" log | grep "FAIL") ]] && echo  "FAILED"

 FAILED
    
por 27.01.2016 / 15:51
0

Eu ofereço que você use sed para analisar o arquivo de log:

sed -n '
/{"class":"com.comcast.parker.GetCurrentAudioLanguageResponse"/{
    /"GENERAL_ERROR"/{
        c\getAudioLanguage FAILED
        p
        q
    }
    /"status":"OK"/{
        c\getAudioLanguage SUCCESSFUL
        h
    }
}
${
g
/SUCCESSFUL/p
}
' logfile
    
por 27.01.2016 / 17:32