logback实践笔记
前言
每次看公司配置好的logback文件的时候,都不知道什么意思。导致有的时候,一些项目发到测试环境的时候,有的项目没有打印日志,自己都不知道哪里有问题。所以自己新建一个springboot项目,使用logback来打印日志的输出格式。
日志区分
slf4j可以认为是一系列的日志接口,而log4j,logback是具体实现了的日志框架,官方翻译过来是这样说的:
slf4j译为简单的日志门面,是日志框架的抽象。而log4j和logback是众多的日志框架中的几种。
我主要对logback进行了实战。
简介
Logback是作为log4j的后续版本,Logback的体系结构足够通用。为了在不同的情况下应用,目前有三大模块:logback-core,logback-classic,logback-access。
- logback-core : 核心模块,为了其他两个模块奠定了基础。
- logback-classic: 可以看作log4f的改进版本,此外,logback-classic本身实现了SLF4J API。
- logback-access: 模块与Servlet容器(如Tomcat和Jetty)集成,以提供HTTP访问日志功能。
配置文件
在springboot项目中,会先查找是否有logback-test.xml文件,有就会加载。没有就查找logback.xml文件,里面有三个比较大的属性。分别是root,logger,appender。一些变量的配置属性property,contextName。
root
根目录属性,每个logback文件中,只有一个level属性,设置整个项目的日志输出水平。如果设置多个root的话,以最高的level为准
logback.xml代码:
<?xml version="1.0" encoding="utf-8" ?>
<!-- debug=是否打印logback内部日志 scan=是否重新加载 scanPeriod=多久扫描一次 -->
<configuration debug="true" scan="true" scanPeriod="30 seconds">
<!-- 下次再详细介绍 -->
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>%d{YYYY年MM月dd日 HH:mm:ss} | %thread | %-5level %logger - %msg%n</Pattern>
</encoder>
</appender>
<!-- 控制台只会输出error的日志 -->
<root level="info">
<appender-ref ref="stdout"/>
</root>
<root level="error">
<appender-ref ref="stdout"/>
</root>
</configuration>
测试代码:
package com.example.logback.Demo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
/**
* @ClassName LogbackTest
* @Description TODO
* @Author ouyangkang
* @Date 2019-01-03 16:34
**/
@Component
public class LogbackTest {
private final Logger logger = LoggerFactory.getLogger("测试");
public void test() {
logger.info("=========>info");
logger.error("=========>error");
logger.debug("=========>debug");
}
}
测试类:
package com.example.logback;
import com.example.logback.Demo.LogbackTest;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import javax.annotation.Resource;
@RunWith(SpringRunner.class)
@SpringBootTest
public class LogbackApplicationTests {
@Resource
private LogbackTest logbackTest;
@Test
public void contextLoads() {
logbackTest.test();
}
}
结果如下:

只输出error中的字段。
下一篇我将把logback.xml中的logger详细介绍一下,和我自己写logger属性Demo的坑。这个坑也让我比较深刻的认识了logback。其实上面代码是有点问题的,不知道你看的出来吗。一旦我是用logger来打印日志这个坑就出来了。
logback实践笔记的更多相关文章
- hadoop2.5.2学习及实践笔记(二)—— 编译源代码及导入源码至eclipse
生产环境中hadoop一般会选择64位版本,官方下载的hadoop安装包中的native库是32位的,因此运行64位版本时,需要自己编译64位的native库,并替换掉自带native库. 源码包下的 ...
- Python编程从入门到实践笔记——异常和存储数据
Python编程从入门到实践笔记——异常和存储数据 #coding=gbk #Python编程从入门到实践笔记——异常和存储数据 #10.3异常 #Python使用被称为异常的特殊对象来管理程序执行期 ...
- Python编程从入门到实践笔记——文件
Python编程从入门到实践笔记——文件 #coding=gbk #Python编程从入门到实践笔记——文件 #10.1从文件中读取数据 #1.读取整个文件 file_name = 'pi_digit ...
- Python编程从入门到实践笔记——类
Python编程从入门到实践笔记——类 #coding=gbk #Python编程从入门到实践笔记——类 #9.1创建和使用类 #1.创建Dog类 class Dog():#类名首字母大写 " ...
- Python编程从入门到实践笔记——函数
Python编程从入门到实践笔记——函数 #coding=gbk #Python编程从入门到实践笔记——函数 #8.1定义函数 def 函数名(形参): # [缩进]注释+函数体 #1.向函数传递信息 ...
- Python编程从入门到实践笔记——用户输入和while循环
Python编程从入门到实践笔记——用户输入和while循环 #coding=utf-8 #函数input()让程序暂停运行,等待用户输入一些文本.得到用户的输入以后将其存储在一个变量中,方便后续使用 ...
- Python编程从入门到实践笔记——字典
Python编程从入门到实践笔记——字典 #coding=utf-8 #字典--放在{}中的键值对:跟json很像 #键和值之间用:分隔:键值对之间用,分隔 alien_0 = {'color':'g ...
- Python编程从入门到实践笔记——if语句
Python编程从入门到实践笔记——if语句 #coding=utf-8 cars=['bwm','audi','toyota','subaru','maserati'] bicycles = [&q ...
- Python编程从入门到实践笔记——操作列表
Python编程从入门到实践笔记——操作列表 #coding=utf-8 magicians = ['alice','david','carolina'] #遍历整个列表 for magician i ...
随机推荐
- PyCharm设置字体风格
设置字体风格:File—Setting—Editor-Color Scheme-Color Scheme Font-把Scheme设置为:WarmNeon
- MySQL数据库权限分类
一.权限表 mysql数据库中的3个权限表:user .db. host 权限表的存取过程是: 1)先从user表中的host. user. password这3个字段中判断连接的IP.用户名.密码是 ...
- windows 7 下用git
参考:http://my.oschina.net/longxuu/blog/141699
- Cannot uninstall 'html5lib'. It is a distutils installed project and thus we cannot accurately determine which files belong to it which would lead to only a partial uninstall.
如标题,安装Tensorflow-gpu时遇到的完整问题 Cannot uninstall 'html5lib'. It is a distutils installed project and th ...
- urls.py路由系统分发的本质
路由系统分发的本质 反向生成redirect跳转url 1.在urls.py中指定url的name from django.conf.urls import url from django.contr ...
- 理解DeepBox算法
理解DeepBox算法 基本情况 论文发表在ICCV2015,作者是Berkeley的博士生Weicheng Kuo: @inproceedings{KuoICCV15DeepBox, Author ...
- [转] 组件库按需加载 借助babel-plugin-import实现
前段时间一直在基于webpack进行前端资源包的瘦身.在项目中基于路由进行代码分离,http://www.cnblogs.com/legu/p/7251562.html.对于公司内部的组件库,所有内容 ...
- 键盘Hook【Delphi版】
原文:https://www.cnblogs.com/edisonfeng/archive/2012/05/18/2507858.html 一.钩子的基本概念 a) Hook作用:监视windows消 ...
- SP3734 PERIODNI - Periodni
题解: 第一道笛卡尔树dp 会发现以一个点为分界 如果左边大于它右边大于它 那么大于的那部分是相互不影响的 于是我们对序列建立笛卡尔树 满足父亲节点的v<儿子节点的v 然后这棵树的中序遍历为原序 ...
- java抽象类详解
前言 在没讲抽象类之前 我们先来看看 final关键字 final 修饰符 可以修饰 类.属性.方法 修饰类时 表示该类不能被继承 其他特征 跟普通的类一样 修饰 属性时 表示 改属性不能改变 ...