前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >《手把手教你》系列基础篇(九十一)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-下篇(详解教程)

《手把手教你》系列基础篇(九十一)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-下篇(详解教程)

作者头像
北京-宏哥
发布2022-04-27 18:56:46
3260
发布2022-04-27 18:56:46
举报

1.简介

为了方便查看和归档:(1)不同包的日志可能要放到不同的文件中,如service层和dao层的日志;(2)不同日志级别:调试、信息、警告和错误等也要分文件输出。所以宏哥今天主要介绍和分享的是:使用logback输出日志到不同文件。废话不说直入主题。

2.第一种方法:根据包输出

根据包输出,通过logger的name属性指定不同的包,具体步骤如下:

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

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

3. 测试方法

2.1创建不同包

1.创建不同包并在包下新建类ADao和BService。如下图所示:

(1)ADao

(2)BService

2.参考代码

(1)ADao.java

代码语言:javascript
复制
package dao;

import org.slf4j.LoggerFactory;
import ch.qos.logback.classic.Logger;

/**
 * @author 北京-宏哥
 * 
 * @公众号:北京宏哥
 * 
 * 《手把手教你》系列基础篇(九十一)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-下篇(详解教程)
 *
 * 2022年3月29日
 */

public class ADao {  
    static final Logger log = (Logger) LoggerFactory.getLogger(ADao.class);  
      
    public void queryADao() {  
        log.debug("query queryADao start...");  
        log.error("An error occurred during the query");  
        log.debug("query queryADao end...");  
    }  
}  

(2)BService.java

代码语言:javascript
复制
package service;

import org.slf4j.LoggerFactory;
import ch.qos.logback.classic.Logger;
import dao.ADao;

/**
 * @author 北京-宏哥
 * 
 * @公众号:北京宏哥
 * 
 * 《手把手教你》系列基础篇(九十一)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-下篇(详解教程)
 *
 * 2022年3月29日
 */

public class BService { 
    
    static final Logger log = (Logger) LoggerFactory.getLogger(BService.class);  
    ADao ad = new ADao();
    public void bObligate() {  
        log.debug("bObligate start..."); 
        ad.queryADao();
        log.error("An error occurred during the progress");  
        log.debug("bObligate end...");  
    }  
}  
2.2logback.xml

1.新建logback.xml文件,而且在logback.xml中添加如下图所示内容:

2.参考代码

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>  
  
<configuration>  
    <appender name="serviceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
        <file>./logs2/bribery.log</file>  
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
            <fileNamePattern>/logs2/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>./logs2/venality.log</file>  
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
            <fileNamePattern>./logs2/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="service.BService" level="DEBUG" additivity="false">  
        <appender-ref ref="serviceAppender" />  
    </logger>  
      
    <logger name="dao.ADao" level="DEBUG" additivity="false">  
        <appender-ref ref="daoAppender" />  
    </logger>  
      
    <!-- root的默认level是DEBUG -->  
    <root level="DEBUG">  
        <appender-ref ref="rollingAppender" />  
    </root>  
</configuration>  
2.3测试方法

1.新建测试类。如下图所示:

2.参考代码

代码语言:javascript
复制
import service.BService;

/**
 * @author 北京-宏哥
 * 
 * @公众号:北京宏哥
 * 
 * 《手把手教你》系列基础篇(九十一)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-下篇(详解教程)
 *
 * 2022年3月29日
 */

public class testLogback {
    
    public static void main(String[] args) {
        
        BService bs = new  BService();
        bs.bObligate();
    }

}
2.4运行测试方法

1.运行代码,右键Run AS->Java Appliance,控制台输出,如下图所示:

2.输出的日志文件,如下图所示:

3.第二种方法:根据日志级别输出

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

这里宏哥还是延续使用上边的代码,只需要一个劲的修改logback.xml文件的内容即可!

3.1加入过滤器

1.修改logback(-test).xml文件:在serviceAppender和daoAppender都加入以下级别过滤器,这样错误日志就不会在bribery.log和venality.log中打印了,代码如下:

代码语言:javascript
复制
<filter class="ch.qos.logback.classic.filter.LevelFilter">  
    <level>ERROR</level>  
    <onMatch>DENY</onMatch>  
    <onMismatch>ACCEPT</onMismatch>  
</filter>  
3.2新建一个appender

1.新建一个错误日志的appender,代码如下:

代码语言:javascript
复制
<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>  
3.2加上errorAppender

在name为dao.ADao和service.BService的logger都加上errorAppender,代码如下:

代码语言:javascript
复制
<appender-ref ref="errorAppender" />  
3.4完整的logback.xml文件

1.修改完成的logback.xml文件,如下图所示:

2.参考代码

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>  
  
<configuration>  
    <appender name="serviceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
        <file>./logs3/bribery.log</file>  
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
            <fileNamePattern>/logs3/bribery-%d{yyyy-MM-dd}.log</fileNamePattern>  
        </rollingPolicy>  
        <encoder>  
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>  
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">  
            <level>ERROR</level>  
            <onMatch>DENY</onMatch>  
            <onMismatch>ACCEPT</onMismatch>  
        </filter>          
    </appender>  
      
    <appender name="daoAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
        <file>./logs3/venality.log</file>  
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
            <fileNamePattern>./logs3/venality-%d{yyyy-MM-dd}.log</fileNamePattern>  
        </rollingPolicy>  
        <encoder>  
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>  
        </encoder>  
        <filter class="ch.qos.logback.classic.filter.LevelFilter">  
            <level>ERROR</level>  
            <onMatch>DENY</onMatch>  
            <onMismatch>ACCEPT</onMismatch>  
        </filter>  
    </appender>  
    <appender name="errorAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
        <file>./logs3/error.log</file>  
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
            <fileNamePattern>/logs3/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>   
    <logger name="service.BService" level="DEBUG" additivity="false">  
        <appender-ref ref="serviceAppender" />  
        <appender-ref ref="errorAppender" />  
    </logger>  
      
    <logger name="dao.ADao" level="DEBUG" additivity="false">  
        <appender-ref ref="daoAppender" />  
        <appender-ref ref="errorAppender" />  
    </logger>  
      
    <!-- root的默认level是DEBUG -->  
    <root level="DEBUG">  
        <appender-ref ref="rollingAppender" />  
    </root>  
</configuration>  
3.5运行测试方法

1.修改完成后,运行代码,右键Run AS->Java Appliance,控制台输出,如下图所示:

 2.输出的日志文件,如下图所示:

 从上图可以看出:service和dao的错误日志都打印到error.log文件中了。

4.小结

  好了,时间也不早了,今天就分享和讲解到这里,希望对您有所帮助,感谢您耐心地阅读!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.简介
  • 2.第一种方法:根据包输出
    • 2.1创建不同包
      • 2.2logback.xml
        • 2.3测试方法
          • 2.4运行测试方法
          • 3.第二种方法:根据日志级别输出
            • 3.1加入过滤器
              • 3.2新建一个appender
                • 3.2加上errorAppender
                  • 3.4完整的logback.xml文件
                    • 3.5运行测试方法
                    • 4.小结
                    相关产品与服务
                    日志服务
                    日志服务(Cloud Log Service,CLS)是腾讯云提供的一站式日志服务平台,提供了从日志采集、日志存储到日志检索,图表分析、监控告警、日志投递等多项服务,协助用户通过日志来解决业务运维、服务监控、日志审计等场景问题。
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档