基于主机的管理一般需要收集服务器的日志信息用于及时发现错误,处理故障。

搭建linux下的集中日志服务器的程序一般可以用syslog,rsyslog,syslog-ng,还有scribe和fluentd等。

基本每一种方式都是服务器端和客户端的模式。

一般syslog,syslog-ng,rsyslog用于收集系统日志,scribe和fluentd用于收集业务日志,rsyslog和syslog-ng也可以收集业务日志,并可定制和过滤、筛选。

LogAnalyzer和LogZilla是分析系统日志,并用web界面展示的的工具,一般只用在syslog,syslog-ng,rsyslog日志系统中。

如下是基于Centos5的rsyslog+mysql+phplogcon的安装,安装前确认安装有EPEL源。

安装rsyslog以及rsyslog-mysql接口支持

yum install rsyslog rsyslog-mysql

安装数据库以及web程序

yum install mysql-server

yum install httpd php php-mysyql php-gd

#service mysqld status || service mysqld start

创建rsyslog写入数据需要的库文件,路径可能根据版本有所不同

mysql < /usr/share/doc/rsyslog-mysql-5.8.10/createDB.sql   创建数据库(确保一致/etc/rsyslog.conf and /path/top/phplogcon/config.php )

如果数据库输入root密码,会报错:

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

这时需要这样输入:

mysql < ./createDB.sql -uroot -p

然后输入root密码即可

mysql> grant all on Syslog.* to syslog@localhost identified by 'mypass';   用户名 syslog,密码mypass

mysql> flush privileges ;

修改配置文件

vi /etc/rsyslog.conf

# Log to Mysql Settings

$ModLoad ommysql

*.* :ommysql:localhost,Syslog,syslog,mypass

{ 注:

localhost:数据库主机名

Syslog:数据库名

syslog:用户名

mypass:密码

}

#Standard Redhat syslog settings

*.info;mail.none;authpriv.none;cron.none /var/log/messages

authpriv.* /var/log/secure

mail.* -/var/log/maillog

cron.* /var/log/cron

*.emerg *

uucp,news.crit /var/log/spooler

local7.* /var/log/boot.log

启动rsyslog:

service syslog stop

service rsyslog start

如果有如下报错信息

Feb 23 23:43:30 mon rsyslogd:could not load module ‘/usr/lib/rsyslog/ommysql’, dlopen: /usr/lib/rsyslog/ommysql: cannot open shared object file: No such file or directory

请尝试软连接

fix fast with:

ln -s /usr/lib/rsyslog/ommysql.so /usr/lib/rsyslog/ommysql

开机启动rsyslog,并关闭syslog的开机启动:

chkconfig syslog off

chkconfig rsyslog on

开启接收远程信息:

edit /etc/sysconfig/rsyslog with option -r:

修改成:SYSLOGD_OPTIONS=”-c2 -r514 -x -m 240”

默认开启UDP 514端口,请确保防火墙没有阻止。

接收不到客户端消息,查看/var/log/message报错:

rsyslogd: Name or service not known

rsyslogd: UDP message reception disabled due to error logged in last message.

这是没有设置端口号,需要在/etc/sysconfig/rsyslog修改

RSYSLOGD_OPTIONS="-c2 -r514"

centos用完,又试了下debain下的服务端,也是接收不到消息,查看/var/log/syslog/发现服务启动时mysql出错,明明用户名是syslog,但是报错信息却是rsyslog@localhost,仔细一找,原来在/etc/syslog.d/下多出一个配置文件mysql.conf,修改里面的配置后错误信息没有了。但是还是没有客户端日志写入。添加RSYSLOGD_OPTIONS选项后一直报错,去掉此项后正常,看来不是这个选项问题。

最后抓包发现,客户端确实有信息发来,但是接收报错:

10:24:09.328491 IP 192.168.0.202.40297 > debian-ibm.syslog: SYSLOG authpriv.info, length: 87

10:24:09.328501 IP debian-ibm > 192.168.0.202: ICMP debian-ibm udp port syslog unreachable, length 123

客户端192.168.0.202确实发了udp消息到514端口,但是服务端端口没启动。

打开/etc/rsyslog.conf

发现有两行行是关于514端口的配置是注释的,取消注释后,通信成功。取消以下四行的注释:

# provides UDP syslog reception

$ModLoad imudp

$UDPServerRun 514

# provides TCP syslog reception

$ModLoad imtcp

$InputTCPServerRun 514

以下是PHPLOGCON的安装

到网址下载最新版本,http://www.phplogcon.org/

新版本已更名为LogAnalyzer

安装如下方式安装

tar -zxvf phplogcon-2.8.1.tar.gz

cd phplogcon-2.8.1

mkdir /var/www/html/syslog

cp -a src/* /var/www/html/syslog

cd /var/www/html/syslog

chmod 666 config.php

#httpd    启动httpd

打开浏览器输入: http://yourserver/syslog/

按照提示操作

安装好后,请做如下操作,以防止被修改。

chmod 644 config.php

客户端发送日志

以Centos为例,不需要安装其他日志程序,直接修改/etc/syslog.conf,在最后一行下面加入:

/var/log/messages @rsyslog_IP

或者

*.*    @rsyslog_IP

保存,重启service syslog restart

查看phplogcon界面是否有客户端的日志出现。