记一次AWK程序耗时日志分析

本文介绍了如何利用AWK进行日志分析,特别是针对程序耗时的记录和计算。通过封装获取时间的方法,在接口前后记录日志,然后使用AWK根据特定格式解析耗时数据,通过字段分割和运算计算平均耗时、总耗时等关键指标。AWK的工作原理包括内存处理和循环读取文件,其在日志分析中表现出强大效能,但面对分布式日志系统,如ELK,其应用可能受限。
摘要由CSDN通过智能技术生成

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的语法,这里我只说明我使用的场景
首先日志文件的格式为:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值