apache统计日志的小脚本

日志test.log格式是这样的

abc.abc.com.cn - - [16/May/2005:18:46:27 +0800] "GET /xxx.html HTTP/1.1" 200 296

abc.abc.com.cn - - [16/May/2005:18:46:27 +0800] "GET /xxx.html HTTP/1.1" 200 296

bbc.abc.com.cn - - [16/May/2005:18:46:27 +0800] "GET /yyy.html HTTP/1.1" 200 296

使用cat test.log | cut -d"." -f1 | sort | uniq -c | sort -rn可以得到

abc 2
bbc 1

就是abc这个主机被访问了两次,bbc被访问1次

下面统计xxx和yyy页面被访问的次数

cat test.log | cut -d" " -f7 | sort | uniq -c | sort -rn

得到:

2 xxx.html
1 yyy.html

输出结果格式化为sql语句就更好了,需要用awk:

cat test.log |  cut -d"." -f1 | sort | uniq -c | sort -rn | awk '{print "update pv set num=num+"$1" where userid=/""$2"/";";}'

得出结果是:

update pv set num=num+2 where userid="xxx";
update pv set num=num+1 where userid="yyy"; 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值