Java logback日志的简单使用

说明

logback作为log4j的替代,有很多优势。要将logback应用到项目中,步骤很简单。加入依赖的jar包和配置文件即可。

logback.xml中主要元素:

  • <property>

定义属性,定义之后,后文可以通过该变量引用。

  • <appender>

定义日志输出格式、位置、文件分割等。被<logger>或<root>引用。

  • <logger>

定义日志名称及对应的级别。name可以是包名、类名或者单纯的字符串。如果是包名或者类名,那么该包或类中的日志级别,对应这里的设置;如果是单纯的字符串名,那么通过getLogger({name})获取的日志,采用这里的配置。

  • <root>

定义默认使用的日志配置。如果不是<logger>中的配置,那么默认使用这里的配置。

使用

logback依赖的包:

<dependency>
 <groupId>org.slf4j</groupId>
 <artifactId>slf4j-api</artifactId>
 <version>1.7.21</version>
</dependency>
<dependency>
 <groupId>ch.qos.logback</groupId>
 <artifactId>logback-core</artifactId>
 <version>1.1.7</version>
</dependency>
<dependency>
 <groupId>ch.qos.logback</groupId>
 <artifactId>logback-classic</artifactId>
 <version>1.1.7</version>
</dependency>

logback.xml配置文件放入classpath中即可,程序会自动读取该文件。

<?xml version="1.0" encoding="UTF-8" ?>

<configuration scan="true" scanPeriod="3 seconds">

 <property name="z_app" value="${z_app:-app}"/>

 <property name="SQL_LEVEL" value="DEBUG"/>
 <property name="SERVICE_LEVEL" value="DEBUG"/>
 <property name="RPC_LEVEL" value="DEBUG"/>
 <property name="BOOT_LEVEL" value="DEBUG"/>
 <property name="BUF_LEVEL" value="DEBUG"/>

 <!-- 09:14:20.256 [main] INFO com.h.db.business.main.Main - asfdasdf -->
 <property name="PATTERN" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n"/>

 <property name="SQL_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}Sql.log"/>
 <property name="SERVICE_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}Service.log"/>
 <property name="RPC_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}RPC.log"/>
 <property name="BOOT_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}Boot.log"/>
 <property name="BUF_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}Buf.log"/>
 <property name="TRACE_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}Trace.log"/>

 <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
  <encoder>
   <charset>utf-8</charset>
   <pattern>${PATTERN}</pattern>
  </encoder>
 </appender>

 <property name="ROOT_LEVEL" value="DEBUG"/>

 <property name="APP_LOG_FILE" value="${LOG_HOME}/logs/${z_app}/${z_app}.log"/>

 <appender name="APP_LOG" class="ch.qos.logback.core.rolling.RollingFileAppender">
  <encoder>
   <charset>utf-8</charset>
   <pattern>${PATTERN}</pattern>
  </encoder>
  <prudent>false</prudent>
  <append>true</append>
  <file>${APP_LOG_FILE}</file>
  <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
   <fileNamePattern>${APP_LOG_FILE}.%d{yyyy-MM-dd}-%i.gz</fileNamePattern>
   <maxFileSize>10MB</maxFileSize>
   <maxHistory>15</maxHistory>
   <totalSizeCap>200MB</totalSizeCap>
  </rollingPolicy>
 </appender>

 <!-- 打印具体sql -->
 <logger name="SqlLog" level="DEBUG" >
  <appender-ref ref="APP_LOG" />
  <appender-ref ref="CONSOLE" />
 </logger>
 <!-- 打印事务轨迹 -->
 <logger name="druid.sql.Connection" level="DEBUG" />
 <logger name="org.springframework.jdbc.datasource.CoreDataSourceUtils" level="DEBUG" />
 <logger name="org.springframework.jdbc.datasource.DataSourceUtils" level="DEBUG" />
 <logger name="org.apache.zookeeper.ClientCnxn" level="info" />
 <logger name="org.mongodb.driver.connection" level="info" />
 <logger name="org.mongodb.driver.cluster" level="info" />
 <logger name="org.apache.zookeeper.Environment" level="ERROR"/>
 <logger name="org.apache.curator.framework.recipes.cache.TreeCache" level="debug"/>
 <logger name="tk.mybatis.mapper.mapperhelper.MapperTemplate" level="DEBUG"/>

 <root level="${ROOT_LEVEL}">
  <appender-ref ref="APP_LOG" />
  <appender-ref ref="CONSOLE" />
 </root>
