由于项目中 Tomcat 日志越来越大,对于日志查找非常不方便,所以经过一番调查可以通过log4j来托管 Tomcat 日志的方式,实现Tomcat日志切片。这里只说明怎么是log4j托管Tomcat日志,至于怎么切分就不做说明,可以log4j.properties文件的配置来实现。

  1. 准备文件:
    1. tomcat-juli.jar,tomcat-juli-adapters.jar。下载地址(tomcat官网):https://tomcat.apache.org/download-70.cgi,或者:http://archive.apache.org/dist/tomcat/tomcat-7/v7.0.63/bin/extras/(改下对应版本号即可)
    2. log4j-1.2.16.jar(项目中用到的log4j依赖包),log4j.properties(自己写的log4j配置文件)
    3. 下载界面:
  2. 将 tomcat-juli.jar 放到 Tomcat/bin 目录中,替换原来的文件
  3. 将 tomcat-juli-adapters.jar,log4j-1.2.16.jar,log4j.properties 放到 Tomcat/lib 目录下
  4. 删除或者重命名 Tomcat/conf 目录下的 logging.properties 文件
  5. 修改 Tomcat/conf/context.xml文件,将<Context>改为<Context swallowOutput="true">。(增加swallowOutput="true" 的属性配置,只有这样才能完全的把tomcat的stdout给接管过来)
  6. 重启 Tomcat,托管配置完成。

  附上一个简单的 log4j.properties 配置文件示例:如下代码,本人在测试的时候,如果把 Console 放开的话,会导致输出两份重复的log信息,所以这里就注释掉了

  1.  
  2. log4j.rootLogger=info,ROLLING_FILE
  3.  
  4. #Console
  5. #log4j.appender.Console=org.apache.log4j.ConsoleAppender
  6. #log4j.appender.Threshold=WARN
  7. #log4j.appender.CONSOLE.Target=System.out
  8. #log4j.appender.Console.layout=org.apache.log4j.PatternLayout
  9. #log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
  10.  
  11. #file
  12. log4j.appender.ROLLING_FILE = org.apache.log4j.DailyRollingFileAppender
  13. log4j.appender.ROLLING_FILE.File = ${catalina.home}/logs/smartbear.log
  14. log4j.appender.ROLLING_FILE.DatePattern = '.'yyyy-MM-dd
  15. log4j.appender.ROLLING_FILE.Append = true
  16. log4j.appender.ROLLING_FILE.Threshold = INFO
  17. log4j.appender.ROLLING_FILE.layout = org.apache.log4j.PatternLayout
  18. log4j.appender.ROLLING_FILE.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n

log4j托管tomcat日志的更多相关文章

  1. Tomcat 日志清除(含扩展AccessLogValve)

    1.tomcat的访问日志AccessLogs定期或者定量删除 a 开启tomcat访问日志 编辑${catalina}/conf/server.xml文件.注:${catalina}是tomcat的 ...

  2. Tomcat日志与Log4j日志

    一:日志作用 更好的调试,分析问题. 普通的一个请求处理10秒钟,日志10秒钟,总共就得20秒钟,这肯定是不行的,因为日志严重影响了性能.所以,我们就有必要了解日志的实现方式,以及它是如何降低IO的时 ...

  3. Tomcat日志、项目中的log4j日志、e.printStackTrace()——我的日志最后到底跑哪去了?

    1.Tomcat自带日志功能,即时你的项目中有log4j也不会影响到Tomcat自己记录日志. 2.你的项目中的log4j中的日志指定打印到什么地方(控制台或者文件),便会打印到什么地方,和Tomat ...

  4. Tomcat日志、项目中的log4j日志、控制台——我的日志最后到底跑哪去了?

    1.Tomcat自带日志功能,即时你的项目中有log4j也不会影响到Tomcat自己记录日志. 2.你的项目中的log4j中的日志指定打印到什么地方(控制台或者文件),便会打印到什么地方,和Tomat ...

  5. Log4j 输出的日志中时间比系统时间少了8小时的解决方法,log4j日志文件重复输出

    1. 第一个问题:时间少了8小时 Log4j 输出的日志中,时间比系统时间少了8小时,但是 eclipse 控制台输出的日志的时间却是对的. log4j配置如下: #all logger output ...

  6. Tomcat日志问题

    [Tomcat日志设定][tomcat控制台日志][log4j日志] 1 Tomcat 日志概述 Tomcat 日志信息分 为 两 类 : 一是运行中的日志,它主要 记录 运行的一些信息,尤其是一些异 ...

  7. 切割TOMCAT日志

    tomcat的catalina.out日志如果不做操作的话,日志就会日积月累的不断增加.我刚入职的时候发现某台服务器的硬盘报警,排查之后我慌了,一个tomcat的日志居然有100G,这怎么可以,在网上 ...

  8. tomcat 日志 按天自动分割 设定时任务定时清除

    一.日志分割所需jar包 1.下载tomcat   apache-tomcat-7.0.79.tar.gz 地址:http://www.apache.org/dist/tomcat/tomcat-7/ ...

  9. Tomcat日志设定

    1    Tomcat 日志概述 Tomcat 日志信息分 为 两 类 : 一.是运行中的日志,它主要 记录 运行的一些信息,尤其是一些异常 错误 日志信息 .二.是 访问 日志信息,它 记录 的 访 ...

随机推荐

  1. Linux下Mycat安装配置和使用

    mysql安装下载mysql[百度云]tar -zxvf mysql-5.6.32-linux-glibc2.5-x86_64.tar.gz 解压把mysql文件夹移动到 /usr/local/ 下m ...

  2. python web开发——django学习(一)第一个连接mysql数据库django网站运行成功

    1.新建一个项目 2.新建一些文件夹方便管理 3.新建一个项目叫message  4.连接数据库 python web开发Django连接mysql 5.在数据库里自动生成django的表  6.运行 ...

  3. Sound (audio file) player in java - working source code example

    转载自:http://ganeshtiwaridotcomdotnp.blogspot.com/2011/12/sound-audio-file-player-in-java-working.html ...

  4. Apache2.4+PHP7.2配置站点访问变下载

    问题描述:Apache正常工作,php-fpm正常工作,访问网址就变下载,显然是站点无法正常解析php造成的.php-fpm与apache的通信出现了问题. 解决方案: 如果php-fpm使用的是TC ...

  5. [转]Xmind 8 pro 软件破解版

    链接地址:https://blog.csdn.net/qq_16093323/article/details/80967867 作者博客:http://www.carrotchou.blog/

  6. H5 video安卓默认点击不能全屏播放解决办法

    调用方法: autoFullScrenn(obj) 还有一篇: 使用MediaElement.js构建个性的HTML5音频和视频播放器 var fullscreen = function(elem) ...

  7. CF1223D Sequence Sorting

    思路: 首先把数组离散化,然后观察可以发现,在最优解中最终没有被移动过的那些数字一定是连续的,那么找到最长的连续的数字长度即可. 实现: #include <bits/stdc++.h> ...

  8. css 修改placeholder样式

    input::-webkit-input-placeholder{ color:red; } input::-moz-placeholder{ /* Mozilla Firefox 19+ */ co ...

  9. Django时区导致的datetime时间比较报错

    我们使用python 的datetime模块比较Django数据库Datetime字段的时候,可能会出现报错: TypeError: can't compare offset-naive and of ...

  10. social engineering toolkit

    1. freebuf介绍 http://www.freebuf.com/sectool/73409.html 2. github https://github.com/trustedsec/socia ...