您的位置:首页 > 运维架构 > Tomcat

在Tomcat 与weblogic 中的 日志(log4j) 配置系列三(log文件的存放路径)

2013-08-06 18:44 483 查看

前言

前面一直在说,如何读取到log4j 的配置文件 log4j.properties。

接下来的探讨的是: log4j 里配置产生的log 文件的路径如何设置。

tomcat 还好。拿复杂点的 weblogic 来说,因为不解压war 档,这个路径该如何设置。

在上一篇

在Tomcat 与weblogic 中的 日志(log4j) 配置系列二(weblogic 应用程序使用log4j)

中也提到了,如果没有配置路径, logfile.log默认也会放到 base_domain目录下。

当然你配置一个绝对路径,但是,这绝对是不被推荐的。

可以通过 ${param} /logfile.log 设置相对路径。



java 获取系统变量(环境变量和设置变量)

这一篇中, 有提到 log4j 的配置可以配置系统变量 。

基于此, 配置 log4j 的相对路径的方法就有2种了。

方法一: 通过 servlet 初始化init() 方法中设置log_dir的系统变量

这个系统的变量名可以随便取, 只需要保证在 init 方法中和log4j 中使用的变量名一致就可以了。

System.setProperty("log_dir", "C:\\Oracle\\Middleware\\user_projects\\domains\\base_domain\\logs");


当然, 这里配置的log_dir 不能使用绝对路径。

可以通过 getServletContext().getRealPath("/"); 等这样一些方法定位到一些相对路径。

当然这种配置方式,也可以直接设置配置文件中的 log4j.appender.logfile.File

String logFile = spath+"/" + ps.getProperty("log4j.appender.logfile.File");
ps.setProperty("log4j.appender.logfile.File",logFile);
PropertyConfigurator.configure(ps);


方法二: 通过服务器环境变量

应对方法一的不便, 还需要通过API获取一些路径。

是否可以直接使用web 服务器里面的已经初始好的系统变量呢? 当然是可以。

在windows 环境下, 在weblogic 的 .cmd 文件中有
set JAVA_PROPERTIES=-Dplatform.home=%WL_HOME% -Dwls.home=%WLS_HOME% -Dweblogic.home=%WLS_HOME%

-D 这样的设置的变量, 是会被写入到系统变量的。

所以以上例子直接使用 ${platform.home} ; ${wls.home} 都可以。

在tomcat 中, 有类似${catalina.home} 等 。。。


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: