org.SLF4J

SLF4J不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。

  实际上,SLF4J所提供的核心API是一些接口以及一个LoggerFactory的工厂类。从某种程度上,SLF4J有点类似JDBC,不过比JDBC更简单,在JDBC中,你需要指定驱动程序,而在使用SLF4J的时候,不需要在代码中或配置文件中指定你打算使用那个具体的日志系统。如同使用JDBC基本不用考虑具体数据库一样,SLF4J提供了统一的记录日志的接口,只要按照其提供的方法记录即可,最终日志的格式、记录级别、输出方式等通过具体日志系统的配置来实现,因此可以在应用中灵活切换日志系统。

1、什么情况可以使用

  如果你开发的是类库或者嵌入式组件,那么就应该考虑采用SLF4J,因为不可能影响最终用户选择哪种日志系统。在另一方面,如果是一个简单或者独立的应用,确定只有一种日志系统,那么就没有使用SLF4J的必要。假设你打算将你使用log4j的产品卖给要求使用JDK 1.4 Logging的用户时,面对成千上万的log4j调用的修改,相信这绝对不是一件轻松的事情。但是如果开始便使用SLF4J,那么这种转换将是非常轻松的事情。

2、举例

  (1)代码

private static final Logger AV_SEARCH_LOGGER = LoggerFactory.getLogger("ieFlightLog");

try{.....

}catch (Exception e) {
            if (e instanceof AvNoRoutingException) {
                if (AV_SEARCH_LOGGER.isWarnEnabled()) {
                    AV_SEARCH_LOGGER.warn(".....", e);
                }

    }

}

(2)使用SLF4J提供的simple log

  将以下jar包加入到项目中,然后执行

  slf4j-api-1.5.2.jar

  slf4j-simple-1.5.2.jar

  最终输出:

  32 [main] INFO Wombat - Today is Wed Sep 10 14:50:57 CST 2008, Temperature set to null. Old temperature was 10.

  32 [main] INFO Wombat - Today is Wed Sep 10 14:50:57 CST 2008, Temperature set to 10. Old temperature was 60.

  32 [main] WARN Wombat - Temperature(60) has risen above 50 degrees.

  (3)使用SLF4J提供的simple log

  将以下jar包加入到项目中,然后执行

  slf4j-api-1.5.2.jar

  slf4j-jdk14-1.5.2.jar

  最终输出:

  2008-9-10 15:01:20 Wombat setTemperature

  信息: Today is Wed Sep 10 15:01:20 CST 2008, Temperature set to null. Old temperature was 10.

  2008-9-10 15:01:20 Wombat setTemperature

  信息: Today is Wed Sep 10 15:01:20 CST 2008, Temperature set to 10. Old temperature was 60.

  2008-9-10 15:01:20 Wombat setTemperature

  警告: Temperature(60) has risen above 50 degrees.

  (4)配置很简单吧

  从以上事例可以看出,配置SLF4J使用那种日志系统是非常简单的一件事,只要将与你打算使用的日志系统对应的jar包加入到项目中,SLF4J就会自动选择使用你加入的那种日志系统。这种方法被称之为静态绑定。当然,该日志系统的相关类库是不能少,例如,如果你打算使用log4j,那么还需要log4j的类库,可能还有配置配置log4j.properties。

  3、格式化日志

  SLF4J还提供了格式化日志的功能,如事例中的语句:

  logger.info("Today is {}, Temperature set to {}. Old temperature was {}.", objs);

  4、日志系统绑定原理

  在应用中,通过LoggerFactory类的静态getLogger()获取logger。通过查看该类的代码可以看出,最终是通过StaticLoggerBinder.SINGLETON.getLoggerFactory()方法获取LoggerFactory然后,在通过该具体的LoggerFactory来获取logger的。类org.slf4j.impl.StaticLoggerBinder并不在slf4j-api-1.5.2.jar包中,仔细查看每个与具体日志系统对应的jar包,就会发现,相应的jar包都有一个org.slf4j.impl.StaticLoggerBinder的实现,不同的实现返回与该日志系统对应的LoggerFactory,因此就实现了所谓的静态绑定,达到只要选取不同jar包就能简单灵活配置的目的。

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

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

相关文章

生产者与消费者

package ProConDemo; //创建资源 public class Goods { private String name; //计数器 private int count 1; //创建一个标记 private boolean flag; //创建资源的生产行为 public synchronized void Sale(String name) { //判断标记 while(flag) //有资源就等待 try {wait()…

java业务层怎么设计_java – 在业务逻辑和数据层看起来重叠时分解它们的最佳设计?...

我正在构建一个MVC Web应用程序(使用Spring MVC框架),我对设计特定区域的最佳方法感到有些困惑.应用程序必须与一系列Web服务进行交互,这些Web服务并非真正设计得非常完美,并且本身并不提供很多抽象 – 基本上每个创建/更新/检索/删除操作都有一个Web服务方法.每个“数据类型”…

Lunx运维监控_shark巨菜_基础篇

Lunx运维监控_shark巨菜_基础篇一、监控重要性单单从“监控”两个字来谈,范围之广可以涵盖我们生活的方方面面,我们生活和工作中处处可见视频监控的摄像机;机房中的电压电流监控、干湿计、温度计;值班室的网络监控,网站…

ansible for devops读书笔记第一章

