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

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

作者: 我可能是个假开发 | 来源:发表于2018-10-27 10:36 被阅读67次

一般默认将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

相关文章

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

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

  • springboot 使用外部配置文件

    使用外部配置文件有两种方法方式一:在启动类上加注解,更改属性源为jvm参数获取 启动参数添加 方式二:直接指定外部...

  • nginx-5 命令行参数

    nginx支持以下命令行参数 -? | -h 获得帮助 -c file 使用指定配置文件,而不是默认配置文件 -g...

  • uboot Makefile解析(二)

    make参数传递 Uboot的编译需要找到并配置所需的配置文件,make命令要使用到的参数都需要从这些配置文件获取...

  • Nginx使用

    Nginx [toc] nginx命令 参数 Nginx启动 通过指定配置文件启动 配置文件语法检查 Nginx配...

  • 2.4 cleos-commands-contracts

    合约相关命令 1. 获取合约 code 获取指定合约账户的代码和 ABI。使用方式 cleos get code ...

  • requirejs

    使用 r.js 命令行参数可以与构建配置文件属性互换您可以在命令行上指定选项:node r.js -o baseU...

  • mongodb.conf配置文件详解

    启动MongoDB有2种方式,一是直接指定配置参数,二是指定配置文件。这里介绍的是配置文件,启动方式如下: 配置参...

  • Java cmd Runtime.getRuntime().ex

    一 使用方式 基本操作 执行多条命令 执行脚本 脚本b.bat 内容如下 启动指定软件 启动指定软件并传递参数 需...

  • Elasticsearch 指定节点存放位置

    指定节点类型 方式 方式一 启动加入 节点类型 参数 方式二 配置文件 修改 elasticsearch.yml ...

网友评论

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

      本文链接:https://www.haomeiwen.com/subject/eoortqtx.html