</configuration>

代码:

// 或者LoggerFactory.getLogger(${logger_name}),这里logger_name为logback.xml中logger标签定义的名称
private static final Logger logger2 = LoggerFactory.getLogger(XX.class);

常见问题

包冲突

如果出现:

org.slf4j.impl.Log4jLoggerFactory cannot be cast to ch.qos.logback.classic.LoggerContext

或:

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/E:/**/WEB-INF/lib/activemq-all-5.10.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/E:/**/WEB-INF/lib/slf4j-simple-1.6.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]

表示有包冲突,将冲突的包删除即可。一般是由log4j,activemq-all等包导致,删除它们。

No such instance field: 'logger2'

一开始认为是编译缓存的原因,rebuild了好几次,都是同样的问题。

通过debugger的evaluate工具,执行LoggerFactory.getLogger("SqlLog").info("testtest"),又是正常的,可以正确在控制台和文件中输出日志内容。这说明,代码是没有问题的,且获取的logger实例也正确(logback的)。

通过evaluate工具,输入logger2始终有问题,但是输入logger却没有问题,logger.info会报错,提示是log4j的包。这已经说明.class不是最新的了。因为logger是修改之前定义了,后来改成了logger2。

只是,断点的时候,代码行的位置并没有错乱。和文件不是最新的似乎有点矛盾。

最后,发现还是编译缓存的原因。

将.class文件手动清除,重新编译启动,问题解决。

看来,idea的rebuild有时候并不靠谱,无法保证.class文件是最新的。

以上就是Java logback日志的使用的详细内容,更多关于Java logback日志的资料请关注我们其它相关文章!

(0)

