zoukankan      html  css  js  c++  java
  • 使用命令参数方式指定log4j配置文件

    http://blog.csdn.net/changong28/article/details/39717209

    *******************************************

    一般而言使用log4j时,只要把log4j.properties放置到类路劲下就可以了,这是log4j会自动从类路径下去寻找然后初始化,然手好多时候,我需要将log4j.properties的文件放置到自己需要的地方,一种是需要是log4j配置对象初始化,例如:

    1. import com.foo.Bar;  
    2.   
    3. import org.apache.log4j.Logger;  
    4. import org.apache.log4j.PropertyConfigurator;  
    5.   
    6. public class MyApp {  
    7.   
    8.   static Logger logger = Logger.getLogger(MyApp.class.getName());  
    9.   
    10.   public static void main(String[] args) {  
    11.     // 配置文件初始化  
    12.     PropertyConfigurator.configure(args[0]);  
    13.     logger.info("Entering application.");  
    14.     Bar bar = new Bar();  
    15.     bar.doIt();  
    16.     logger.info("Exiting application.");  
    17.   }  
    18. }  

    上述args[0]传入log4j配置文件路径。

    但如上述这样初始化的话感觉有点繁琐,有没有其他更简洁的办法吗?答案是有,因为一般一个Java工程一个log4j 配置文件就够了,所以我们在运行java主程序的时候通过附加参数可以实现该功能,如下:

    1. -Dlog4j.configuration=file:{path to file}  

    eg:   -Dlog4j.configuration=file:./log4j.properties

    上述中file:前缀是一定要的,千万别忘了加上,{path to file}当然是log4j配置文件了,完整例子如下:

    1. set APP_CLASSPATH=.;%APP_HOME%/lib/*  
    2. set APP_PARAMS=-Dapp.path.home="%APP_HOME%" -Dlog4j.configuration="file:%APP_HOME%configlog4j.properties"  
    3. "%JAVA_HOME%injava" %APP_PARAMS% -cp "%APP_CLASSPATH%" "com.changong28.maven.HelloWorld"  

    参考:http://logging.apache.org/log4j/1.2/manual.html

  • 相关阅读:
    Teleport垃圾代码tppabs的清理
    MVC Action 返回类型[转]
    Jquery 技巧收集..慢慢添加吧..
    下拉框根据输入文字自动选择和输入提示
    Repeater中,寻找TextBox,Lable.等的值
    纯CSS列自适应高
    一些基本的项目开发规范.慢慢总结中..
    MSSQL触发器
    IIS错误集,以及解决方法!
    C#创建Windows服务
  • 原文地址:https://www.cnblogs.com/zhao1949/p/6003086.html
Copyright © 2011-2022 走看看