myselect 基于SQL的日志分析工具

程序名称:myselect

授权协议: GPL

操作系统: 跨平台

开发语言: PHP

myselect 介绍

myselect用sql语法对日志文件进行统计分析,把要分析的日志文件当成一个数据库,里面的日志行当作数据库记录,比awk等工具使用更方便

$ myselect -h
usage:
myselect ‘sql sentence’; 用 sql进行统计分析
myselect -s ‘log line’;对日志行按空格进行分割编号
myselect -n ‘log line’ ‘sql sentence’; 对日志行用sql进行解析
myselect -p ‘sql sentence’; 查看sql语法解析结果
myselect -c ‘sql sentence’; 查看sql计算过程

对于如下的Nginx日志

198.52.103.14 - - [29/Jun/2014:00:17:11 +0800] “GET /q/1403060495509100
HTTP/1.1” 200 26788 “http://wenda.so.com/q/1403060495509100“ “Mozilla/4.0
(compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; .NET CLR 2.0.50727)” 221
0.532

如果要知道来源ip最多的是哪些,myselect实现如下

$ myselect ‘select count($1),$1 from accesstest.log group by $1 order by
count($1) desc limit 10’
14 111.13.65.251
13 10.141.88.248
12 10.141.88.239
10 10.141.88.250
9 121.226.135.115
8 10.141.88.241
8 10.141.88.249
8 222.74.246.190
7 211.149.165.150
6 61.174.51.174

myselect 官网

https://github.com/micweaver/myselect

相关编程语言

IPTraf是一个使用简单的网络状况监视工具。
所谓 rootkit ,是一类入侵者经常使用的工具。这类工...
系统管理员可以利用Health Monitor 去监控网络中的每...
当服务器遭到黑客攻击时,在多数情况下,黑客可能对...
Hobbit是一个基于WEB用于监视系统运行状态和网络信息...
MX4J是Java管理扩展技术的一个开源实现,支持JSR3 (...