Logback日志框架

1、日志有什么用

日志是用来记录追踪程序在运行过程中的信息的,我们可以利用日志很快定位问题。

2、什么是Logback

Logback是由log4j创始人设计的又一个开源日志组件

3、Logback的主要组成部分

Logback主要由三个模块组成:

① logback-access
logback-access模块与Servlet容器继承,以提供HTTP访问日志功能,我们可以使用logback-access来替换Tomcat的访问日志

② logback-classic
log4j的改良版,同时它提供了slf4j API,让我们可以很方便的更换成其他日志系统,如:log4j。(slf4j:即门面日志接口,提供了一套标准的日志功能接口,没有具体实现,log4j,logback都是slf4j的具体实现)

③ logback-core
其他两个模块的基础模块

4、Logback主要标签

Logback主要用到的三个标签:

① logger

日志记录器,用于存放日志对象,定义日志的类型和级别等

② appender

用于指定日志输出的目的地,也就是日志存放的媒介,这个媒介可以是控制台,可以是文件,也可以是远程套接字服务器

③ layout

用来格式化日志信息的输出的

5、Logback的具体配置

1、引入logback依赖

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
</dependency>

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
</dependency>

2、创建logback配置文件logback.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!--
configuration是logback的根标签;
scan="true" 表示配置文件发生了改变会自动加载;
scanPeriod="60 seconds" 检测配置文件修改的时间间隔,默认的单位是毫秒,这里我们设置的表示每分钟检测;

debug="false" debug如果设置为true,表示我们会打印出logback自身实时的运行信息,这里我们就不需要了,
    因为logback自身运行时非常稳定的,我们不需要对它做日志。
-->
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <include resource="org/springframework/boot/logging/logback/defaults.xml" />

    <!--定义一些参数常量-->
    <!--定义日志的输出位置-->
    <property name="log.filepath" value="log"/>

    <!--
    定义日志展示的格式
    %d{yyyy-MM-dd HH:mm:ss.SSS} 定义一条日志的展示时间
    [%thread] 表示执行日志的线程名称
    %-5level 我们空出5个空格,然后显示我们的日志级别
    %logger{100} 显示我们再哪个类(全限定类名)里面记录的日志,后面的{100}表示这个类名展示的最大长度是100
    %msg 表示我们的日志信息
    %n 表示换行
    -->
    <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{100} %msg%n"/>

    <property name="stdlog.pattern" value="%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss}}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>

    <!--定义日志输出的媒介-->
    <!--定义控制台输出,class指定的是我们具体输出位置要使动的类-->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <!--appender负责 统一调度日志的输出工作,而具体的日志的格式化工作和输出的工作会交给encoder-->
        <encoder>
            <!--定义日志输出的格式-->
            <pattern>${stdlog.pattern}</pattern>
        </encoder>
    </appender>

    <!--定义error级别的日志的appender,RollingFileAppender表示滚动日志,我们可以按天或者按月来生成不同的日志文件-->
    <appender name="ROLLING" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--文件路径-->
        <file>log/tc-order-server.log</file>
        <!--定义滚动策略,TimeBasedRollingPolicy是一个基于时间的滚动策略-->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--
            设置按每分钟的方式来生成文件,如果我们的文件名是用.gz结尾的,那么logback会自动帮我们压缩日志文件,
            如果我们不需要压缩,我们可以直接把.gz删除就行了
            -->
            <fileNamePattern>log/tc-order-server-%d{yyyy-MM-dd}.log</fileNamePattern>
            <!--设置文件最大保存的历史数据,这里就默认30份就行了-->
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <!--定义日志格式-->
        <encoder>
            <!--定义日志输出的格式-->
            <pattern>${log.pattern}</pattern>
        </encoder>
        <!--因为我们的ROLLING只需要记录error级别的日志,对于其他的日志我们不需要,所以我们要加一个过滤器,对于其他级别的日志,直接过滤-->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <!--如果是ERROR日志,我们同意记录-->
            <onMatch>ACCEPT</onMatch>
            <!--如果不是ERROR日志,我们直接忽略-->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!--
    对于日志框架来说,日志是有级别的,logback的日志级别有如下:
    trace(追踪) < debug(调试) < info(记录信息) < warn(警告) < error(错误)

    配置我们自己写的代码的日志记录器
    name="com.vgxit.logback.kkdm" 表示对应包(包含子包)里面的类中的代码产生的日志才会被下面的日志记录器记录,否则不会
    level="DEBUG" 表示我们的日志记录的级别是DEBUG,如果我们不指定level的时候,我们这个日志记录器对应的级别自动继承根记录器
    additivity="true" 表示我们自定义的记录器日志输出
    -->
    <logger name="com.itc.order" level="DEBUG" additivity="true">
        <appender-ref ref="ROLLING"/>
    </logger>

    <!--根日志记录器,所有包下面的日志都会被记录-->
    <root level="INFO">
        <appender-ref ref="STDOUT"/>
    </root>

</configuration>

6、过滤某个级别的日志

在对应的appender标签中添加以下filter

<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
        <level>INFO</level>
</filter>

7、补充,日志拆分,通过时间或大小

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容