我们在不同的服务器上安装了几个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)。
由于
答案 0 :(得分:3)
在setenv.bat中设置环境变量JAVA_OPTS。通过这种方式,您可以提供java VM参数。以下适用于Linux中的setenv.sh:
export JAVA_OPTS =“ - Dlog.base = / logs / tomcat /”
现在您应该能够在logging.properties
中使用$ {log.base}