前一段时间,我写过一篇文章,shell脚本分析 nginx日志访问次数最多及最耗时的页面(慢查询),其中提到了分析耗时页面重要性。今天主要讲的,是通过awk分析日志,快捷得到执行时间。在性能以及效率方面比前一篇提到的有很大提高!
一、web日志文件格式
代码如下:
二、执行代码
代码如下:
awk BEGIN{
print “Enter log file:”;
getline logs;
#logs=”/var/log/nginx/access.log-20101008″;
OFMT=”%.3f”;
while(getline < logs)
{
split($7,atmp,”?”);
aListNum[atmp[1]]+=1;
aListTime[atmp[1]]+=$NF;
ilen++;
}
close(logs);
print “\r\ntotal:”,ilen,”\r\n======================================\r\n”;
for(k in aListNum)
{
print k,aListNum[k],aListTime[k]/aListNum[k] | “sort -r -n -k3”;
} </p> <p>}结果:
性能:
422780条日志,统计完成速度是:5秒左右。