LAMP+logzilla2.9.9+syslog-ng实现集中日志管理(第二版)[原创] 不指定

刘天斯 , 2010/07/24 14:28 , Linux , 评论(59) , 阅读(11567) , Via 本站原创 | |
一、前言
       为什么要引入第二版?由于第一版是基于Logzilla3.0,作者在Logzilla3.0以后做了licensed限制,可以从作者回复邮件的内容得到证实[图1]。因此需要定期去更新license.txt来达到延长使用期限的目的,个人感觉比较麻烦,同时还有主机及日志数的限制,这也是整理第二版的原因,当然,你也可以通过以下途径获取免费、无限制的licensed,见How to get a free, unlimited, license of LogZilla。但这不是本文所要讨论的话题:),第二版中本人采用logzilla2.9.9版来搭建一个免费、无限制的日志集中管理平台,功能上与3.0差异不大,好了,废话少说,我们开始吧!
[图1]

点击在新窗口中浏览此图片

平台截图
点击在新窗口中浏览此图片
点击在新窗口中浏览此图片

二、平台初始化
部署LAMP平台(略)

#yum install libdbi* libnet
#cpan Date::Calc Text::LevenshteinXS String::CRC32
#cpan -i Digest::SHA1
#cpan -i Net::MySQL

三、下载相关包

#cd /home/install
#mkdir logzilla;cd logzilla
#wget http://www.balabit.com/downloads/files/eventlog/0.2/eventlog_0.2.9.tar.gz
#wget http://www.balabit.com/downloads/files/syslog-ng/open-source-edition/3.0.3/setups/rhel-5-i386/syslog-ng-3.0.3-1.rhel5.i386.rpm

四、开始安装

# cp eventlog_0.2.9.tar.gz /usr/src/redhat/SOURCES/
# tar zxvf  eventlog_0.2.9.tar.gz
# cd eventlog-0.2.9/
# rpmbuild --ba eventlog.spec.bb
# cd /usr/src/redhat/RPMS/x86_64
# rpm -Uvh libevtlog*

#cd /home/install/logzilla
#rpm -Uvh syslog-ng-3.0.3-1.rhel5.i386.rpm

五、安装logzilla

#cd /www/webroot/
#wget http://php-syslog-ng.googlecode.com/files/logzilla_v2.9.9o.tgz
#tar xzvf logzilla_v2.9.9o.tgz
#mkdir -p /var/log/logzilla

六、配置Mysql

# mysql -u -p
mysql> SELECT @@event_scheduler;
+-------------------+
| @@event_scheduler |
+-------------------+
| OFF               |
+-------------------+
1 row in set (0.00 sec)


低于Mysql5.1版本会提示如下,如不打算升级到logzilla3.0,没有关系,可以略过此步骤。
mysql> SELECT @@event_scheduler;
ERROR 1193 (HY000): Unknown system variable 'event_scheduler'

激活event_scheduler

mysql> SET GLOBAL event_scheduler = 1;
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT @@event_scheduler;
+-------------------+
| @@event_scheduler |
+-------------------+
| ON                |
+-------------------+
1 row in set (0.00 sec)

mysql> quit;

七、修改Syslog-ng配置
#vi /opt/syslog-ng/etc/syslog-ng.conf

八、修改apache配置
#vi httpd.conf

重启apache服务:/etc/init.d/apache2 restart

九、修改php.ini
Vi /usr/local/php/lib/php.ini

十、配置日志分隔
cp /www/webroot/php-syslog-ng/scripts/contrib/system_configs/logrotate.d /etc/logrotate.d/logzilla

十一、添加作业

@daily /usr/local/php/bin/php /www/webroot/php-syslog-ng/scripts/logrotate.php >> /var/log/php-syslog-ng/logrotate.log
@daily /usr/bin/find /www/webroot/php-syslog-ng/html/jpcache/ -atime 1 -exec rm -f '{}' ';'
0,5,10,15,20,25,30,35,40,45,50,55 * * * * /usr/local/php/bin/php /www/webroot/php-syslog-ng/scripts/reloadcache.php >> /var/log/php-syslog-ng/reloadcache.log

十二、开始平台安装
# /etc/init.d/syslog-ng restart
http://192.168.0.100/logs/来进行安装
步骤如下:
点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

点击在新窗口中浏览此图片

十三、替换脚本路径

cd /www/wewroot/php-syslog-ng/scripts
./fixpaths.sh

或者直接用sed来修改

#sed -i -e "{ s@/path_to_logzilla@/www/webroot/php-syslog-ng@}" *.*

#/etc/init.d/syslog-ng restart

十四、客户端配置
在最后添加以下,其中syslog.admin.com.cn为主机域名,也可以直接用IP代替。
#vi /etc/syslog.conf
*.emerg;*.err;*.warning         @syslog.admin.com.cn
#/etc/init.d/syslog restart

测试:logger -p local4.err "This is a local.err test message."

