如何做到在任何地方输出log4j日志
2016-04-19 · 做真实的自己 用良心做教育
千锋教育
千锋教育专注HTML5大前端、JavaEE、Python、人工智能、UI&UE、云计算、全栈软件测试、大数据、物联网+嵌入式、Unity游戏开发、网络安全、互联网营销、Go语言等培训教育。
向TA提问
关注
展开全部
实现思路就是做一个自己的Appender用于处理日志, 这本身就是log4j的运作/扩展原理
关键点在于实现append方法
public void append(LoggingEvent event) {
super.append(event);
// 所有通过log4j输出的日志都最终会到这里
// 因此这里可以任意地处理你的日志
System.out.println(this.layout.format(event))
}
因此我们可以在append时保存最近的N条日志信息, 方便在其他地方(如web页面)显示, 可以继承最常用的RollingFileAppender兼容它的功能
如果想取出最近的日志信息, 调用RecentLogConsoleAppender.getRecentLogs
前提是必须在log4的配置文件中使用这个Appender
例如
log4j.appender.logfile = x.common.log.RecentLogConsoleAppender
# 其他参数兼容RollingFileAppender
# 配置最多保存多少条最近的日志, 如果不配置默认为300条, 这个不会影响写入文件的日志数
log4j.appender.logfile.recentSize = 500
这样我们就可以在web页面中抽取出这些日志用于显示
关键点在于实现append方法
public void append(LoggingEvent event) {
super.append(event);
// 所有通过log4j输出的日志都最终会到这里
// 因此这里可以任意地处理你的日志
System.out.println(this.layout.format(event))
}
因此我们可以在append时保存最近的N条日志信息, 方便在其他地方(如web页面)显示, 可以继承最常用的RollingFileAppender兼容它的功能
如果想取出最近的日志信息, 调用RecentLogConsoleAppender.getRecentLogs
前提是必须在log4的配置文件中使用这个Appender
例如
log4j.appender.logfile = x.common.log.RecentLogConsoleAppender
# 其他参数兼容RollingFileAppender
# 配置最多保存多少条最近的日志, 如果不配置默认为300条, 这个不会影响写入文件的日志数
log4j.appender.logfile.recentSize = 500
这样我们就可以在web页面中抽取出这些日志用于显示
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询