【发布时间】:2012-05-18 22:14:41
【问题描述】:
我有一个 Google Web Toolkit (GWT) - 我以三种不同模式运行的应用程序:
- 部署在 Tomcat 上
- 托管模式
- Junit 测试
如何配置 log4j.properties 以使每种模式都能正确记录?
如果我使用 ${catalina.base},我无法在托管模式和 Junit 测试中使用它,如果我只使用相对的 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
【问题讨论】:
-
我不确定它是否适用于您的所有情况,但您可以尝试登录到标准输出。 Tomcat 将在它的日志目录中的日志文件中捕获它。你没有说服务器在托管模式下是什么,但这也可能在那里工作。我相信 JUnit 也会捕获标准输出。
-
是的,我已经另外登录到标准输出,但我不想在启动程序时遇到所有这些异常。
-
什么是“所有这些例外”?
-
@GreyBeardedGeek Exeptions like
log4j:ERROR setFile(null,true) call failed. java.io.FileNotFoundException: /logs/user_sessions.html (Datei oder Verzeichnis nicht gefunden) at java.io.FileOutputStream.open(Native Method) at java.io.FileOutputStream.<init>...(每个 Appender 一个) -
您是否只需要找到一种方法来为托管和 junit 模式设置 catalina.base 系统属性?我对 GWT 了解不多,但我相信这是可能的。