Apache日志的一些操作命令技巧
假设apache日志格式为:
118.78.199.98 – - [09/Jan/2010:00:59:59 +0800] “GET /Public/Css/index.css HTTP/1.1″ 304 – “http://www.a.cn/common/index.php” “Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; GTB6.3)”
问题1:在apachelog中找出访问次数最多的10个IP。
awk '{print $1}' apache_log |sort |uniq -c|sort -nr|head -n 10
awk 首先将每条日志中的IP抓出来,如日志格式被自定义过,可以 -F 定义分隔符和 print指定列;
sort进行初次排序,为的使相同的记录排列到一起;
upiq -c 合并重复的行,并记录重复次数。
head进行前十名筛选;
sort -nr按照数字进行倒叙排序。
我参考的命令是:
显示10条最常用的命令
问题2:在apache日志中找出访问次数最多的几个分钟。
awk 用空格分出来的第四列是[09/Jan/2010:00:59:59;
cut -c 提取14到18个字符 -- 00:59
剩下的内容和问题1类似。
问题3:在apache日志中找到访问最多的页面:
类似问题1和2,唯一特殊是用sed的替换功能将”http://www.a.cn/common/index.php”替换成括号内的内容:”http://www.a.cn(/common/index.php)”
问题4:在apache日志中找出访问次数最多(负载最重)的几个时间段(以分钟为单位),然后在看看这些时间哪几个IP访问的最多?
1,查看apache进程:
2,查看80端口的tcp连接:
3,通过日志查看当天ip连接数,过滤重复:
4,当天ip连接数最高的ip都在干些什么(原来是蜘蛛):
5,当天访问页面排前10的url:
6,用tcpdump嗅探80端口的访问看看谁最高
接着从日志里查看该ip在干嘛:
7,查看某一时间段的ip连接数:
8,当前WEB服务器中联接次数最多的20条ip地址:
9,查看日志中访问次数最多的前10个IP
10,查看日志中出现100次以上的IP
11,查看最近访问量最高的文件
12,查看日志中访问超过100次的页面
13,列出传输时间超过 30 秒的文件
14,列出最最耗时的页面(超过60秒的)的以及对应页面发生次数
相关文章
win8下XAMPP中Apache模块无效(apache无法打开)的解决方法
win8下系统默认占用80端口,导致apache无法打开,下面是具体的解决方法:首先以管理员权限运行c:\windows\system32\cmd.exe.....感兴趣的朋友可以参考下哈,希望对大家有所帮助2013-07-07
Ubuntu安装telent服务器时出现:apt-get:Package has no installation的原因及
这篇文章主要介绍了Ubuntu安装telent服务器时出现:apt-get:Package has no installation的原因及解决方法的相关资料,需要的朋友可以参考下2016-11-11


最新评论