Tomcat集群配置日志服务器

1 整体架构

2 中央日志服务器配置

2.1 配置时钟同步

2.1.1 方式一

中央日志服务器和Tomcat节点均向同一个时钟源(例如:pool.ntp.org)进行对时即可。说明:本小节下面命令均以root用户执行,并且在中央日志服务器和Tomcat节点均要执行。

首先,需要关闭ntpd服务:

service ntpd stop

chkconfig ntpd off

执行crontab -e,输入下面内容:

*/5 * * * * ntpdate pool.ntp.org

表示:每隔5分钟向时钟源pool.ntp.org对时一次

然后重启cron:service crond restart

2.1.2 方式二

中央日志服务器作为时钟源,其他Tomcat节点均向中央日志服务器对时,需保证中央日志服务器时间是正确的。

说明:本小节下面命令均以root用户执行。

2.1.2.1. 中央日志服务器

开启ntpd服务,执行下面命令:

service ntpd start

chkconfig ntpd on

2.1.2.2. 所有Tomcat节点

测试ntp能否连接到中央日志服务器:

ntpdate 192.168.1.1

如果连接不成功一般是2个原因导致的:

1. Server端的ntpd服务刚刚启动,一般情况下需要等待几分钟之后才能对时成功;

2. 防火墙问题,需要开放udp 123端口号;

关闭ntpd服务:

service ntpd stop

chkconfig ntpd off

然后执行crontab -e,输入下面内容:

*/5 * * * * ntpdate 192.168.1.1

表示:每隔5分钟向中央日志服务器对时一次。

然后重启cron:service crond restart

2.2 防火墙配置

rsyslog默认运行在514端口号上,需要配置防火墙开放514端口,或者关闭防火墙。

另外,如果运行在RHEL、CentOS、Fedora等Linux系统上,还需要关闭SeLinux。

2.3 配置rsyslog

编辑rsyslog.conf:

取消下面两行的注释(删除掉前面的#):

$ModLoad imudp

$UDPServerRun 514

修改下面一行,添加“;local2.none”,不将local2的日志写入/var/log/messages:

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

添加下面一行,将local2的debug级别日志写入/var/log/dispatcher/debug.log:

local2.debug /var/log/dispatcher/debug.log

2.4 配置logrotate

针对上面配置的日志文件/var/log/dispatcher/debug.log,为避免其日积月累导致文件过于庞大,还需要为其进行及时备份,采用Linux自带的logrotate工具即可实现该功能。

新建文件/etc/logrotate.d/dispatcher,内容为:

/var/log/dispatcher/debug.log {

copytruncate

daily

minsize 1M

rotate 90

}

表示:每天备份一次,备份90个文件,即只保留3个月内的日志文件。

参数说明如下:

1. copytruncate:表示此方法采用的是先拷贝再清空的方式,整个过程中日志文件的操作句柄没有发生改变,所以不需要通知应用程序重新打开日志文件;

2. daily:每天轮询备份;

3. minsize 1M:最小文件大小为1M,超过这个值才进行rotate;

4. rotate 90:轮询备份90个文件。

logrotate是基于cron任务来执行的,其执行脚本位于/etc/cron.daily下面,也就是说logrotate会每天自动执行一次。

也可以手动执行,命令如下:logrotate -f /etc/logrotate.d/dispatcher。

3 Tomcat节点配置

3.1 配置log4j

配置log4j,以便将日志传输到日志服务器。

编辑log4j的配置文件log4j.properties,添加如下内容(如果第一行的rootLogger已经配置的话,合并即可):

log4j.rootLogger=debug, SYSLOG

log4j.appender.SYSLOG=org.apache.log4j.net.SyslogAppender

log4j.appender.SYSLOG.syslogHost=192.168.0.1

log4j.appender.syslog.Threshold=DEBUG

log4j.appender.SYSLOG.layout=org.apache.log4j.PatternLayout

log4j.appender.SYSLOG.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [ %p ] %m [ %l ] %n

log4j.appender.SYSLOG.Header=true

log4j.appender.SYSLOG.Facility=local2

注意:

1. log4j.appender.SYSLOG.syslogHost需要配置为中央日志服务器的IP地址或域名;

2. log4j.appender.SYSLOG.Facility需要配置为local2,与中央日志服务器中配置的rsyslog一致。

3.2 配置rsyslog将所有日志都传输到日志服务器

说明:本步骤不是必须要做的,根据实际情况配置即可。

编辑/etc/rsyslog.conf,添加如下一行:

*.* @192.168.0.1

即可将所有日志通过UDP协议输出到日志服务器。

备注:如果希望可靠传输,建议采用TCP协议传输,将上述一行改为:

*.* @@192.168.0.1

即可。

4 拓展

以上部分是采用rsyslog+logrotate进行日志集中保存和管理,除此之外,还可以使用MySQL+ loganalyzer对日志进行存储和Web图形化的分析、查看。

Tomcat集群配置日志服务器

时间: 2024-11-11 00:06:30

Tomcat集群配置日志服务器的相关文章

Apache + Tomcat集群配置详解 (1)

一.软件准备 Apache 2.2 : http://httpd.apache.org/download.cgi,下载msi安装程序,选择no ssl版本 Tomcat 6.0 : http://tomcat.apache.org/download-60.cgi,下载Tomcat 6.0.18 zip文件 注意:由于Apache和Tomcat项目与集群相关的模块均处于持续发展和优化过程中,因此笔者不保证本文配置方法对所有Apache和Tomcat版本均适用. 二.软件安装 把Apache安装为运

Apache + Tomcat集群配置详解

Apache + Tomcat集群配置详解 一.软件准备 Apache 2.2 : http://httpd.apache.org/download.cgi,下载msi安装程序,选择no ssl版本 Tomcat 6.0 : http://tomcat.apache.org/download-60.cgi,下载Tomcat 6.0.18 zip文件 注意:由于Apache和Tomcat项目与集群相关的模块均处于持续发展和优化过程中,因此笔者不保证本文配置方法对所有Apache和Tomcat版本均

nginx+tomcat集群配置(1)---根目录设定和多后端分发配置

前言: 对于javaer而言, nginx+tomcat集群配置, 已然成了web应用部署的主流. 大公司如此, 小公司亦然. 对于个人开发者而言, 资源有限, 往往多个web应用混部于一台服务器(云主机), 如何隔离访问这些服务资源? 彼此又不影响呢? nginx来为你排忧解难, ^_^. 本文将介绍tomcat的简单配置和部署, 以及nginx作为反向代理, 如何分流. 基础架构: 不成文的约定: 1). 一个tomcat容器部署一个webapp应用实例 2). url根目录访问webapp

