tail -fのときにgrep一致を1つだけ印刷する方法は?

tail -fのときにgrep一致を1つだけ印刷する方法は?

アクティビティログを読み、特別な電話に応答しようとしています。

$ tail -f example.log | egrep 'pattern1|pattern2|pattern3|pattern4|pattern5'

しかし、いくつかのパターンは開発プロセスのためにほとんど印刷されず、他のパターンは非常に連続的に印刷されています。

egrepパターンごとに1つの要求のみを印刷して正しく機能するかどうかを簡単に確認するには?

ベストアンサー1

次のことができます。

tail -f example.log | awk '
  BEGIN {
    n = split("pattern1,pattern2,pattern3,pattern4,pattern5", pats, /,/)
  }
  {
    found=0
    for (i in pats) if ($0 ~ pats[i]) {
      found=1
      delete pats[i]
      n--
    }
  }
  found {print; if (!n) exit}'

awkすべてのモードが表示されると終了しますが、次に何かが記録されたときにのみ終了します(tailSIGPIPE)。

あるいは、行が複数のパターンと一致しない可能性があり、すべてのパターンを見つけた後に終了することに気が付かない場合は、短くなりますが効率が低下します。

awk '/pattern1/&&!a++ || /pattern2/&&!b++ || /pattern3/&&!c++ || \
     /pattern4/&&!d++ || /pattern5/&&!e++'

zshGNUを使用するとgrep

(trap '' PIPE;tail -f example.log > >(grep -m1 pattern1) \
                                  > >(grep -m1 pattern2) \
                                  > >(grep -m1 pattern3) \
                                  > >(grep -m1 pattern4) \
                                  > >(grep -m1 pattern5))

ただし、複数のパターンに一致する行は複数回印刷されることに注意してください。

おすすめ記事