我正在使用一个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 '^error\b'; 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|^error\b" | while read line; do
所以如果你愿意,一个长期运行的grep进程应该进行预处理.
编辑:如评论中所述,将-line-buffered添加到grep调用更安全.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。