相关推荐

  • spring boot使用logback日志级别打印控制操作

    因为公司业务需要,需要把性能日志和业务日志分开打印,用elk收集处理,所以需要对不同的业务的日志,打印到不同文件. 使用的是spring boot自带的logback. 首先在yml文件配置logback.xml文件,默认会从resources下找logback.xml文件,找不到会从yml文件中找logging.config下的指定文件. logging: level: DEBUG config: classpath:logback.xml logback.xml是logback的配置文件,可

  • 使用logback屏蔽一些包的日志

    在logback.xml中加上该配置,包名如:com.xxx <logger name="packageName" level="OFF"> </logger> 补充知识:logback,利用java包名对包内所有类定义输出形式 目的 将java package 中的所有类定义一个输出logger,定义它的级别,这样就不用每个类都配置. 测试 配置文件 <?xml version="1.0" encoding=&qu

  • Spring Boot日志技术logback原理及配置解析

    一.logback日志技术介绍 Spring Boot中使用的日志技术为logback.其与Log4J都出自同一人,性能要优于Log4J,是Log4J的替代者. 在Spring Boot中若要使用logback,则需要具有spring-boot-starter-logging依赖,而该依赖被spring-boot-starter-web所依赖,即不用直接导入spring-boot-starter-logging依赖. 二.添加配置属性 该文件名为logback.xml,且必须要放在src/mai

  • 解决logback的日志文件路径问题

    假如使用绝对路径,没有任何问题,就是移植性不太好. 假如使用相对路径,则要注意当前路径"."是在哪儿? 一般我们都会在配置文件中加入log文件的存储目录,如 本人通过研究测试发现: 1.对于J2SE项目,当前路径为工程所在目录 如我的工程为:D:\test 则使用-/logs生成的日志文件位于:D:\logs 2.对于J2EE项目,当前路径为tomcat\bin所在目录 如我的tomcat路径为:D:\tomcat\bin 则使用-/logs生成的日志文件位于:D:\tomcat\lo

  • 使用Logback日志保存到相对路径的操作

    说明 在使用Logback中需要保存输出日志,但是却在保存的时候路径出现问题 项目背景 1.Win7 2.Java Web + Tomcat 7.0(在D盘目录下) 3.Logback 1.1.7 案例一 Logback.xml文件配置 <!-- 路径名称 --> <property name="log.base" value="logs" /> <!-- 保存的文件名 --> <property name="lo

  • logback使用filter过滤日志操作

    笔者语录: 我发现我喜欢捣鼓一些小玩意儿,虽然官网(见文末)写得很明白了,但是咱们对感兴趣的部分来敲一遍代码好吧. 过滤器简介: 简介 logback具有过滤器支持.logbcak允许给日志记录器appender配置一个或多个Filter(或者给整体配置一个或多个TurboFilter),来控制:当满足过滤器指定的条件时,才记录日志(或不满足条件时,拒绝记录日志).logback支持自定义过滤器,当然logback也自带了一些常用的过滤器,在绝大多数时候,自带的过滤器其实就够用了,一般是不需要自

  • 利用logback 设置不同包下的日志级别

    1.实现效果:项目的整体的日志打印级别为ERROR,但在某个包下或某个类想打印INFO级别的日志. 2.配置: FILE是ERROR级别日志打印: SPECIAL 是INFO级别日志打印: FILE与SPECIAL唯一不同是日志保存路径不同,其它策略相同: 通过 logger标签指定包路径或类路径并引用SPECIAL: <?xml version="1.0" encoding="UTF-8"?> <configuration> <con

  • springboot使用Logback把日志输出到控制台或输出到文件

    一:日志: 1.配置日志级别 日志记录器(Logger)的行为是分等级的.如下表所示: 分为:OFF.FATAL.ERROR.WARN.INFO.DEBUG.ALL 默认情况下,spring boot从控制台打印出来的日志级别只有INFO及以上级别,可以配置日志级别 设置日志级别 logging.level.root=WARN 这种方式只能将日志打印在控制台上 二.Logback日志 spring boot内部使用Logback作为日志实现的框架. Logback和log4j非常相似,如果你对l

  • logback关闭某个包的日志操作

    最近想关闭一个包的日志打印,经过一番研究实际上就一句话的事, 一直没成功是因为name写错了. <logger name="packname" level="OFF"> </logger> packname一般是包名,但也可能是其他的名字,这个取决于java代码中写的名字 static final Logger log=LoggerFactory.getLogger("name"); 补充知识:Log4j和logback冲

  • SpringBoot项目的logback日志配置(包括打印mybatis的sql语句)

    关于logback日志的详解见这位仁兄的博客:Spring Boot-日志配置(超详细) 我在这就开门见山直接介绍我们项目日志的配置使用吧!~ 1.基本介绍 默认情况下,Spring Boot项目就会用Logback来记录日志,并用INFO级别输出到控制台.如下图: 实际开发中我们不需要直接添加logback日志依赖. 你会发现 spring-boot-starter 其中包含了 spring-boot-starter-logging,该依赖内容就是 Spring Boot 默认的日志框架 lo

  • Logback日志基础及自定义配置代码实例

    Logback日志基础配置 logback日志配置有很多介绍,但是有几个非常基础的,容易忽略的.下面是最简单的一个配置,注意加粗的描述 <?xml version="1.0" encoding="UTF-8"?> <configuration debug="true" scan="true" scanPeriod="30 seconds"> <!--log.path定义的是局部

  • springcloud LogBack日志使用详解

    <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency> 引入lombok即可,lombok包含了Slf4j 下面只需在resources目录下引入此xml配置即可 <?xml version="1.0" encoding="UTF-8"?> <

  • Java日志框架之logback使用详解

    为什么使用logback 记得前几年工作的时候,公司使用的日志框架还是log4j,大约从16年中到现在,不管是我参与的别人已经搭建好的项目还是我自己主导的项目,日志框架基本都换成了logback,总结一下,logback大约有以下的一些优点: 内核重写.测试充分.初始化内存加载更小,这一切让logback性能和log4j相比有诸多倍的提升 logback非常自然地直接实现了slf4j,这个严格来说算不上优点,只是这样,再理解slf4j的前提下会很容易理解logback,也同时很容易用其他日志框架

随机推荐