繁体   English   中英

java.util.logging不会记录到文件

[英]java.util.logging won't log to file

我正在努力使java.util.logging记录到文件,而不是仅记录到Eclipse中的控制台。

public class TestDefaultConfiguration {

    private static Logger logger = Logger.getLogger(TestDefaultConfiguration.class.getName());

    public static void main(String[] args) {
        System.out.println("-- main method starts --");
        logger.info("an info msg");
        logger.warning("a warning msg!");
        logger.severe("a severe msg!");
    }
}

这里是属性:

C:\Program Files\Java\jre1.8.0_152\lib\logging.properties

我将默认属性文件编辑为:

.level= INFO
# default file output is in user's home directory.
#java.util.logging.FileHandler.pattern = %h/java%u.log
java.util.logging.FileHandler.pattern = C:/temp/test/MyLogFile2.log

java.util.logging.FileHandler.limit = 50000
java.util.logging.FileHandler.count = 1
#java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter
java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter

当我调试测试类时,我可以在logger.manager.props看到这些属性被拾取。 到现在为止还挺好。

为什么在C:/temp/test/MyLogFile2.log没有创建日志文件?

不确定是否应在Eclipse配置VM参数中添加:

-Djava.util.logging.config.file="C:/Program Files/Java/jre1.8.0_152/lib/logging.properties"

但是,如果我这样做,那不会有任何改变。

有什么建议么?

在logging.properties中,您没有显示将处理程序附加到记录器的部分。 这在文件中作为注释进行了说明

# "handlers" specifies a comma separated list of log Handler 
# classes.  These handlers will be installed during VM startup.
# Note that these classes must be on the system classpath.
# By default we only configure a ConsoleHandler, which will only
# show messages at the INFO and above levels.
handlers= java.util.logging.ConsoleHandler

# To also add the FileHandler, use the following line instead.
#handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler

使用记录器调试代码来查看处理程序是否已附加到根记录器。

将以下行添加到您的属性文件:

handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM