如何让Tomcat的logging.properties识别我的Catalina变量?

时间:2013-05-02 13:53:20

标签: variables properties log4j tomcat7 catalina

我们在不同的服务器上安装了几个Tomcat 7个实例。我们有时会为不同的Tomcats(针对不同的客户)部署基本相同的应用程序,唯一的区别就是配置。为了标准化日志记录位置等,我们正在努力使应用程序“通用”,这样只需将war文件部署到Tomcat实例就会自动连接它,这样我们就不必记得更改应用程序了客户1,然后再次为客户2等。

无论如何,在每个Tomcat/conf文件夹中,我在catalina.properties文件的末尾添加了一些属性。例如:

# custom logging
log.base=c:/logs/tomcat/myapp
log.file=MYAPP.log

现在,在我的应用程序的 log4j.cfg文件中,我有:

log4j.appender.R.File=${log.base}/${log.file}

应用程序 myapp.cfg中,我有:

logfile=${log.file}

部署时效果很好。 Tomcat将所有内容放在除了 logging.properties文件中的内容之外。

该文件通常包含:

1catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
2localhost.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
3manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
4host-manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs

但我想更改${catalina.base}/logs以使用我自己的${log.base}变量。但Tomcat(或许log4j?)不承认这一点。相反,它实际上在Tomcat根文件夹中创建了名为“$ {log.base}”的目录。

我读到你可以在setenv.bat文件中声明自定义变量。我这样做了,但仍然没有用。

我该如何解决这个问题?

BTW,我正在使用Windows,Tomcat 7和Windows服务安装(使用GUI)。

由于

1 个答案:

答案 0 :(得分:3)

在setenv.bat中设置环境变量JAVA_OPTS。通过这种方式,您可以提供java VM参数。以下适用于Linux中的setenv.sh:

export JAVA_OPTS =“ - Dlog.base = / logs / tomcat /”

现在您应该能够在logging.properties

中使用$ {log.base}