一、logrotate

logrotate 程序是一个日志文件管理工具。用来把旧的日志文件删除,并创建新的日志文件,我们把它叫做转储。我们可以根据日志文件的大小,也可以根据其天数来转储,这个过程一般通过 cron 程序来执行。

logrotate 程序还可以用于压缩日志文件,以及发送日志到指定的E-mail

logrotate 的配置文件是 /etc/logrotate.conf。主要参数如下表:

参数功能

compress            通过gzip 压缩转储以后的日志

nocompress               不需要压缩时,用这个参数

copytruncate       用于还在打开中的日志文件,把当前日志备份并截断

nocopytruncate   备份日志文件但是不截断

create mode owner group 转储文件,使用指定的文件模式创建新的日志文件

nocreate              不建立新的日志文件

delaycompress compress 一起使用时,转储的日志文件到下一次转储时才压缩nodelaycompress 覆盖 delaycompress 选项,转储同时压缩。

errors address     专储时的错误信息发送到指定的Email 地址

ifempty                 即使是空文件也转储,这个是 logrotate 的缺省选项。

notifempty            如果是空文件的话,不转储

mail address         把转储的日志文件发送到指定的E-mail 地址

nomail                  转储时不发送日志文件

olddir directory     转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统

noolddir                转储后的日志文件和当前日志文件放在同一个目录下

prerotate/endscript     在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行

postrotate/endscript   在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行

daily                     指定转储周期为每天

weekly                 指定转储周期为每周

monthly                指定转储周期为每月

rotate count          指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份

tabootext [+] list logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, ~

size size               当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB(sizek)或者MB (sizem).

二、logrotate安装

      yum -y install logrotate

三、自定义配置:(按需求定制)

[root@gy01 ~]# cd /u1/script/logsplit/

[root@gy01 logsplit]# cat nginx

   /u1/logs/nginx/*.log {

   sharedscripts

   rotate 8

   daily

   compress

   compresscmd/bin/gzip

   compressext .gz

   postrotate

   /usr/bin/killall-HUP nginx 2> /dev/null || true

   endscript

   }

             #注:加上压缩切割后的log日志文件命名格式,如:www_access.log.1.gz          

           [root@gy01 logsplit]#cat lbnginx

/u1/logs/lbnginx/*.log {

                 sharedscripts

                 rotate7

                  daily

                 postrotate

                  /usr/bin/killall-HUP lbnginx 2> /dev/null || true

                 endscript

}

#注:切割后log日志文件命名格式,如:www_access.log.1

           [root@gy01 logsplit]#cat php-fpm

/u1/logs/php/*.log {

                 sharedscripts

                 rotate7

                  daily

                 postrotate

                 /usr/bin/killall-12 php-fpm 2> /dev/null || true

                 endscript

}

           [root@gy01 logsplit]#cat rsync

/u1/script/rsync/logs/*.log {

                  sharedscripts

                 rotate7

                 daily

                 postrotate

                 endscript

}

四、定时脚本

      [root@gy01 logsplit]# crontab -e

#split lbnginx log

0      0       *       *      * (bash /u1/script/logsp.sh)

       [root@gy01 logsplit]#cat /u1/script/logsp.sh

#!/bin/bash

. ~/.bashrc

/usr/sbin/logrotate -f/u1/script/logsplit/lbnginx

/usr/sbin/logrotate -f/u1/script/logsplit/nginx

/usr/sbin/logrotate -f/u1/script/logsplit/php-fpm

五、日志分析命令:

Nginx的日志格式:

log_formataccess '$remote_addr - $remote_user [$time_local] "$request" $status$body_bytes_sent $request_time "$http_referer""$http_user_agent" $http_x_forwarded_for $connection$connection_requests';

log记录的详情:

117.30.92.75 -- [04/Jun/2013:00:00:02 +0800] "GET /gywww/testconn HTTP/1.1" 200 50.001 "-" "Mozilla/5.0 (compatible; MSIE 9.0; Window

s NT 6.1;Trident/5.0)" - 873663449 1

180.114.157.2- - [04/Jun/2013:00:00:02 +0800] "POST/gywww/resource/noticeService/getOfflineNoticeByUserid HTTP/1.1" 200 1470.003 "-"

"-" - 873663452 1

命令选项:

1)通过日志查看当天访问次数最多的时间段

[root@gy01 ~]# awk '{print $4}' access.log | grep "04/Jun/2013"|cut -c 14-18|sort|uniq -c|sort -nr|head

2)通过日志查看当天指定ip访问次数过的url和访问次数

[root@gy01 ~]# cat access.log | grep "117.30.92.75 " |awk '{print $7}' | sort | uniq -c | sort –nr

3)通过日志查看当天访问次数最多的10IP

[root@gy01 ~]# awk '{print $1}' access.log |sort |uniq -c|sort-nr|head

4)通过日志查看当天ip连接数,统计ip地址的总连接数

[root@gy01 ~]# cat access.log | grep "04/Jun/2013" | awk'{print $1}' | sort | uniq -c | sort –nr

5)通过日志查看当天访问次数最多的10IP ,只需要在上一个命令后加上head命令

[root@gy01 ~]# cat access.log | grep "04/Jun/2013" |awk'{print $3}'|sort |uniq -c|sort -nr|head –n 10

6)通过日志查看当天访问页面排前10url

[root@gy01 ~]# cat access.log | grep "04/Jun/2013" | awk'{print $7}' | sort | uniq -c | sort -nr | head -n 10