logback 同一路径下只能有一个配置文件吗

logback 同一路径下只能有一个配置文件吗,第1张

般情况下,如果在同一个web容器中有多个项目用到logback(下面都以tomcat为例,其他容器类似)

1)每个项目都自带logback的lib包和配置文件(logback.xml)

缺点:念纳项目多的话一堆重复的第三方jar包,打war包发布更新的时候慢

2)把lib包和配置文件都放在tomcat/lib下

缺点:多个项目的配置写在同一个文件中,互相干扰,发布完还得手动改,不方便

为了解决该问题,建立了logback-web项目

内容非常简单,就一个类+一个配置文件

达到的效果仔衡没:将logback的jar包和logback-web的包都放在tomcat/lib下,而每个项目自己的日志配置文件(logback.xml或logback.groovy)放在自己的WEB-INF/classes下,logback自动为每个项目分别初始化LoggerFactory

原理:logback读取配置文件的顺序为

1.classpath下(如果jar包放在tomcat/lib下它就会到这个目录找)

2.寻找Configurator的第一个实现类

3.代码内默认的配置(以固定格式输出日志到console)

logback-web就是实现了Configurator,根据每个项目初始拦激化线程找到项目路径,分别读取配置文件

为了方便查看和归档:

不同包的日志可能启喊要放到不同的文件中,如service层和dao层的日志;

不同日志级别:调试、信息、警告和错误等衫稿也要分文件输出。

一、根据包输出,通过logger的name属性指定不同的包

1. 创建不同包下的两个类:

Java代码

package com.john.service

@Service

public class ObligationService {

static final Logger log = LoggerFactory.getLogger(ObligationService.class)

@Resource

ObligationDao dao

public void obligate() {

log.debug("obligate start...")

dao.queryObligations()

log.error("An error occurred during the progress")

log.debug("obligate end...")

}

}

Java代码

package com.john.dao

@Repository

public class ObligationDao {

static final Logger log = LoggerFactory.getLogger(ObligationDao.class)

public void queryObligations() {

log.debug("query obligations start...")

log.error("An error occurred during the query")

log.debug("query obligations end...")

}

}

2. 在logback(-test).xml中添加:

Xml代码

<appender name="serviceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">

<file>/或旁孝logs/bribery.log</file>

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<fileNamePattern>/logs/bribery-%d{yyyy-MM-dd}.log</fileNamePattern>

</rollingPolicy>

<encoder>

<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>

</encoder>

</appender>

<appender name="daoAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">

<file>/logs/venality.log</file>

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>

</rollingPolicy>

<encoder>

<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>

</encoder>

</appender>

<logger name="com.john.service" level="DEBUG" additivity="false">

<appender-ref ref="serviceAppender" />

</logger>

<logger name="com.john.dao" level="DEBUG" additivity="false">

<appender-ref ref="daoAppender" />

</logger>

在类路径下创建Spring的beans.xml文件:(beans节点省略)

Xml代码

<context:component-scan base-package="com.john" />

3. 测试方法:

Java代码

@Test

public void dispatchByPackageTest() {

AbstractApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml")

ObligationService service = ctx.getBean(ObligationService.class)

service.obligate()

}

执行测试后,

bribery.log:

15:59:59.839 [main] DEBUG c.j.s.ObligationService - obligate start...

15:59:59.844 [main] ERROR c.j.s.ObligationService - An error occurred during the progress

15:59:59.844 [main] DEBUG c.j.s.ObligationService - obligate end...

venality.log:

15:59:59.844 [main] DEBUG c.j.d.ObligationDao - query obligations start...

15:59:59.844 [main] ERROR c.j.d.ObligationDao - An error occurred during the query

15:59:59.844 [main] DEBUG c.j.d.ObligationDao - query obligations end...

二、根据日志级别输出

这里把所有级别为ERROR的日志输出到一个文件中

1. 修改logback(-test).xml文件

