spring+log4j配置文件无法读取系统环境变量问题

在spring-web项目中,log4j的配置位于log4j.properties文件中,其中日志路径使用环境变量配置(配置在/etc/profile)。但是,实际运行该路径没有生效。如果直接写路径,是没有问题的。

log4j.appender.logFile.File = ${BYTREES_LOG4J_FILE}

原因分析:

log4j采用System.getProperty读取系统属性,而System.getenv才是读取环境变量,可以参考org.apache.log4j.helpers.OptionConverter

解决方案:

创建一个Listener,在spring启动前,把需要将环境变量,转化成系统属性。

Listener创建:

package com.bytrees.utils;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

public class Log4jListener implements ServletContextListener  {

	@Override
	public void contextInitialized(ServletContextEvent sce) {
		// TODO Auto-generated method stub
		String log4jLogFile = System.getenv("BYTREES_LOG4J_FILE");
		if (log4jLogFile != null) {
			System.setProperty("BYTREES_LOG4J_FILE", log4jLogFile);
		}
	}

	@Override
	public void contextDestroyed(ServletContextEvent sce) {
		// TODO Auto-generated method stub
		System.getProperties().remove("BYTREES_LOG4J_FILE");
	}
    
}

配置web.xml,注意这个必须在ContextLoaderListener之前

<listener>  
    <listener-class>com.bytrees.utils.Log4jListener</listener-class>  
</listener>

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值