logback怎么根据logger输出不同文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了logback怎么根据logger输出不同文件相关的知识,希望对你有一定的参考价值。

参考技术A 为了方便查看和归档:
不同包的日志可能要放到不同的文件中,如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-%dyyyy-MM-dd.log</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%dHH:mm:ss.SSS [%thread] %-5level %logger5 - %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-%dyyyy-MM-dd.log</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%dHH:mm:ss.SSS [%thread] %-5level %logger5 - %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-%dyyyy-MM-dd.log</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%dHH:mm:ss.SSS %thread %XinvokeNo %logger40 %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本回答被提问者和网友采纳

springboot 将logback日志根据不同类输入到不同路径下2(含sql)

一 概述

想通过将日志按照不同class进行打印输出,但是上一篇没有包含sql日志,本编就详细介绍根据不同类日志输出到不同文件且包含sql日志。

二操作

2.1 工程概况

2.2  logback的配置

2.2.1 usercontroller

1.日志文件的声明

<!-- 生成用户日志文件 -->
<appender name="userFILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!-- 日志名称 -->
    <file>$LOG_PATH/uc/usercontroller.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
        <fileNamePattern>$LOG_PATH/uc/usercontroller.%dyyyy-MM-dd.%i.log</fileNamePattern>
        <!-- 日志最大 50MB -->
        <maxFileSize>50MB</maxFileSize>
        <!-- 保存 30 天 -->
        <maxHistory>30</maxHistory>
        <!--            <totalSizeCap>10GB</totalSizeCap>  &lt;!&ndash; 总日志大小 &ndash;&gt;-->
    </rollingPolicy>

    <encoder>
        <pattern>$LOG_FILE_PATTERN</pattern>
    </encoder>
</appender>

2 定义日志级别

 sql的输出:这一步很重要,不然sql就不会输入到制定的文件中。

<logger name="com.ljf.spring.boot.demo.persistence.dao.UsersMapper" level="debug">
    <appender-ref ref="userFILE"/>
</logger>

常规日志输出:

<!--用户 -->
<logger name="userLog" level="INFO" additivity="false">
    <appender-ref ref="CONSOLE"/>
    <appender-ref ref="userFILE"/>
</logger>

2.2.2 bikecontroller

1.声明

<!-- 生成用户日志文件 -->
<appender name="bikeFILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!-- 日志名称 -->
    <file>$LOG_PATH/bike/bike.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
        <fileNamePattern>$LOG_PATH/bike/bike.%dyyyy-MM-dd.%i.log</fileNamePattern>
        <!-- 日志最大 50MB -->
        <maxFileSize>50MB</maxFileSize>
        <!-- 保存 30 天 -->
        <maxHistory>30</maxHistory>
        <!--            <totalSizeCap>10GB</totalSizeCap>  &lt;!&ndash; 总日志大小 &ndash;&gt;-->
    </rollingPolicy>

    <encoder>
        <pattern>$LOG_FILE_PATTERN</pattern>
    </encoder>
</appender>

2.定义日志级别

 sql的输出:这一步很重要,不然sql就不会输入到制定的文件中。

<logger name="com.ljf.spring.boot.demo.persistence.dao.BikeMapper" level="debug">
    <appender-ref ref="bikeFILE"/>
</logger>
<!--bike -->
<logger name="bikeLog" level="INFO" additivity="false">
    <appender-ref ref="CONSOLE"/>
    <appender-ref ref="bikeFILE"/>
</logger>

2.3  logback文件的加载使用

1.定义sql语句输出到文件中加载类和风格;以及加载应用到的logback文件 

2.4 在具体不同类中使用各自的log日志文件输出

1.user

 

2.bike

 2.5 启动测试

1.启动程序后,不同类的日志生成到不同文件目录下

 

2.对各个类进行访问

 user:

2.bike

 

3.查看日志

user:

 

 bike:

 ok! 到此大工搞成!!!

以上是关于logback怎么根据logger输出不同文件的主要内容,如果未能解决你的问题,请参考以下文章

logback怎样通过http访问log

Logback配置文件这么写,TPS提高10倍

Logback日志配置(分级别输出到不同文件)

logback架构

logback 日志打印 怎么实现换行

Logback输出行号