serviceAppender和daoAppender都加入以下级别过滤器,这样错误日志就不会在bribery.log和venality.log中打印了:

Xml代码

<filter class="ch.qos.logback.classic.filter.LevelFilter">

<level>ERROR</level>

<onMatch>DENY</onMatch>

<onMismatch>ACCEPT</onMismatch>

</filter>

新建一个错误日志的appender:

Xml代码

<appender name="errorAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">

<file>/logs/error.log</file>

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>

</rollingPolicy>

<encoder>

<pattern>%d{HH:mm:ss.SSS} %thread %X{invokeNo} %logger{40} %msg%n</pattern>

</encoder>

<filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印错误日志 -->

<level>ERROR</level>

<onMatch>ACCEPT</onMatch>

<onMismatch>DENY</onMismatch>

</filter>

</appender>

name为com.john.dao和com.john.service的logger都加上errorAppender:

Xml代码

<appender-ref ref="errorAppender" />

2. 执行上面的测试方法,service和dao的错误日志都打印到error.log文件中了:

16:12:51,433 main com.john.dao.ObligationDao An error occurred during the query

16:12:51,433 main com.john.service.ObligationService An error occurred during the progress

logback日志框架由三部分组成: logback-core 、 logback-access 、 logback-classic 。使用起来也很方便需要在项目目录下增加logback.xml文件。在springboot项目,框架已经集成了logback(默认的日志框架),只需要在项目 resource 下配置 logback.xml文件模烂 或者 logback-spring.xml 文件。这里主要记录的是logback配置文件的内容部分。

在学习logback时,我们需要了解设计者的思维方式。我们才能更好的配置出我们需要的日志策略及性能。

(1)控制台日志和写入文件日志分开

日志本身是可追加写入的,定义为 追加器 : appender ,控制台和写入文件日志分别有 ConsleAppdender 和 FileAppender 两个追加器处理。

(2)日志打印的内容可以控制参数格式

打印出的日志一定是规整的,便于开发跟踪问题。例如:问题发生的时间,由于大部分程序都是多线程运行的,则需要知道每个业务请求的线程号,出问题的使用到的类名等等.

(3)写入文件中的日志不宜过大同时考虑时间跨天问题

考虑到将文件分开(可卷起 Rolling ),则使用升级的追加器 RollingFileAppender ,同时分开规则( Policy )考虑到跨天跨时间 。则在追加器中定义拆分规则: SizeAndTimeBasedRollingPolicy

(4)日志应该可以灵活指定输出级别

针对“ com.sports ”包下的日志,控制台和日志文件都使用debug级别。

(5)必须对主体日志指定输出级别

虽然我们会对不同的包或者框架下日志设置输出级别,但不可缺少主体日志输出级别: root

(6)日志可以异步写入

通常日志是汪返和业务应用公用同一个线程,写系统日志会有 IO 开销,会损耗性能,我们应该可以异步写日志

logback框架日志格式通过 PatternLayout 方式配置,样例:

encoder作用:①把日志信息转换成字节数组;②把字节数组写入到输出流。

PatternLayoutEncoder 是唯一有用的且默认的 encoder , encoder 下只有一个 pattern 节点。

(1) % + “转换符号”输出信息

%t : t表示线程的转换符,打印控制台" [Thread: restartedMain]"

pattern中的转换符列表

(2)格式修饰符

与转换符共同使用,可选的格式修饰符位于“%”和转换符之间

左对齐 修饰符 :符号是减困码饥号“-”;接着是可选的最小宽度 修饰符,用十进制数表示

(3)使用 slf4j 中的 MDC 新增线程参数

“ %X ”用于输出和当前线程相关联的 MDC (嵌套诊断环境),格式 %X{xxx},使用 org.slf4j.MDC 添加 key/value 即可增加新值,

其中tracId是在MDC中设置进当前线程中的参数,记得在线程运行完时清除 clear 掉。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12148672.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存