linux中自动化日志分析,linux 分析日志

linux环境下操作日志常用命令:

1.查找关键日志grep

2.精简或替换日志内容 sed

3.对记录进行排序sort

4.统计日志相关记录数 awk

1、查看当天有多少个IP访问

cut -d " " -f 1 /usr/local/apache2/logs/access_log |uniq -c | sort -rn | head -20

cut

-d, --delimiter=DELIM

use DELIM instead of TAB for field delimiter

表示用-分割,然后-f 1

-f, --fields=LIST

select only these fields;  also print any line that contains  no

delimiter character, unless the -s option is specified

表示打印第一部分,就是ip

uniq 是将重复行去掉, -c表示前面前面加上数目,

sort -rn 就是按照数字从大到小排序,

head -20取前面20行

或者

awk '{print $1}' log_file|sort|uniq|wc -l

2、查看某一个页面被访问的次数

grep "/index.php" log_file | wc -l

3、查看每一个IP访问了多少个页面

awk '{++S[$1]} END {for (a in S) print a,S[a]}' log_file

4、查看某一个IP访问了哪些页面

grep ^111.111.111.111 log_file| awk '{print $1,$7}'

5、查看2009年6月21日14时这一个小时内有多少IP访问

awk '{print $4,$1}' log_file | grep 21/Jun/2009:14 | awk '{print $2}'| sort | uniq | wc -l

7、输出日志中的某个日期中的ERROR的行

sed -n '/^2011-08-23.*ERROR/p' demolog.log

8、查找某个时间段内的日志

sed -n '/\[2017-06-13T18:00:10\,103+0800\]/,/\[2017-06-13T18:00:10\,114+0800\]/p' ecp-services-error.log

匹配得到从[2017-06-13T18:00:10,103+0800]开始到[2017-06-13T18:00:10,114+0800]结束的日志

更多linux命令详解请参考http://man.linuxde.net/shell-script

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值