十五、后续问题
问题一、点击[Graph]时会提示“JpGraph Error Font file "/usr/share/fonts/truetype/msttcorefonts/verdana.ttf" is not readable or does not exist.”
解决方法:
mkdir -p /usr/share/fonts/truetype/msttcorefonts/
上传windows XP/2003/vista/下的字体文件verdana.ttf到/usr/share/fonts/truetype/msttcorefonts/即可。

问题二、logs表无数据,运行/www/webroot/php-syslog-ng/scripts/contrib/dbgen/dbgen.pl
提示:Cannot determine peer address at /usr/lib/perl5/site_perl/5.8.5/Net/MySQL.pm line 277

解决方法:
1、是logzilla2.9.9安装时一个bug,新建的mysql的syslogadmin、sysloguser用户权限没有成功赋予,手工添加上就OK了,感谢【杭州】FIGO提供的故障案例。
2、如第1步不成功,尝试修改/www/webroot/php-syslog-ng/html/config/config.php文件mysql主机地址localhost为127.0.0.1。

问题三、搜索缓存图表只显示两天的数据,最近三天没有数据?
解决方法:
由于search_cache表采用的是MEMORY存储引擎,有大小的限制,修改一下/etc/my.cnf,在[MYSQLD]添加:
tmp_table_size=1G
max_heap_table_size = 1G
再重启mysql就可以了。
效果图:
点击在新窗口中浏览此图片

问题四、不能显示日志当中带有"<"、">"的问题,如思科系统的日志。
感谢[常州]老高提供的故障案例。
解决方法:
在tailresult.php和regularresult.php中查找

在里面添加

即可。

问题五、客户端日志无法入库。
感谢[北京]永远飞扬提供的故障案例。
系统环境:
CentOS release 5.5 (Final) i386 2.6.18-194.el5
LAMP (系统rpm默认安装)
Mysql:5.0.77
Php:PHP 5.1.6
Apache:2.2.3

原因:
perl for mysql驱动异常,直接采用bin/mysql+insert sql语句入库。

解决方法:
#vi /opt/syslog-ng/etc/syslog-ng.conf

*注:配置中的相关参数需根据个人实际环境进行修改。

参考文献:http://nms.gdd.net/index.php/LogZilla_Installation_Guide

如大家有什么疑问或感兴趣的话题可以通过weibo与我交流:http://t.qq.com/yorkoliu
小k Email Homepage
2011/12/22 18:27
刘兄, 我想问一下 如何用syslog-ng 获取客户端类似nginx haproxy apache的日志。
刘天斯 回复于 2011/12/23 19:00
先了解这些程序包是否支持syslog模块。
wyw
2011/12/17 11:35
大牛,想请问一下按照你的步骤都搭建好了以后,发现首页的logs per day 显示不出来,按照问题三去修改了也没用。可能是什么问题?谢谢
MT
2011/08/30 13:02
我碰到个问题,查了很多资料也没解决,还望指导下。1.把config.php里的host从localhost修改为127.0.0.1,输入http://ip/logs,出现登陆界面,登陆后报错如下:Error in perform_query functionNo DB link for query: SELECT * FROM users WHERE username='admin' AND pwhash='4277afca1c7800b5ecd999ef8513a71c'Mysql_error: Can't connect to MySQL server on '127.0.0.1' (13)直接在本机用mysql客户端是可以连接的:mysql -h 127.0.0.1 -u root -pWelcome to the MySQL monitor.  Commands end with ; or \g.Your MySQL connection id is 349903Server version: 5.0.77 Source distribution还请指导下,谢谢!
GG Email Homepage
2011/05/22 10:27
您好,请问那图表绘制是用什么软件啊
琼山阿泰 Email
2011/04/17 07:53
把这句:
0,5,10,15,20,25,30,35,40,45,50,55 * * * * /usr/local/php/bin/php /www/webroot/php-syslog-ng/scripts/reloadcache.php >> /var/log/php-syslog-ng/reloadcache.log

