Search code examples
bashunixlogginggrepdefunct

How to grep multiline stack trace? Defunct threads are created with my solution


I have a file (application.log) where my applications store their logs. Sometimes I've got an Exception and I'd like to store only these exceptions in another file (exception.log). Each line of logs starts from the date in such format:

[2017-28-09 10:00:00,000] Text of log number 1
[2017-28-09 10:00:05,000] Text of log number 2
[2017-28-09 10:00:10,000] Text of Exception number 1
 at bla bla bla
 at bla bla bla    
 at bla bla bla    
 at bla bla bla    
[2017-28-09 10:00:15,000] Text of log number 4

In such siutation to exception.log should be stored:

[2017-28-09 10:00:10,000] Text of Exception number 1
 at bla bla bla
 at bla bla bla    
 at bla bla bla    
 at bla bla bla  

I tried with such method:

kill $(ps -ef | grep tail | awk '{print $2}')
tail -f /path/to/my/application.log | pcregrep -M 'Exception[^\[]+' | while read line
do
(echo "$line" >> /path/to/my/exception.log)
done &

This solution successfully does the job but also it created many threads and number of total threads in my system dramtically increased. Because of that I need to use another solution or resolve "defunct issue".

Do you, guys, have any idea how can I cut, grep or copy only Exception stack trace to another file or prevent to not open defunct threads?


Solution

  • $ cat test.txt 
    [2017-28-09 10:00:00,000] Text of log number 1
    [2017-28-09 10:00:05,000] Text of log number 2
    [2017-28-09 10:00:10,000] Text of Exception number 1
     at bla bla bla
     at bla bla bla    
     at bla bla bla    
     at bla bla bla    
    [2017-28-09 10:00:15,000] Text of log number 4
    
    $ awk '/\[.*\]/{d=0; if($0 ~ "Exception")d=1}d' test.txt
    [2017-28-09 10:00:10,000] Text of Exception number 1
     at bla bla bla
     at bla bla bla    
     at bla bla bla    
     at bla bla bla