重新登录:重新登录

嗨,我再次回到日志中来,这是任何应用程序设计和开发的固有部分。 我是坚强的基础知识的忠实拥护者,在我的拙见中,日志记录是任何企业级应用程序中经常被忽略但基本的关键要素之一。

我已经写在此之前这里 。 为了理解当前文章,阅读本书并不是强制性的,但可以粗略地看一下它,以设置本文的上下文。

在第一篇文章中,我介绍了日志记录作为无所不在的System.out.println()的一种高收益,低成本的替代方法,所有Java人士都非常喜欢它。 我在那篇文章中使用过log4j 。 Log4j是一个可靠的框架,并兑现了承诺。 在使用它的所有年份中,它从未让我失望。 我可以全心全意地推荐它。 但是,话虽如此,也很少有替代品,这些替代品在市场上已经存在了一段时间。我很高兴地说,其中至少有一个似乎在挑战自己的地盘log4j。 我说的是Logback 。
当然,这并不是一个新手,这就是我建议您从企业级应用程序开始考虑的原因之一。 快速浏览一下Maven Central ,发现第一版发布于2006年。在2006年至2012年6月8日之间,也就是最新版本推向Maven Central时,已经有46个版本。 将此与log4j进行比较。 第一个版本于2005年在Maven Central推出,最后一个版本于2012年5月26日发布,在这些版本之间共有14个不同的版本。 我并不是要使用这些数据来比较这两个框架。 唯一的目的是向读者保证Logback已经存在了很长时间,并且已经足够引起人们的重视。
在身边是一回事,留下自己的印记是不同的。 就雄心和意图而言,Logback清楚地表明它打算成为log4j的后继者-并在其主页上明确表示。 当然,Logback声称它比Log4j具有详尽的功能/优点列表。 您可以在此链接上阅读有关它们的信息。 就是这样。 本文的重点是,我建议在设计和开发基于企业级Java的应用程序时,应更加仔细地记录日志,并考虑使用Logback 。
我希望现在有一些观众愿意大声疾呼,激发他们最喜欢的编辑器,并选择Logback试一试。 如果您是其中之一,那么您和我有一些共同点。 您可能想继续阅读。
Logback承诺的第一件事就是更快的实现(在此链接处 )。 真? 我想核实这一说法。
我首先使用Maven创建一个香草Java应用程序。

档案:MavenCommands.bat

call mvn archetype:create ^-DarchetypeGroupId=org.apache.maven.archetypes ^-DgroupId=org.academy ^-DartifactId=logger

不幸的是,它已经预装了JUnit3。我设置了JUnit 4,还添加了Contiperf,这样我可以多次运行测试-如果要检查性能,这将很方便。

文件:/logger/pom.xml

[...]UTF-84.102.2.0[...]                           [...]junitjunit${junit.version}testorg.databenecontiperf${contiperf.version}test

另外,我想显式控制用于编译和执行代码的Java版本。

文件:/logger/pom.xml

[...]2.0.21.7[...]org.apache.maven.pluginsmaven-compiler-plugin${maven-compiler-plugin.version}${java.version}                        ${java.version}

最后配置–暂时。 随心所欲地运行单元测试。

文件:/logger/pom.xml

[...]2.12[...]org.apache.maven.pluginsmaven-surefire-plugin${maven-surefire-plugin.version}org.apache.maven.surefiresurefire-junit47${maven-surefire-plugin.version}-XX:-UseSplitVerifier

请注意,我竭尽全力将所有这些依赖项及其版本添加到本文中,只是为了确保您自己尝试一下,您确切知道测试的软件配置是什么。

现在,让我们最后添加单元测试。

文件:/logger/src/test/java/org/academy/AppTest.java

public class AppTest {                                 private final static Logger logger = LoggerFactory .getLogger(AppTest.class);                 @Rule                                              public ContiPerfRule i = new ContiPerfRule();      @Test                                              @PerfTest(invocations = 10, threads = 1)           @Required(max = 1200, average = 1000)              public void test() {                         for(int i = 0; i<10000 ; i++){          logger.debug("Hello {}", "world.");        }                                              }                                                  
}

因此,我们在单元测试中使用了logger,但未添加logger的实现。 我打算做的是一个接一个地添加log4j(带有slf4j)和logback(带有slf4j的固有支持),并多次运行此简单测试以比较性能。

要添加log4j,我使用了此设置。

文件:/logger/pom.xml

org.slf4jslf4j-api${slf4j.version}org.slf4jjcl-over-slf4j${slf4j.version}runtimeorg.slf4jslf4j-log4j12${slf4j.version}runtime

对于登录,我使用了此设置。

文件:/logger/pom.xml

ch.qos.logbacklogback-classic${logback.version}

具有以下版本。

文件:/logger/pom.xml

1.6.11.0.6

为了使这两个记录器框架中的任何一个实际记录任何内容,您必须添加一个文件,告诉记录器要记录什么以及在何处。

文件:src / main / resources / log4j.properties

# Set root logger level to DEBUG and its only appender to A1.
log4j.rootLogger=DEBUG, A1# configure A1 to spit out data in console
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout 
log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p %c - %m%n
最后,是关键时刻。 我对每个框架(即logback和log4j)进行了三次测试。 本质上,我在每次测试中将字符串log.debug()进行1000,000次并计时。 这就是最终数字出来的方式。
构架 第一轮 第二次 第三轮
退回 0.375秒 0.375秒 0.406秒
Log4j 0.454秒 0.453秒 0.454秒
就这个小实验而言,Logback的执行速度显然比Log4j快。 当然,这是过于简单的实验,并且尚未考虑许多有效方案。 例如,我们还没有真正使用vanilla log4j。 我们已经将log4j与slf4j API结合使用,这不是完全一样的。 同样,更快不是唯一的考虑因素。 Log4j异步工作( 在此处和此处阅读),而据我所知,Logback并非如此。 Logback具有Log4j没有的许多漂亮功能。
因此,孤立地看这小小的代码并不能真正证明任何东西。 如果有的话,它使我回到了我提出的第一点–如果您正在设计/编码基于Java的企业级应用程序,则Logback具有很大的潜力,值得一看。
这就是本文的全部内容。 快乐的编码。
想继续读吗? 我可以建议...
本系列的第一篇文章。 应用程序日志记录的10个技巧。 如何轻松排除公共日志
关于提高NOT日志记录性能的一个不错的技巧。

参考:在Tech for Enterprise博客上,从我们的JCG合作伙伴 Partho 重新获得了日志记录 。


翻译自: https://www.javacodegeeks.com/2012/07/logback-logging-revisited.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/371743.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

eclipse 下使用git clone

方法一&#xff1a;eclipse安装好git插件后&#xff0c;直接import-git-project from git- clone url-输入github的网址等就可以了方法二&#xff1a;使用git软件&#xff0c;到指定的目录&#xff0c;右击git bash here&#xff0c;git clone 加带有网址的文件.git,如&#xf…

linux -unrar解压缩

解压缩命令unrar的使用&#xff1a; $unrar --help用法: unrar <command>-<switch 1> -<switchN> <archive><files...><listfiles...><path_to_extract\><命令>e 解压文件到当前目录l[t,b] 列出压缩文档信…

终极JPA查询和技巧列表–第3部分

在阅读第三部分之前&#xff0c;请记住本系列的第一部分和第二部分 JPA&#xff1a;通过查询创建对象 JPA允许我们在查询内创建对象&#xff0c;并带有所需的值&#xff1a; package com.model;public class PersonDogAmountReport {private int dogAmount;private Person pe…

分治1--二分查找

分治1--二分查找 一、心得 二、题目和分析 三、代码和结果 1 #include <iostream>2 using namespace std;3 int a[10]{1,2,4,5,7,8,9,10,13,20};4 5 6 //非递归 7 int find(int i){8 int l0,r9;9 int mid(lr)/2; 10 while(l<r){ 11 mid(lr)/2; 12…

隐式意图启动一个Activity

隐式意图是通过指定一组动作或者属性实现&#xff0c;主要用于跨应用使用。 1.创建一个意图对象 Intent intent new Intent();2.设置意图过滤器 intent.setAction("android.intent.action.testActivity"); //对应于action intent.addCategory("android.intent.…

Spring自定义命名空间

Spring自定义命名空间提供了一种很好的方式来简化用于描述Spring应用程序上下文的bean定义的xml文件。 这是一个相当古老的概念&#xff0c;最初是在Spring 2.0中引入的&#xff0c;但值得不时地进行审查。 考虑一种情况&#xff0c;必须为没有自定义名称空间的Spring MVC应用程…

java二叉树代码_JAVA语言实现二叉树生成的代码教程

本文主要向大家介绍了JAVA语言实现二叉树生成的代码教程&#xff0c;通过具体的内容向大家展示&#xff0c;希望对大家学习JAVA语言有所帮助。给定某二叉树三序遍历中的两个&#xff0c;我们即可以通过生成该二叉树&#xff0c;并遍历的方法&#xff0c;求出剩下的一序&#xf…

一个回到顶部的锚点

一般网站的右下角都会有一个回到顶部的锚点&#xff0c;但是在没有学bootstrap的时候&#xff0c;我还是会想着用定位来做这个东西&#xff0c;但是现在用bootstrap来做的&#xff0c;所以将它记录下来。 <!DOCTYPE html><html> <head><title>附加导航…

jquery jgrid filterToolBar beforeSearch 修改postData

beforeSearch: function() { var posted_data $("#mygrid").jqGrid(getGridParam,postData); posted_data ["testp"]"helloTest"; }转载于:https://www.cnblogs.com/qiumingcheng/p/7141671.html

预告片:裸指关节SOA

我正在研究这个想法&#xff0c;但我不知道它是否对你们有吸引力。 我想就您是否需要进一步探讨提出您的意见。 达成协议&#xff1a;我遇到过一些团队&#xff0c;他们在使用SOA技术时由于其工具的复杂性而陷入泥潭。 我只在Java中看到过这种情况&#xff0c;但是我从一些C&am…

网页转图片 java_java-网页转图片

对比了网上常用的好几种网页转图片的开源插件&#xff0c;最后效果还不如使用原生的java直接写来得好&#xff0c;上代码&#xff0c;很简单&#xff0c;中间需要考虑网页加载延迟的问题&#xff0c;所以需要加上thread.sleep&#xff0c;休眠一下等待网页加载完成了&#xff0…

开一个新坑吧

每天读读日志 给自己动力 开个新坑&#xff08;外星殖民&#xff09; 无聊时写一写 转载于:https://www.cnblogs.com/dandansang/p/7143489.html

JMX和Spring –第1部分

这是三篇文章的第一篇&#xff0c;这三篇文章将展示如何通过JMX支持为Spring应用程序赋能。 Maven配置 这是用于设置此示例代码的Maven pom.xml&#xff1a; <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSche…

maven exclude java_java – Maven:从shade插件中排除依赖项

我在mvn clean install之后看过下一个字符串Including com.sun.jersey.contribs:jersey-multipart:jar:1.5 in theshaded jar问题&#xff1a;即使我已经为maven-shade-plugin添加了exlusion,我也无法使它没有阴影(参见下面的代码)我的maven-shade-plugin&#xff1a;org.apach…

JMX和Spring –第3部分

本文是本系列的最后一篇。 看一下第1 部分和第2部分 。 在本系列的最后一篇文章中&#xff0c;我将展示如何在JDK中使用本机JMX支持来实现一种通知机制&#xff0c;该机制可以在HEAP内存超过特定阈值时向侦听器发出警报。 正如我在上一篇文章中讨论的那样&#xff0c;这种方法…

QScrollArea不能显示滚动条

转载请注明出处&#xff1a;http://www.cnblogs.com/dachen408/p/7147141.html 问题&#xff1a;QScrollArea不能显示滚动条 解决方案&#xff1a;设置QScrollArea->setWidgetResizeable&#xff08;false&#xff09;解决问题。 例子&#xff1a; ui.scrollArea->setWi…

java婚庆网站源码_基于jsp的婚庆网站-JavaEE实现婚庆网站 - java项目源码

基于jspservletpojomysql实现一个javaee/javaweb的婚庆网站, 该项目可用各类java课程设计大作业中, 婚庆网站的系统架构分为前后台两部分, 最终实现在线上进行婚庆网站各项功能,实现了诸如用户管理, 登录注册, 权限管理等功能, 并实现对各类婚庆网站相关的实体进行管理。该婚庆…

JQuery实现的模块交换动画效果

<!doctype html> <html><head><meta http-equiv"content-type" content"text/html;charsetutf-8" /><title>JQuery实现的模块交换动画效果</title><meta name"Keywords" content"jquery&#xff0c…

CKD 实现

主要功能&#xff1a;1、新物料&#xff08;部品号&#xff09;的入库管理 部品号的验证、描述、品名、重量、单价等 2、部品号-供应商的核对 校验部品号/供应商的对应情况、入库、移除等 3、BOM清单的导入 基础清单的导入 4、订单 CKD套件管理 物料齐套管理 箱单管理 汇总 5、…

JMX和Spring –第2部分

这篇文章从本教程的第1部分继续。 嗨&#xff0c;在我的前一篇文章中&#xff0c;我解释了如何通过Spring设置JMX服务器以及如何通过身份验证和授权保护对它的访问。 在本文中&#xff0c;我将展示如何实现一个简单的MBean&#xff0c;该MBean允许用户在运行时更改Log4j记录器…