caoweichen520
2018-05-29 06:47
采纳率: 80%
浏览 1.4k
已采纳

Tomcat下部署两个war包项目 使用Log4j 接管 catalina.out 日志文件生成方式

我在一个tomcat里面部署了两个web项目 启动成功也能跑起来 一切OK ,但是log4j日志总是
在一个文件里打印 ,它不按天或者小时打印,这就出现一个问题 ,如果文件过大,工具是打不开的
,查找bug也很困难,所以请求大神们怎样可以让他按天打印,log4j配置文件应该怎样配置,
网上有很多是起动一个项目的配置,没有两个的.
跪求详细的教程

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • m0_37468953 2018-05-29 09:28
    已采纳

    由于tomcat catalina.out日志不会自动分割,

    一、日志分割所需包在附近中

    1、 压缩包中有三个jar包:

    log4j-1.2.16.jar 
    
    tomcat-juli-adapters.jar
    
    tomcat-juli.jar
    

    说明:如果不是tomcat7版本,请去官网下载对应版本的tomcat-juli.jar,tomcat-juli-adapters.jar类包,

         下载地址: http://www.apache.org/dist/tomcat   在对应版本中的bin/extras 路径下
    

    二、修改相关配置文件

    1、 修改${catalina.home}/conf/context.xml

    修改:为只有这样才能完全的把tomcat的stdout给接管过来。

    2、 复制log4j-1.2.16.jar和tomcat-juli-adapters.jar 到tomcat的lib下

    3、 复制tomcat-juli.jar到${catalina.home}/bin下,在该目录会存在该文件,覆盖即可

    4、 建立log4j.properties,并把其放到到tomcat的/lib下

    Log4j.properties的内容如下:相关参数根据需要可以相应修改

    log4j.rootLogger=INFO, CATALINA

    Define all the appenders

    log4j.appender.CATALINA=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.CATALINA.File=/home/richmail/logs/tomcat/catalina.log

    log4j.appender.CATALINA.Append=true

    log4j.appender.CATALINA.Encoding=UTF-8

    Roll-over the log once per day

    log4j.appender.CATALINA.DatePattern='.'yyyy-MM-dd

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

    log4j.appender.CATALINA.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

    log4j.appender.LOCALHOST=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.LOCALHOST.File=/home/richmail/logs/tomcat/localhost.log

    log4j.appender.LOCALHOST.Append=true

    log4j.appender.LOCALHOST.Encoding=UTF-8

    log4j.appender.LOCALHOST.DatePattern='.'yyyy-MM-dd

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

    log4j.appender.LOCALHOST.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

    log4j.appender.MANAGER=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.MANAGER.File=/home/richmail/logs/tomcat/manager.log

    log4j.appender.MANAGER.Append=true

    log4j.appender.MANAGER.Encoding=UTF-8

    log4j.appender.MANAGER.DatePattern='.'yyyy-MM-dd

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

    log4j.appender.MANAGER.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

    log4j.appender.HOST-MANAGER=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.HOST-MANAGER.File=/home/richmail/logs/tomcat/host-manager.log

    log4j.appender.HOST-MANAGER.Append=true

    log4j.appender.HOST-MANAGER.Encoding=UTF-8

    log4j.appender.HOST-MANAGER.DatePattern='.'yyyy-MM-dd

    log4j.appender.HOST-MANAGER.layout = org.apache.log4j.PatternLayout

    log4j.appender.HOST-MANAGER.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

    log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender

    log4j.appender.CONSOLE.Encoding=UTF-8

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

    log4j.appender.CONSOLE.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

    Configure which loggers log to which appenders

    log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost]=INFO, LOCALHOST

    log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager]=\

    INFO, MANAGER

    log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager]=\

    INFO, HOST-MANAGER

    1. 修改bin/catalina.sh

      a. 屏蔽或删除如下内容:

      (1) if [ -z "$CATALINA_OUT" ] ; then

            CATALINA_OUT=$CATALINA_BASE/logs/catalina.out
      
          fi
      

      (2) touch "$CATALINA_OUT"

      (3) >> "$CATALINA_OUT" 2>&1 "&" (两处)

      b. 修改org.apache.catalina.startup.Bootstrap "$@" start \ 内容 (两处)

      修改为:org.apache.catalina.startup.Bootstrap "$@" start & \

    2. 修改conf/server.xml中localhost_access_log日志路径

    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/home/richmail/logs/tomcat "

               prefix="localhost_access_log." suffix=".txt"
    
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
    
    1. 删除 conf/logging.properties 文件

    2. 启动tomcat。

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • caoweichen520 2018-05-29 06:49

    这是在小黑窗里运行的,是直接拿tomcat起动的

    评论
    解决 无用
    打赏 举报
  • 小小驴子 2018-05-29 13:45

    log file

    log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.D.File =../logs/IvaDubboWeb-info.log
    log4j.appender.D.Append = true
    log4j.appender.D.Threshold = INFO
    log4j.appender.D.layout = org.apache.log4j.PatternLayout
    log4j.appender.D.layout.ConversionPattern = [%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n

    评论
    解决 无用
    打赏 举报
  • ml1985kklt 2018-06-01 06:20

    两个war里的log4j,单独配置一下

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题