从日志文件中解析Log4j布局

时间:2011-07-08 11:48:47

标签: java logging log4j apache-chainsaw

是否有任何开源工具可以将 Apache Log4j 1.2.x 的所有Layout implementations读入有意义的内容(例如,Log4j自己的LogEvent个对象)?到目前为止,我还没有找到可以做到这一点的应用程序(包括Chainsaw)。

我正在寻找直接的东西,从文本文件(普通或XML)转换为Java对象,给定文件名和模式参数(例如,PatternLayout中的格式模式)。如果它有一个清晰的API,可以很容易地集成到应用程序中,甚至更好,但这不是必需的。

3 个答案:

答案 0 :(得分:9)

我正在开发开源日志查看器OtrosLogViewer。您可以在应用程序中将其用作库。看一下这个example

//Define log4j properties
Properties p = new Properties();
p.put("type", "log4j");
p.put("pattern", "TIMESTAMP LEVEL [THREAD]  MESSAGE");
p.put("dateFormat", "yyyy-MM-dd HH:mm:ss,SSS");
Log4jPatternMultilineLogParser logParser = new Log4jPatternMultilineLogParser();    
LogImporterUsingParser importerUsingParser = new LogImporterUsingParser(logParser);
importerUsingParser.init(p);

//
ParsingContext context = new ParsingContext();

//Create log collector, it capture all parsed log events
ProxyLogDataCollector dataCollector = new ProxyLogDataCollector();

//Create input stream from file
InputStream in = new FileInputStream("log4j/log4j.txt");

//parse log file
importerUsingParser.importLogs(in, dataCollector, context);

答案 1 :(得分:9)

这是Chainsaw用于将patternlayouts转换为有用的代码的代码,仅使用log4j API。对于Chainsaw的最新开发人员快照,它用于直接从log4j xml或属性文件fileappender条目构建Chainsaw配置。

使用PatternParser#parse填充的转换器和字段来执行您想要的操作。 PatternParser类包含在log4j'adts'伴侣中。

来自http://svn.apache.org/repos/asf/logging/chainsaw/trunk/src/main/java/org/apache/log4j/chainsaw/LogFilePatternLayoutBuilder.java

public static String getLogFormatFromPatternLayout(String patternLayout) {
    String input = OptionConverter.convertSpecialChars(patternLayout);
    List converters = new ArrayList();
    List fields = new ArrayList();
    Map converterRegistry = null;

    PatternParser.parse(input, converters, fields, converterRegistry, PatternParser.getPatternLayoutRules());
    return getFormatFromConverters(converters);
}

如果您确实想要读取符合特定PatternLayout的日志文件并生成log4j LoggingEvents的内容,请参阅LogFilePatternReceiver。 Chainsaw使用getLogFormatFromPatternLayout方法将patternLayout转换为接收器所需的LogFormat。

顺便说一句,Chainsaw的开发人员快照包含许多其他新功能 - 如果你想尝试一下,你可以在这里找到它:

http://people.apache.org/~sdeboy

答案 2 :(得分:1)

我遇到了你的项目并且它是一个不错的工作,但理想情况下我想要一些采用原生 Log4j转换模式(例如,%-5p [%t]: %m%n)和使用格式化的文件该模式,并读取相应的信息。

基本上,我正在寻找Log4j的基本Layout类的Layout.format(LoggingEvent)方法的反向。此方法生成一个存储在日志文件中的String,因此反向操作将能够解析该文件并创建LoggingEvent对象或类似的东西(类似于反序列化过程)。

谢谢!

编辑:转换很简单,只需执行

即可
LogFilePatternLayoutBuilder.getLogFormatFromPatternLayout(conversionPattern);

通过Chainsaw类org.apache.log4j.chainsaw.LogFilePatternLayoutBuilder。