linux认识和分析日志文件

前言

唉,这周本来想彻底研究一下树的数据结构,结果搭建了基于nginx+php-fpm的web server运行模式,回到宿舍就太累没心思再思考数据结构和算法,就这样吧,这周就只搞运维了,虽然之间也写了点php代码学了点设计模式

syslogd:记录日志文件的服务

日志内容的一般格式

一般来说,系统产生的信息经过syslog而记录下来的数据中,每条信息均会记录下面几个重要数据:
(1)事件发生的日期与时间
(2)发生此事件的主机名
(3)启动此时间的服务名称
(4)该信息的实际数据内容
举个例子如下:

解释一下其中一条数据:在2012年11月15日的10:13:34秒,错误信息是php-fpm绑定的ip地址被使用了,主机名和服务名称是我自己设置没加上

syslog的配置文件

ubunt10,04之后,syslog的配置文件在
/etc/rsyslog.conf

配置文件的内容可以简单分为三部分说明:

服务名称

auth : 主要与认证有关的机制
cron : 就是例行性工作调度crontab等生成信息日志的地方
daemon : 就是各个daemon有关的信息
kern : 就是内核(kernel)产生信息的地方
lpr : 打印相关信息
mail : 只要与邮件收发有关的信息记录在此
news :  与新闻组服务器有关的东西


信息等级

info : 一些基本的信息说明
notice : 除了info还需要注意的一些信息内容
warning : 警示的信息,可能有问题,但是不至于影响到某个daemon的运行
error : 一些重大的错误信息
crit : 比error还要严重的错误信息
alert : 警告,已经很有问题的等级
emerg : “疼痛”等级,意指系统已经几乎要死机状态!
链接符号[.|.=|.!]

. : 代表比后面还要高的等级(含该等级)都被记录下来的意思。例如:news.err 代表只要是news的信息,而且该信息的等级大于等于error级别就会被记录下来的意思
.= : 代表所需要的等级==后面链接的等级,其它的不要
.! : 代表不等于,即除了该等级之外的等级都记录下来


说下题外话:
一个程序员一般会尽全力消除程序中所有的notice,因此到现在我也是仅仅见过error级别的,error之上的我觉得可能需要更大并发量的时候才能遇到

信息记录的文件名或设备或主机

注意

查看rsyslog的配置文件的时候,大部分linux选手会选择vim,并且更大的部分在退出文件的时候会:x一下,这就会麻烦了,我这里是参考了<<鸟哥linux私房菜>>中的说法:由于你vim保存了日志文件,则syslog会误判为该文件已被改动过,将导致syslog不再写入该文件新的内容,因此只能重新启动syslog程序了,重启命令:
/etc/init.d/rsyslog  restart

日志文件的轮替(logrotate)

前言:

syslog利用的是daemon的方式来启动的,当有需求的时候立刻会被执行,但是logrotate却是在规定的时间到了之后才来进行日志文件的轮替,所以这个logrotate程序当然是挂在cron下面进行的。


查看一下logrotate的内容如下:
#!/bin/sh

# Clean non existent log file entries from status file
cd /var/lib/logrotate
test -e status || touch status
head -1 status > status.clean
sed 's/"//g' status | while read logfile date
do
    [ -e "$logfile" ] && echo "\"$logfile\" $date"
done >> status.clean
mv status.clean status

test -x /usr/sbin/logrotate || exit 0
/usr/sbin/logrotate /etc/logrotate.conf
logrotate主要是针对日志文件来进行轮替操作,所以它必须记载在什么状态下才将日志文件进行轮替的设置,通过上面的shell脚本,就可以看出配置文件是在/etc/logrotate.conf

logrotate的配置文件

# see "man logrotate" for details
# rotate log files weekly
weekly   <== 默认每个星期进行一次logrotate工作

# keep 4 weeks worth of backlogs
rotate 4 <== 默认没星期保留4个日志文件

# create new (empty) log files after rotating old ones
create <== 由于日志文件被重命名,因此新建一个新的来继续存储

# uncomment this if you want your log files compressed
#compress <== 被修改的日志文件是否需要压缩存储?(文件太大可以考虑这个参数)

# packages drop log rotation information into this directory
include /etc/logrotate.d <== 将这个目录下的所有文件都读进来执行rotate程序

# no packages own wtmp, or btmp -- we'll rotate them here
/var/log/wtmp {  <== 仅针对/var/log/wtmp 所设置的参数
    missingok 
    monthly <== 每月执行一次备份操作
    create 0664 root utmp <== 指定文件的权限
    rotate 1 <== 仅保留一个
}

/var/log/btmp {
    missingok
    monthly
    create 0660 root utmp
    rotate 1
}

# system-specific logs may be configured here

logrotate语法

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 个备份 
size size:当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB (sizek)或者MB (sizem).

备注

本来想通过logrotate来按天备份nginx日志文件,查看了logrotate中关于nginx的配置,发现也是发送了kill -USR1信号给nginx重新生成日志,就不准备用nginx了,还是要自己写脚本通过crontab控制吧

按天备份php5-fpm脚本

#!/bin/bash - 

#1.php5-fpm日志存放路径
php5_fpm_logs_path="/var/log/php5-fpm/"
category_array=("access" "error")


#2.php5-fpm日志名后缀
postfix=`date -d '-1 days' +%Y%m%d`".log"


#3.php5-fpm日志切割
for category in ${category_array[*]}
do
	if [ -e $php5_fpm_logs_path/php5-fpm.$category.log ]
	then
		mv $php5_fpm_logs_path/php5-fpm.$category.log \
			$php5_fpm_logs_path/php5-fpm.$category.$postfix
	fi
done


#4.查找php5-fpm进程号,让其产生新的日志文件
php5fpm_pid=`ps -aux |grep -E 'php-fpm: master process'|grep -v 'grep'|awk '{print $2}'`
#USR1:Reopen log files,刷新nginx日志文件
kill -USR1 $php5fpm_pid


参考文献

<<鸟哥linux私房菜>>

你可能感兴趣的:(linux认识和分析日志文件)