这篇文章主要讲解了“Shell实现根据web日志计算平均连接时间功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Shell实现根据web日志计算平均连接时间功能”吧!
今天在网上看到一个求web连接平均时间的shell命令,在自己的机器上试了下,发现不能使用,居然出现awk: fatal: division by zero attempted这样的错误,就自己改了下shell命令.
原shell脚本例子:
代码如下:
cat access.log|grep "connect cbp" |awk 'BEGIN{sum=0;count=0;}{sum+=$10;count++;}END{printf("sum=%d,count=%d,avg=%f\n",sum,count, sum/count)}'
修改后的shell:
代码如下:
cat access.log |awk '{sum+=$10;count+=1} END{print "SUM:"sum"\nAVG:"sum/count"\nCOUNT:"count}'
执行结果:
代码如下:
SUM:33403166
AVG:7951.24
COUNT:4201
当然直接改原来的也可以:
代码如下:
cat access.log |awk 'BEGIN{sum=0;count=0;}{sum+=$10;count++;}END{printf("sum=%d,count=%d,avg=%f\n",sum,count, sum/count)}'
执行结果:
代码如下:
sum=33403166,count=4201,avg=7951.241609
可以看到原shell脚本求的结果更加精确些.有需要的可以自己拿去试试.
感谢各位的阅读,以上就是“Shell实现根据web日志计算平均连接时间功能”的内容了,经过本文的学习后,相信大家对Shell实现根据web日志计算平均连接时间功能这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。