【问题标题】:How to specify Tomcat logs as home for log4j log file如何将 Tomcat 日志指定为 log4j 日志文件的主目录
【发布时间】:2012-06-10 18:19:59
【问题描述】:

我的 WAR 正在使用通过 WAR 内 classes/ 目录下的 log4j.properties 文件配置的 log4j FileAppender。

我已经这样配置了我的 log4j appender:

# Set the root logger to DEBUG.
log4j.rootLogger=DEBUG

# MonitorLog - used to log messages in the Monitor.log file.
log4j.appender.MonitorAppender=org.apache.log4j.FileAppender
log4j.appender.MonitorAppender.File=MonitorLog.log
log4j.appender.MonitorAppender.layout=org.apache.log4j.PatternLayout
log4j.appender.MonitorAppender.layout.ConversionPattern= %-4r [%t] %-5p %c %x - %m%n

# Use the MonitorAppender to log all messages.
log4j.logger.*=DEBUG,MonitorAppender

通过这种配置,我试图实现以下目标:

  • 所有 DEBUG 级别及更高级别的日志消息都会被记录(所以一切)
  • 我希望MonitorLog.log 文件位于Tomcat 的logs/ 目录下

这个配置是否实现了这些项目,如果没有,需要改变什么?

【问题讨论】:

    标签: java tomcat log4j


    【解决方案1】:

    如果你知道这个 WAR 只会部署到一个 tomcat,你可以利用系统属性catalina.base,它代表你的 tomcat 基础文件夹的根目录(还有一个cataline.home,但它们经常除非您在同一台机器上运行多个 tomcat 并且共享服务器库,否则相同,但我离题了)。

    所以更新如下:

    log4j.appender.MonitorAppender.File=${catalina.base}/logs/MonitorLog.log
    

    【讨论】:

    • 对于那些从 Eclipse 运行应用程序的人 - ${catalina.base} 变量将替换为 %WORKSPACE%\.metadata\.plugins\org.eclipse.wst.server.core\tmp1 其中%WORKSPACE% 是实际的工作区绝对路径。
    猜你喜欢
    • 1970-01-01
    • 2018-03-24
    • 2011-06-12
    • 2014-05-26
    • 1970-01-01
    • 2018-11-16
    • 2014-11-17
    • 1970-01-01
    • 2014-08-17
    相关资源
    最近更新 更多