我是靠谱客的博主 沉静小丸子,最近开发中收集的这篇文章主要介绍linux 统计日志数量总,shell统计日志中时间段内匹配的数量的方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

shell统计日志中时间段内匹配的数量的方法,有需要的朋友可以参考下。

假设日志文件mtasvr.log格式如下:

T:24583088(04:02:06)[root:Info] 6KqowLDLAgC93DFIKrENAA==.41S2:from=,to=, queued

T:122428336(13:36:51)[root:Info] 6KqowLAbAAByYzJIZGsOAA==.2W:from=,to=, queued

要求统计从14:27:20到15:26:41之间包含queued的数量。

最初,用grep匹配queued,然后用awk取出()中间的时间,最后用wc来统计行数,得到下面这条语句:

复制代码 代码如下:

cat mtasvr.log |grep queued |awk -F( '{print $2}' |awk -F) '{if ($1>="14:27:20" && $1<="15:26:41") {print $1}}' |wc -l

接下来,觉得两次awk取出括号()中的时间比较繁琐。决定用sed替换掉括号再统计,会比较好看:

复制代码 代码如下:

cat mtasvr.log |grep 'queued' |sed "s/[()]/;/g" |awk -F; '{if ($2>="14:27:20" && $2<="15:26:41") {print}}' |wc -l

然后,想法应该去掉cat和grep。cat本身就没必要,grep的匹配也可以直接用sed来完成:

复制代码 代码如下:

sed "/queued/s/[()]/;/g" mtasvr.log |awk -F; '{if ($2>="14:27:20" && $2<="15:26:41") {print}}' |wc -l

最后,把wc统计行数也去掉,只用sed和awk来完成这个任务:

复制代码 代码如下:

sed "/queued/s/[()]/;/g" mtasvr.log |awk -F; '{if($2>="14:27:20" && $2<="15:26:41") m++} END{print m}'

总结:

sed和awk很强大,当然有些简化也没必要。

比如wc就能很好的完成统计行数的任务,没必要再去想awk怎么来实现。

最后

以上就是沉静小丸子为你收集整理的linux 统计日志数量总,shell统计日志中时间段内匹配的数量的方法的全部内容,希望文章能够帮你解决linux 统计日志数量总,shell统计日志中时间段内匹配的数量的方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部