AWK简介
awk和grep sed并称为linux三剑客,听名字就很牛逼,grep常用来做关键字匹配,什么 ps -ef | grep ‘XXX’查找进程 ,cat XXX.log | grep '关键字’查找文件的关键字应该是比较常用的了,sed好像没用过,awk以前听别人提到过很久之前使用过一次用来统计访问量,现在忘记的差不多了,这里刚好有一个需求是分析程序的耗时,因为和各种服务都有关联,需要知道程序的瓶颈在哪里,虽然程序中有监控上报的,有记录日志的,但是要分析耗时的话,还是实现不了这种功能,于是我想到了awk,于是查了一下资料,用了一下
使用之前需要记录耗时的log
public function millisecond($beginTime = false)
{
if($beginTime){
return $beginTime - round(microtime(true) * 1000);
}else{
return round(microtime(true) * 1000);
}
这里封装了一个获取当前时间毫秒数或者取毫秒数时间查的方法 ,在需要分析的接口前后加两行代码记录log就行了,注意log里面的关键字能区分是什么接口
然后就是运行程序
使用awk分析log
awk的语法很多博客都有介绍,要能够熟练的使用需要对照awk的语法,这里我只说明我使用的场景
首先日志文件的格式为: