Logback和log4j是非常相似的,如果你对log4j很熟悉,那对logback很快就会得心应手。下面列了logback相对于log4j的一些优点:
[b]更快的实现 [/b]
Logback的内核重写了,在一些关键执行路径上性能提升10倍以上。而且logback不仅性能提升了,初始化内存加载也更小了。
[b]非常充分的测试 [/b]
Logback经过了几年,数不清小时的测试。Logback的测试完全不同级别的。在作者的观点,这是简单重要的原因选择logback而不是log4j。
[b]Logback-classic非常自然实现了SLF4j [/b]
Logback-classic实现了SLF4j。在使用SLF4j中,你都感觉不到logback-classic。而且因为logback-classic非常自然地实现了SLF4J,所以切换到log4j或者其他,非常容易,只需要提供成另一个jar包就OK,根本不需要去动那些通过SLF4JAPI实现的代码。
[b]非常充分的文档 [/b]
官方网站有两百多页的文档。
[b]自动重新加载配置文件 [/b]
当配置文件修改了,Logback-classic能自动重新加载配置文件。扫描过程快且安全,它并不需要另外创建一个扫描线程。这个技术充分保证了应用程序能跑得很欢在JEE环境里面。
[b]Lilith [/b]
Lilith是log事件的观察者,和log4j的chainsaw类似。而lilith还能处理大数量的log数据
[b]谨慎的模式和非常友好的恢复 [/b]
在谨慎模式下,多个FileAppender实例跑在多个JVM下,能够安全地写道同一个日志文件。RollingFileAppender会有些限制。Logback的FileAppender和它的子类包括RollingFileAppender能够非常友好地从I/O异常中恢复。
[b]配置文件可以处理不同的情况 [/b]
开发人员经常需要判断不同的Logback配置文件在不同的环境下(开发,测试,生产)。而这些配置文件仅仅只有一些很小的不同,可以通过,和来实现,这样一个配置文件就可以适应多个环境。
[b]Filters(过滤器) [/b]
有些时候,需要诊断一个问题,需要打出日志。在log4j,只有降低日志级别,不过这样会打出大量的日志,会影响应用性能。在Logback,你可以继续保持那个日志级别而除掉某种特殊情况,如alice这个用户登录,她的日志将打在DEBUG级别而其他用户可以继续打在WARN级别。要实现这个功能只需加4行XML配置。可以参考MDCFIlter
[b]SiftingAppender(一个非常多功能的Appender) [/b]
它可以用来分割日志文件根据任何一个给定的运行参数。如,SiftingAppender能够区别日志事件跟进用户的Session,然后每个用户会有一个日志文件。
[b]自动压缩已经打出来的log [/b]
RollingFileAppender在产生新文件的时候,会自动压缩已经打出来的日志文件。压缩是个异步过程,所以甚至对于大的日志文件,在压缩过程中应用不会受任何影响。
[b]堆栈树带有包版本 [/b]
Logback在打出堆栈树日志时,会带上包的数据。
[b]自动去除旧的日志文件 [/b]
通过设置TimeBasedRollingPolicy或者SizeAndTimeBasedFNATP的maxHistory属性,你可以控制已经产生日志文件的最大数量。如果设置maxHistory为12,那那些log文件超过12个月的都会被自动移除。
总之,logback比log4j太优秀了,让我们的应用全部建立logback上吧
Java logback配置syslog
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
下一篇:sklearn中逻辑回归模型原理
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
Logback - 日志框架
日志管理之Logback...
日志管理 Java -
java logback 配置 路径 logback配置文件详解
一、添加maven依赖<dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.25</version>
java logback 配置 路径 logback spring spring boot bootstrap -
java遍历xml的子标签及内容
二叉树的遍历分前序、中序、后序遍历,实现可以用递归版和非递归版本,正常的遍历都需要使用额外的栈空间来辅助,额外空间复杂度为O(h) h为二叉树高度,mirros遍历则可以充分利用空间,额外空间复杂度为O(1)来实现前序、中序和后序遍历。递归三种遍历方式,递归程序都一样,只是打印时机不一样。 非递归前序遍历:遍历顺序为中左右,这里使用栈结构来辅助,放入头节点,弹出之间打印,再把右节点放到
java遍历xml的子标签及内容 tinyxml2遍历所有节点 二叉树层序遍历递归与非递归 前序遍历中序遍历生成二叉树 子树