yum -y install ansible ansible --versionmkdir /etc/ansible touch /etc/ansible/hosts[example]   www.example.com ansible example -m ping -u [username]ansible example -a "free -m" -u [username]转载于:https://www.cnblogs.com/guxiaobei/p/8250988.htm…

java项目皮肤包_java swing项目皮肤包+使用方法说明

这是java swing项目皮肤包使用方法说明下载,项目可用的皮肤包,总共四个,自己下载总结的,包含使用代码说明。直接在main函数最开始加入说明代码即可使用~~~加入代码后记得处理异常!软件介绍java swing项目皮肤包使用方法…

Oracle中sys和system的区别

1.数据库的启动需要以SYSDBA/SYSOPER身份登录。 2.如果在同一主机上使用IPC连接到数据库使用操作系统授权,登录任何一个用户都可以拥有as sysdba和as sysoper。 3.sys和system用户的区别 SYS用户具有DBA权限,并具有SYS模式。只能通过SYSDBA登录数据库&am…

引用和指针区别

1.引用是一个已存在对象的别名,必须被初始化,且所指对象唯一。 指针本身就是一个对象,可以为空值,能够指向不同的对象。 2.引用本质上是被限制的指针。更安全,更可靠。转载于:https://www.cnblogs.com/Chixinyang/p/82…

WinXP的EFS加密文件如何解密?

根据网上流传的资料,EFS(Encrypting File System)EFS加密是基于公钥策略的。在使用EFS加密一个文件或文件夹时,系统首先会生成一个由伪随机数组成的FEK(File Encryption Key,文件加密钥匙),然后将利用FEK和…

关于滚动条出现页面跳动问题

二、CSS3计算calc和vw单位巧妙实现滚动条出现页面不跳动 很简单,只要一行代码就搞定了: .wrap-outer {margin-left: calc(100vw - 100%); } 或者: .wrap-outer {padding-left: calc(100vw - 100%); } 然后就可以庆祝放鞭炮啦!&…

JAVA生产环境验证_Java生产环境下性能监控与调优详解

本课程将为你讲解如何在生产环境下对Java应用做性能监控与调优;通过本课程,你将掌握多种性能监控工具应用,学会定位并解决诸如内存溢出、cpu负载飙高等问题;学会线上代码调试,Tomcat、Nginx,GC调优等手段&a…

17款漂亮的 HTML5 网站模板免费下载

在过去的几年,设计师们已开始关注和使用 HTML5 了,如今 HTML5 得到了更加广泛的应用。今天,本文与大家分享17款免费的 HTML5 网站模板,看看有没自己喜欢的。 1- Smart Net 免费下载 2- Photo Art 免费下载 3- The Art Of Business…

ES6 (总结篇二)

一.字符串扩展 1.indexOf和index 之前做项目,遇到判断一个字符串是否存在,不清楚用index还是indexOf,百度之后,用了indexOf。indexOf:返回某个指定的字符串值在字符串中首次出现的位置 ,如果没有找到这个值…

python中try finally的用法_Python中的try-finally子句

您可以将finally:块与try:块一起使用。finally块是放置必须执行的所有代码的位置,无论try块是否引发异常。try-finally语句的语法是:try:You do your operations here;......................Due to any exception, this may be s…

工作三个月的总结

想想,我已经工作三个月了,总结一下我的工作经验。 找到了和自己专业相关的工作javaweb方面。虽然是个小公司,我 已经很知足了,对于没有上个好大学的我,真的很满意。 到公司没有几天,我就开始熟悉公司正在做…

关于jrebel碰到的一次问题记录

今天使用jrebel更新gitlab的代码之后,项目总是启动报错。报一个类找不到,但是这个类在整个目录下搜索不到,在target的class目录看了下也没有对应的目录。郁闷了好久,最后同事看了下,在整个target目录搜了下&#xff0c…

java动态生成sdk_android、java制作sdk以及自动生成文档

最近一直在做android开发,昨天经理让我写个接口SDK做个接口文档,以便后面的开发。这让我很焦灼,SDK怎么做?要是只有敲代码还好。可是那个接口文档!!!文档这东西最讨厌了,头都大了后来…

利用 Selenium 自动化 web 测试

Selenium 是一个健壮的工具集合,跨很多平台支持针对基于 web 的应用程序的测试自动化的敏捷开发。它是一个开源的、轻量级的自动化工具,很容易集成到各种项目中,支持多种编程语言,比如 .NET、Perl、Python、Ruby 和 Java™ 编程语…

Python3异常处理

Python3异常处理 一. 简介 在编程过程中为了增加友好性,在程序出现Bug时一般不会直接将错误信息展示给用户,而是提供一个友好的输出提示。 二. 使用 1. 异常基础 常用结构: 1234try:passexcept Exception,ex:pass其他结构: 123456…

php 正则替换style,php正则去除js,class,id,style标签代码

在写xml的时候,文档要求内容里面只要图片和段落就可以了,其他的css,js什么的都不需要。所以,在输出的时候,就要用正则去过滤掉不需要的标签代码。第一种:php正则去除js标签代码。$preg "/$content preg_replace…

Flex 序列化自定义类 解决 sharedObject 保存自定义对象

问题我想把自定义类实例存储到LSO解决办法使用flash.net.registerClassAlias( )方法保留类型信息并把类实例添加到共享对象的data属性上。讨论LSOs 使用特殊的二进制格式,Action Message Format (AMF),当要在LSO中存储类实例时,实例会被编码为…