换成这句如何:
*/5 * * * * /usr/local/php/bin/php /www/webroot/php-syslog-ng/scripts/reloadcache.php >> /var/log/php-syslog-ng/reloadcache.log
刘天斯 回复于 2011/04/17 10:34
当然不行,我们要求分钟定位到整点位,*/5只能做到每隔5分钟。
lota
2011/02/28 14:54
最近才发现数据库里只有最近一个月的日志,前面的日志全没了
crontab里没有清除旧日志的计划
请问可能会是什么原因导致?
ev
2011/01/27 22:45
db_insert.pl的性能有没有做过测试?一分钟能插入多少条记录
刘天斯 回复于 2011/01/28 08:48
瓶颈不在脚本运算上,只要在数据库服务器的网卡流量、IO上。
yifan
2011/01/06 09:23
问一个问题,博主有没有遇到 Cache last updated on  这个时间有时候可以更新有时候好几天都不更新,重启一下mysql肯定会更新。
刘天斯 回复于 2011/01/06 21:15
尝试加大默认内存表大小。
Air Max 180 Email Homepage
2010/12/11 09:12
文章很好。
kevin
2010/12/02 14:13
发现这个挺麻烦哇,我现在也是用syslog-ng,不过我是悼念windows系统日志,使用cacti的一个插件syslog,我觉得挺好,就是有一点,空格被两个数字1替代了,找到了解决办法就是在syslog-ng的配置里面把那个template_escape(yes) 改成template_escape(no),但是会报一个错误,不过不影响使用,不知道你这里有没有这个问题?
刘天斯 回复于 2010/12/02 16:42
没有监控windows的服务器,多谢提供解决方案。
yifan Email Homepage
2010/12/01 16:55
问一下这个里面显示时间的时候能否把日期也显示了
刘天斯 回复于 2010/12/01 16:58
可以,需修改入库脚本及数据库结构。
123
2010/11/27 13:21
严格按上面的步骤重装N遍了,514端口还是没开放。:(
123
2010/11/26 19:49
你好!
请问一下,我按照你安装的方法去安装,syslog-ng服务已经启动了,为什么机器还没开514端口呢?
刘天斯 回复于 2010/11/26 20:15
请检查配置及日志。
keven
2010/11/25 01:40
安装完php-syslog-ng,登陆进入以后,提示没有主机,让我执行dbgen.pl
There appear to be no hosts in the Database yet
You can generate fake ones using scripts/dbgen.pl

但我执行dbgen.pl,却提示:
Debug off, showing only inserted data...
#08S01Bad handshake at ./dbgen.pl line 205
但我发现一点:
数据库里面:@@event_scheduler这里已经是ON状态了。。
我退出数据库以后重新登陆,再显示@@event_scheduler这里又变成OFF状态了(是否正常?)。
不知道是不是和这个有关?
请问我要让php-syslog-ng接收来自其他机器发过来的日志文件,接下来该怎么设置呀?
刘天斯 回复于 2010/11/25 08:47
与@@event_scheduler无关,应该还是数据权限这块的问题。
ooxx
2010/11/25 00:27
重新来了一次,这次syslog-ng的服务启动起来了。
一样的步骤,不知道到底是哪里错了。
谢谢liuts。:)
刘天斯 回复于 2010/11/25 08:46
:)
ooxx
2010/11/24 22:49
您好!
我的OS是centos5.5,syslog-ng是syslog-ng-3.0.3-1.rhel5.i386.rpm,因为是第一次配置,所以每一步都是按你上面写的在进行。
syslog-ng.conf文件的第一行内容为:
@versionon: 3.0
再无其它任何字符。

麻烦您帮我分析一下。
刘天斯 回复于 2010/11/25 08:46
应该是@version: 3.0,非@versionon: 3.0。
ooxx
2010/11/24 22:26
您好!
请问一下,我按照您的配置方法,配置到第12步,重启syslog-ng服务的时候,系统返回:
Configuration file has no version number, assuming syslog-ng 2.1 format. Please add @version: maj.min to the beginning of the file;
WARNING: global: the default value of chain_hostnames is changing to 'no' in version 3.0, please update your configuration accordingly;
syntax error in /opt/syslog-ng/etc/syslog-ng.conf at line 1.

syslog-ng documentation: http://www.balabit.com/support/documentation/?product=syslog-ng
mailing list: https://lists.balabit.hu/mailman/listinfo/syslog-ng

请问是怎么回事(好像是说syslog-ng.conf文件里没有版本号),该怎么解决呀?
刘天斯 回复于 2010/11/24 22:34
请提供你的OS及syslog-ng版本。另请确认配置首行的@version: 3.0无其它字符。
coralzd
2010/11/23 10:22
./dbgen.pl
Debug off, showing only inserted data...
Timeout of authentication at ./dbgen.pl line 205
出现以上错误,客户端也配置了syslog,但是并没有见到日志写入到库。
ps:sysloguser syslogadmin 已经赋权!
刘天斯 回复于 2010/11/23 10:45
参考文章后续问题。
ciici Email
2010/11/15 09:26
麻烦问下,我执行了dbgen.pl后出现了很多原作者的监控主机,怎么删除,怎么添加我自己的主机呢?然后问题2:我点击Graph,出现这样的报错: 图像:http://192.168.9.104/index.php?table=logs&excludeHost=0&host2=&host%5B%5D=1701-0&excludeProgram=0&program2=&excludeFacility=0&excludePriority=0&date=&time=&date2=&time2=&limit=50&topx=10&orderby=fo&order=DESC&graphtype=tophosts&msg1=&msg2=&msg3=&pageId=Graph 因本身有错误无法显示
刘天斯 回复于 2010/11/15 17:30
1、直接在Mysql数据库中delete掉就可以了,在客户端服务器添加sysctl指向便会自动添加主机。2、你确认GD库是否支持。
zaminy Email
2010/11/10 08:15
麻烦问下,我这里的繁体下乱码,windows传过来的日至是Big5的 数据库在在繁体下可以查询出来! utf-8的客户端环境,在控制台下也无法显示! 问下这是什么情况啊
刘天斯 回复于 2010/11/10 10:53
建议统一编码,在入库前做转换。/www/webroot/php-syslog-ng/scripts/db_insert.pl
分页: 1/3 第一页 1 2 3 下页 最后页
发表评论

昵称

网址

电邮

打开HTML 打开UBB 打开表情 隐藏 记住我 [登入] [注册]