使用命令参数方式获取指定log4j配置文件

一般默认将log4j的配置文件放在项目中的src或者maven项目的resource文件夹下,程序可以直接读取到配置文件,并以配置文件的配置输入日志。

但是在将程序发布是,默认log4j的配置文件也要一同被打入jar包才可能被读取到,要想将log4j的配置文件放在jar包外可以通过以下的代码手动指定log4j配置文件的位置:

将以下代码放在main函数所在类中:

static {   
      DOMConfigurator.configure(System.getProperty("user.dir") + File.separator + "conf" + File.separator   
                        + "log4j.xml");   
         }  
static {  
        DOMConfigurator.configure(System.getProperty("user.dir") + File.separator + "conf" + File.separator  
                    + "log4j.xml");  
        }  

static {   
        PropertyConfigurator.configure(System.getProperty("user.dir") + File.separator + "conf" + File.separator   
                    + "log4j.properties");   
        }  
static {  
        PropertyConfigurator.configure(System.getProperty("user.dir") + File.separator + "conf" + File.separator  
                    + "log4j.properties");  
        }  

上述代码是log4j的配置文件放在jar包所在目录下的conf目录中。

以上代码的区别在于DOMConfigurator载入的是log4j.xml而PropertyConfigurator载入的是log4j.properties文件。

以上内容转自:http://free0007.iteye.com/blog/1577264

或者下面这种方式:

PropertyConfigurator.configure(Props.getString("log4"));

使用:

    private static Logger logger = Logger.getLogger(Transfer.class);
    PropertyConfigurator.configure(Props.getString("log4jforerror")); 
    logger.debug("这里记录debug级别的日志");
    logger.error("这里记录error级别的日志");

log4j.properties:

 ### 设置日志级别###
log4j.rootLogger = debug,stdout,D,E

### 输出信息到控制台 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n

### 输出DEBUG 级别以上的日志到=./logs/log.log ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
#log4j.appender.D.File = C:\\mysqltomongodb\\logs\\log.log
log4j.appender.D.File = /opt/facedatatransfer/logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 输出ERROR 级别以上的日志到=./logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
#log4j.appender.E.File =C:\\mysqltomongodb\\logs\\error.log
log4j.appender.E.File = /opt/facedatatransfer/logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR 
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 5,084评论 1 13
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,971评论 6 342
  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 5,030评论 0 6
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 腊月过去了一多半,农历新年越来越近。 去年B质问我的话,如同我眼前的墙壁上,指示九点四十分的钟表的指针,清晰可辨。...
    珠穆朗玛方阅读 276评论 1 7