Nginx+Memcached+Tomcat集群配置

1.   Nginx Nginx是通过将多个Web Server绑定到同一个IP地址下,以实现多个WebServer间的负载均衡,降低单个Web Server的负荷,以提高整体的性能与稳定性. 安装和配置Nginx的简单方式如下: 1)      下载并解压Nginx到本地目录:http://nginx.org/en/download.html 2)      对Nginx的配置主要是对它的配置文件/conf/nginx.conf的修改.如下链接是nginx.conf配置文件各个属性的详细说明:

Apache+Tomcat集群配置

本文Apache+Tomcat集群配置 基于最新的Apache和Tomcat,具体是2011年4月20日最新的Tomcat和Apache集群和负载均衡配置. 准备环境 Apache[下载地址] 企业框架源码 Apache是http服务器,我们利用其对Tomcat进行负载均衡.目前最新版本为2.2.17,下载地址为http://httpd.apache.org/download.cgi#apache22.如下图: 目前已经出现Apache2.3.11,但是为beta版本,所以没有使用. 下载后直接

转载 Tomcat集群配置学习篇-----分布式应用

Tomcat集群配置学习篇-----分布式应用 现目前基于javaWeb开发的应用系统已经比比皆是,尤其是电子商务网站,要想网站发展壮大,那么必然就得能够承受住庞大的网站访问量:大家知道如果服务器访问量过大,就会出现服应用务器崩溃的情况,这个时候怎么办,难道就只能去重启服务器吗?好,如果是一般的小型公益网站到也无所谓,但如果是比如像大型航空公司售票等电子商务网站,每天每小时都有大量的订单业务,如果这些售票系统一旦崩溃后,再去重启,这些时间和客户的损失就直接会影响到航空公司的利益,这些损失如何去避

Tomcat集群配置--负载均衡

Tomcat集群配置学习篇-----分布式应用 现目前基于javaWeb开发的应用系统已经比比皆是,尤其是电子商务网站,要想网站发展壮大,那么必然就得能够承受住庞大的网站访问量:大家知道如果服务器访问量过大,就会出现服应用务器崩溃的情况,这个时候怎么办,难道就只能去重启服务器吗?好,如果是一般的小型公益网站到也无所谓,但如果是比如像大型航空公司售票等电子商务网站,每天每小时都有大量的订单业务,如果这些售票系统一旦崩溃后,再去重启,这些时间和客户的损失就直接会影响到航空公司的利益,这些损失如何去避

nginx+tomcat集群配置(4)--rewrite规则和多应用根目录设定思路

前言: nginx中有一块很重要的概念, 就是rewrite规则. 它会对URL进行修改, 然后进行内部的重定向. rewrite授予了nginx更多的自由, 使得后级服务的接入更加地方便. 本文将简单讲述nginx的rewrite规则和原理, 同时讲解下如何借助rewrite实现单tomcat实例/多Web App服务 对应的多域名根目录访问. 案列目标: 首先来谈一下之前对于多Web App服务对应多域名根目录访问的方案. 注: 一个域名对应一个tomcat实例, 一个tomcat实例只包含

tomcat集群配置方案对比

Tomcat集群配置方案大体上可以分为两种配置方案:共享Session型与不同享Session型.当然,其中各有千秋,如果不共享需要上层需要有一定结构进行一致化路由.何谓一致化路由,简单来讲,就是你上次怎么走路,这次还是怎么走,实现的方式有很多种,例如直接按照nginx进行来源或者目的ip进行相应的hash,dns进行地域划分等等,只要能保证上一次和下一次踏入的是"同一条河流"即可. 另一方面,如果不共享需要有一定机制进行共享Session机制,此时共享一般分为两种,找个第三方存储Se