linux日志文件怎么加时间,linux-如何按日期对几个日志文件的输出进行排序

我从几个不同的日志文件中得到了输出:

logfile3

2010/07/21 15:28:52 INFO xxx

2010/07/21 15:31:25 INFO xxx

2010/07/21 15:31:25 DEBUG xxx

logfile1

2010/07/21 19:28:52 INFO xxx

2010/07/21 19:31:25 INFO xxx

2010/07/21 19:31:25 DEBUG xxx

logfile2

2010/07/21 13:28:52 INFO xxx

2010/07/21 13:31:25 INFO xxx

2010/07/21 13:31:25 DEBUG xxx

我想按日期对输出进行排序,但将日志文件的名称保留在日志行上方,因此它应类似于:

logfile2

2010/07/21 13:28:52 INFO xxx

2010/07/21 13:31:25 INFO xxx

2010/07/21 13:31:25 DEBUG xxx

logfile3

2010/07/21 15:28:52 INFO xxx

2010/07/21 15:31:25 INFO xxx

2010/07/21 15:31:25 DEBUG xxx

logfile1

2010/07/21 19:28:52 INFO xxx

2010/07/21 19:31:25 INFO xxx

2010/07/21 19:31:25 DEBUG xxx

您是否知道如何使用sed或awk的bash命令对输出进行排序?

非常感谢!

更新:

这是输出的来源

for i in $( find log/ -iname *debug*.log -size +0 );do

if [ `grep -c 'ERROR' $i` -gt 0 ];then

echo -e "\n$i"

grep 'ERROR' --color=auto -A 5 -B 5 $i

fi

done

马丁

解决方法:

您可以从中获得满意的结果(只要您的文件名都不包含冒号):

grep -C 5 --recursive 'ERROR' log/* | sort --field-separator=: --key=2

每行将以文件名开头.您的输出将如下所示:

logfile2:2010/07/21 13:28:52 INFO xxx

logfile2:2010/07/21 13:31:25 INFO xxx

logfile2:2010/07/21 13:31:25 DEBUG xxx

logfile3:2010/07/21 15:28:52 INFO xxx

logfile3:2010/07/21 15:31:25 INFO xxx

logfile3:2010/07/21 15:31:25 DEBUG xxx

etc.

您可以使用AWK将其重新格式化为示例中显示的格式:

grep -C 5 --recursive 'ERROR' log/* | sort --field-separator=: --key=2 |

awk '{colon = match($0,":"); file = substr($0,1,colon - 1);

if (file != prevfile) {print "\n" file; prevfile = file};

print substr($0,colon+1)}'

如果您仍然使用脚本,则可以对脚本进行一些改进:

find log/ -iname "*debug*.log" -size +0 | while read -r file

do

if grep -qsm 1 'ERROR' "$file"

then

echo -e "\n$file"

grep 'ERROR' --color=auto -C 5 "$file"

fi

done

标签:bash,awk,sed,linux

来源: https://codeday.me/bug/20191209/2097687.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值