如何grep两个单独的日志文件? , 目前只输出到一个日志文件

问题描述

我有以下命令将 shell 脚本输出文件 RestartLog.log,然后仅将“错误”grep 到另一个文件 RestartLog_ERROR.log

 sudo  ./DailyRestart.sh |sudo tee  /RestartLog.log |grep ERROR | sudo tee /RestartLog_ERROR.log

我有两个问题

请帮我解决这两个问题

解决方法

只有 STDOUT 通过您的管道。如果还需要STDERR,需要先重定向到STDOUT:

sudo  ./DailyRestart.sh 2>&1 | ...
,

awk 可能是一个更好的选择:

./DailyRestart.sh | awk '/Warning/ { print $0 >> "RestartLog_WARNING.log" } /ERROR/ { print $0 >> "RestartLog_ERROR.log" }1' 

搜索包含“警告”的行并将该行打印到文件 RestartLog_WARNING.log。搜索包含“ERROR”的行并将该行打印到文件 RestartLog_ERROR.log。用 1 将所有行打印到屏幕上。