假设日志文件是:access.log
内容格式是:ip 192.168.10.100 time 20220413 10:05:20
如图:
我们先来说一下思路:
抓日志文件中的文件要用时间戳,然后统计行数就是一天的访问量;要看每个客户的,就要用ip排序然后去重,得到客户的列表,导入到临时文件,然后逐行读取文件,再重新抓一下所有的日志文件做对比统计次数,导入到临时文件,再对临时文件做排序。
shell代码如下:
#!/bin/bash
echo "-----------------------" >> clients.log
time=`date -d -1day +"20%y%m%d"`
count=`grep "$time" access.log | wc -l`
echo "$time clients count is:$count" >> clients.log
grep "$time" access.log | sort -rn -k 2 | awk -F " " '{print $2}'