2

我们Tomcat 7在不同的服务器上安装了几个实例。我们有时将基本相同的应用程序部署到不同的 Tomcat(针对不同的客户),唯一的区别是配置。为了标准化日志记录位置等,我们正在尝试使应用程序“通用”,以便简单地将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文件中声明自定义变量。我这样做了,但它仍然没有用。

我怎样才能解决这个问题?

顺便说一句,我正在使用 Windows、Tomcat 7 和 Windows 服务安装(使用 GUI)。

谢谢

4

1 回答 1

5

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

导出 JAVA_OPTS="-Dlog.base=/logs/tomcat/"

现在您应该可以在 logging.properties 中使用 ${log.base}

于 2013-05-02T21:52:32.783 回答