7

我有一个使用外部库的 java 程序。主程序用于log4j记录其消息,库使用java.util.logging.

我的问题是来自外部库和主程序的日志消息混合在控制台中。

我想将所有日志消息从外部库重定向到一个文件。logging.properties我试图用一个文件来做到这一点:

handlers= java.util.logging.FileHandler
.level= INFO
java.util.logging.FileHandler.pattern = foo.log
java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter

该文件初始化为:

System.setProperty("java.util.logging.config.file", "logging.properties");

不幸的是,来自外部库的日志消息不断出现在控制台中。我应该使用类似的东西slf4j来拦截来自的日志消息java.util.logging吗?

感谢您的时间。

4

1 回答 1

13

这是我的一个程序中的一些代码。这也会自动旋转。配置类是我自己的,从属性文件中读取。您可以将其替换为您自己的值。

Logger rootLogger = Logger.getLogger(""); 
logHandler = new FileHandler(config.getLogFile(), 
                             config.getLogRotateSize()*1024*1024, 
                             config.getLogRotateCount(), false); 
logHandler.setFormatter(new SimpleFormatter()); 
logHandler.setLevel(Level.INFO); 
rootLogger.removeHandler(rootLogger.getHandlers()[0]); 
rootLogger.setLevel(Level.INFO); 
rootLogger.addHandler(logHandler); 

请注意,这是针对独立程序的。任何应用服务器都有它自己的日志配置工具。如果需要动态调试模式,该程序还可以动态更改格式化程序和级别。

于 2010-11-27T17:04:46.723 回答