我的Log4J级别在哪里设置?

时间:2015-04-16 17:27:18

标签: java logging log4j

以下是我的Log4J代码:

 import org.apache.logging.log4j.LogManager;
 import org.apache.logging.log4j.Logger;
 import org.apache.logging.log4j.Level;



public class HelloWorldLog4J {

 private static final Logger logger = LogManager.getLogger("HelloWorld");


  //private static Logger logger = Logger.getLogger(HelloWorldLog4J.class);

    public static void main(String[] args) {

        System.out.println("pre_loggerDOTinfo");
        System.out.println();
        //logger.setLevel(Level.INFO);   //used to be.. 

        logger.info("Hello, this is an INFO message");
        logger.warn("Hello, this is an WARN  message");
        logger.fatal("Hello, this is an FATAL  message");
        logger.fatal("Hello, this is an FATAL  message ALSO, #2");
        logger.fatal("Hello, this is an FATAL  message ALSO, #3");
        logger.fatal("Hello, this is an FATAL  message ALSO, #4");
        logger.debug("Hello, this is an FATAL  message");

        logger.info("Hello, this is an INFO message");
        logger.info("Hello, this is an INFO message");
        System.out.println();
        System.out.println("post_loggerDOTinfo");

    }


}

当我运行它时,它会起作用,并输出以下内容:

  

pre_loggerDOTinfo

     

12:21:20.761 [main]致命的HelloWorld - 你好,这是致命的   消息12:21:20.763 [主要]致命的HelloWorld - 你好,这是致命的   消息也是,#2

     

12:21:20.764 [main]致命的HelloWorld - 你好,这是致命的   消息另外,#3

     

12:21:20.765 [main]致命的HelloWorld - 您好,这是致命的   消息也是,#4   11

     

post_loggerDOTinfo

这很好,但我希望它输出所有的日志消息,而不仅仅是FATAL消息。

所以我尝试的是在与Java文件相同的目录中创建log4j.properties文件。它在这里:

log4j.rootLogger=DEBUG,console,file
log4j.appender.console=DEBUG,org.apache.log4j.ConsoleAppender
log4j.appender.file=INFO,org.apache.log4j.RollingFileAppender



log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.conversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %-5p - %m%n

log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=log4j.log
log4j.appender.FILE.MaxFileSize=512KB
log4j.appender.FILE.MaxBackupIndex=3
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %-5p - %m%n

但是当我重新运行HelloWorldLog4J类时,我得到了同样的东西(好像它在其他地方找到了一个属性文件)。

我认为我需要在HelloWorldLog4J类中设置log4j属性文件?我确实试过这个,使用以下行:

logger.setLevel(Level.INFO); 

但是,这不起作用 - 我收到此错误:

HelloWorldLog4J.java:20: error: cannot find symbol
        logger.setLevel(Level.INFO);   //used to be..
              ^
  symbol:   method setLevel(Level)
  location: variable logger of type Logger
1 error

C:\Users\Adel\JavaCoding>

任何提示表示赞赏

1 个答案:

答案 0 :(得分:1)

您可能正在使用自定义log4.properties文件导入任何库,或者您的属性文件在类路径中不可见

有关如何设置的讨论,请参阅此处 https://logging.apache.org/log4j/1.2/manual.html#defaultInit

您可以尝试在开始上课时设置log4j.configuration属性。

-Dlog4j.configuration="PATH_TO_YOUR_FILE"

看看现在是否已经拿起