子类化java.util.logging.Formatter不起作用

时间:2013-04-16 06:52:46

标签: java logging

我正在使用java.util.logging进行日志记录(我不想使用log4j或其他任何内容)。

这是我完整的私有logging.properties:

handlers= java.util.logging.FileHandler
.level= INFO
java.util.logging.FileHandler.pattern = my.log
java.util.logging.FileHandler.limit = 500000
java.util.logging.FileHandler.count = 40
java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter

这是我程序中的代码:

public static Logger log = Logger.getLogger(MyClass.class.getName());
// Is there anything else to be init'ed here? 
// I don't. I just start using log directly in the code.

log.severe("something");
log.info("something else");

由于这会在两行上给出每条日志消息,我试过这个

How do I get java logging output to appear on a single line?

完全在第一个回复中复制了LogFormatter类。

在logging.properties中更改了一行

java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter;

现在我的日志已经开始以XML格式出现了。我强烈认为FileHandler不喜欢我的com.mycomp.myproj.LogFormatter,因此默认为默认XMLFormatter。我如何弄清楚为什么FileHandler没有使用我的LogFormatter类?

5 个答案:

答案 0 :(得分:4)

  

如何弄清楚为什么FileHandler没有使用我的LogFormatter类?

在调试器中启动程序并逐步执行代码。在LogManager.getLogger()和/或LogManager.readConfiguration()

中设置断点

或者忘记java.util.logging并使用易于配置的logback这样的框架,并在出现问题时为您提供有用的错误消息。

答案 1 :(得分:4)

您可以在FileHandler实例上的代码本身中设置格式化程序。

import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;

// please change name of your own choice
Logger log = Logger.getLogger("CustomLogger"); 
log.setUseParentHandlers(false);
log.setLevel(Level.ALL);

FileHandler handler = new FileHandler("[log_file_location]");
handler.setFormatter(new CustomFormatter()); // set formatter
log.addHandler(handler);

log.info("test message");

handler.close(); // close the handler at some later point in your application.

CustomFormatter类定义如下。

import java.util.logging.Formatter;
import java.util.logging.LogRecord;

public class CustomFormatter extends Formatter {

    @Override
    public String format(LogRecord record) {
        StringBuffer buffer = new StringBuffer();
        buffer.append(record.getMessage());
        return buffer.toString();
    }

}

您可以在CustomFormatter中编码,以您想要的任何格式输出消息。希望这会有所帮助。

答案 2 :(得分:1)

好吧,这个也让我非常恼火,并且让我疯了,我正在无休止地检查拼写,正在谷歌搜索等 - 这就是我到这里的方式 - 我知道这是一年了,但你要踢自己。以下是我非常肯定你的答案。

对于:

java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter;

应该是:

java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter

放弃训练“;”。似乎需要将 完全 与我看到其他人抱怨他们有空白字符的类名相匹配 - 这就是我的问题所在。更好的错误消息会有所帮助。

干杯 - 马克

答案 3 :(得分:1)

com.mycomp.myproj.LogFormatter不在您的系统类路径中。

LogManager将执行以下调用以加载您的类:

Formatter getFormatterProperty(String name, Formatter defaultValue) {
        String val = getProperty(name);
        try {
            if (val != null) {
                Class<?> clz = ClassLoader.getSystemClassLoader().loadClass(val);
                return (Formatter) clz.newInstance();
            }
        } catch (Exception ex) {
            // We got one of a variety of exceptions in creating the
            // class or creating an instance.
            // Drop through.
        }
        // We got an exception.  Return the defaultValue.
        return defaultValue;
}

您需要确保您的类LogFormatter位于系统的类路径中。

答案 4 :(得分:0)

我发现,除非您通过配置设置格式,否则它不会应用格式器。我在JDK 11上进行了测试。

handlers= java.util.logging.FileHandler
.level= INFO
java.util.logging.FileHandler.pattern = my.log
java.util.logging.FileHandler.limit = 500000
java.util.logging.FileHandler.count = 40
java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter
com.mycomp.myproj.LogFormatter.format = %n

即添加最后一行com.mycomp.myproj.LogFormatter.format = %n