加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 用于等待日志文件中特定字符串的Bash脚本优化

发布时间:2020-12-13 13:52:25 所属栏目:Linux 来源:网络整理
导读:我正在使用一个bash脚本调用多个进程,这些进程必须按特定顺序启动,并且必须完成某些操作(然后它们会将某些消息打印到日志中),然后才能启动下一个进程. bash脚本具有以下代码,适用于大多数情况: tail -Fn +1 "$log_file" | while read line; do if echo "$li

我正在使用一个bash脚本调用多个进程,这些进程必须按特定顺序启动,并且必须完成某些操作(然后它们会将某些消息打印到日志中),然后才能启动下一个进程. bash脚本具有以下代码,适用于大多数情况:

tail -Fn +1 "$log_file" | while read line; do
    if echo "$line" | grep -qEi "$search_text"; then
        echo "[INFO] $process_name process started up successfully"
        pkill -9 -P $$tail
        return 0
    elif echo "$line" | grep -qEi '^errorb'; then
        echo "[INFO] ERROR or Exception is thrown listed below. $process_name process startup aborted"
        echo "  ($line)  "
        echo "[INFO] Please check $process_name process log file=$log_file for problems"
        pkill -9 -P $$tail
        return 1
    fi
done

但是,当我们将进程设置为以DEBUG模式打印日志记录时,它们会打印太多日志记录,以至于此脚本无法跟上,并且在完成该过程后大约需要15分钟才能使bash脚本赶上.有没有一种优化方法,比如将’while read line’改为’while read 100 lines’,或类似的东西?

最佳答案
如何不为每个日志行分配两个grep进程?

tail -Fn +1 "$log_file" | grep -Ei "$search_text|^errorb" | while read line; do

所以如果你愿意,一个长期运行的grep进程应该进行预处理.

编辑:如评论中所述,将-line-buffered添加到grep调用更安全.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读