4

我有一个 Google Web Toolkit (GWT) - 我以三种不同模式运行的应用程序:

  1. 部署在 Tomcat 上
  2. 托管模式
  3. Junit 测试

如何配置 log4j.properties 以便正确记录每种模式?

如果我使用${catalina.base}它,我将无法在托管模式和 Junit 测试中使用它,并且如果我只使用 relative logs/myapplication.log,它将无法与 Tomcat 一起使用,因为我会得到:

java.io.FileNotFoundException: log/myapplication.log (Keine Berechtigung)

如果可以相对于应用程序路径指定日志目录,我不介意将日志放在 webapps/myapplication/logs 中,但如果日志文件只是在 /var/log/tomcat7/... 或其他一些日志文件夹。

目前我的 log4j.properties 包含以下文件记录条目:

log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=${catalina.base}/logs/myapplication.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%c %C %d{ABSOLUTE} %-5p %C{1}: %m%n
log4j.appender.file.threshold=DEBUG
log4j.appender.file.Append=false
4

1 回答 1

3

1.部署在Tomcat上

我登录到 ${catalina.home},但您的配置看起来仍然不错。我在 Windows 上本地运行我的配置,当我启动服务器时没有看到任何关于找不到该文件夹​​的错误。如果您想指向 Windows 上的某个位置,请尝试在运行配置中将以下内容添加到您的参数中:

-Dcatalina.base="C:\somefolder\" -Dcatalina.home="C:\somefolder\"

2.托管模式

在这种模式下,您在 IDE 中本地运行它。因此,您不需要记录到文件。在这种情况下,将附加程序添加stdout到您的 log4j.properties

log4j.rootLogger=DEBUG, stdout, A

这样,您将在 IDE 的控制台中看到日志消息

3. JUnit 测试

使用单独的日志配置文件进行测试(这是标准做法)。这使您可以更好地控制日志级别,而不会影响您的生产日志级别。

于 2012-08-29T15:02:11.050 回答