设为首页 收藏本站
查看: 431|回复: 0

[经验分享] Tomcat集群配置日志服务器

[复制链接]

尚未签到

发表于 2018-12-3 10:31:11 | 显示全部楼层 |阅读模式
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图形化的分析、查看。




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-642704-1-1.html 上篇帖子: Tomcat中配置MySQL连接池 下篇帖子: 【tomcat】启动报错
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表