Logback日志基础及自定义配置代码实例

作者:贾树丙 时间:2022-09-04 01:01:41 

Logback日志基础配置

logback日志配置有很多介绍,但是有几个非常基础的,容易忽略的。下面是最简单的一个配置,注意加粗的描述


<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true" scan="true" scanPeriod="30 seconds">

<!--log.path定义的是局部变量,./logs指定的是相对路径下的文件夹logs-->
 <property name="log.path" value="./logs"/>

<appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">

<!--这里的文件名是不能使用正则表达式,只能是定死的名字,实现了很久-->
   <file>${log.path}/errorlog.log</file>

<!-- 日志输出格式:%d表示日期时间,%thread表示线程名,%-5level:级别从左显示5个字符宽度
      %logger{50} 表示logger名字最长50个字符,否则按照句点分割。 %msg:日志消息,%n是换行符 -->
   <encoder>
     <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
   </encoder>

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
     <!-- 每天日志归档路径以及格式,可以不使用log后缀,%i:当文件大小超过maxFileSize时,按照i进行文件滚动,i从0开始滚动 -->
     <FileNamePattern>${log.pat h}/errorlog.%d{yyyyMMdd}.log.%i.gz</FileNamePattern>
     <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
       <maxFileSize>4096MB</maxFileSize>
     </timeBasedFileNamingAndTriggeringPolicy>
     <!--日志文件保留天数-->
     <maxHistory>365</maxHistory>
   </rollingPolicy>
 </appender>

<!-- 日志级别-->
 <root level="debug">   
   <appender-ref ref="ROLLING-FILE-OUT"/>
 </root>

</configuration>

在规范里,行结束符往往采用Linux结束符(\n),而不是上面那样的 %n。 这个\n ,使用txt文档查看,并没有换行

使用%的正则还有许许多多,比如如下:

<property name="CONSOLE_LOG_PATTERN" value="%date{yyyy-MM-dd HH:mm:ss} | %highlight(%-5level) | %yellow(%thread) | %green(%logger) | %msg%n"/>

再比如:%contextName 作用是 显示主机名

Logback日志自定义配置

即便如此,还是有很多想要的东西显示不了,这时就可自定义配置。比如我希望每条日志有个uuid类型的id,希望每条日志能打印ip地址

一、新建两个配置类,重写convert方法


package cn.jiashubing.config.logback;

import ch.qos.logback.classic.pattern.ClassicConverter;
import ch.qos.logback.classic.spi.ILoggingEvent;
import java.util.UUID;

public class LogIdConfig extends ClassicConverter {

@Override
 public String convert(ILoggingEvent event) {
   return UUID.randomUUID().toString().replaceAll("-", "");
 }
}

package cn.jiashubing.config.logback;

import ch.qos.logback.classic.pattern.ClassicConverter;
import ch.qos.logback.classic.spi.ILoggingEvent;
import java.net.InetAddress;
import java.net.UnknownHostException;

public class IPLogConfig extends ClassicConverter {

@Override
 public String convert(ILoggingEvent event) {
   try {
     return InetAddress.getLocalHost().getHostAddress();
   } catch (UnknownHostException e) {
     e.printStackTrace();
   }
   return null;
 }
}

二、配置日志文件


<property name="log.path" value="./logs"/>
<conversionRule conversionWord="ip" converterClass="cn.jiashubing.config.logback.IPLogConfig" />
<conversionRule conversionWord="logid" converterClass="cn.jiashubing.config.logback.LogIdConfig" />

<appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">       
 <file>${log.path}/errorlog.log</file>       
 <encoder>           
   <pattern>[loglevel=%level] [timestamp=%d{yyyy-MM-dd HH:mm:ss}] [logid=%logid] [ip=%ip] [cmd=%msg] \n</pattern>       
 </encoder>
 ...
</appender>

来源:https://www.cnblogs.com/acm-bingzi/p/logback.html

标签:Logback,日志,基础,自定义,配置
0
投稿

猜你喜欢

  • Java封装、继承、多态三大特征的理解

    2023-07-16 14:26:46
  • VSCode 搭建 Arm 远程调试环境的步骤详解

    2023-06-27 08:54:36
  • Java monitor机制使用方法解析

    2023-11-09 11:25:56
  • List调用toString()方法后,去除两头的中括号实例

    2023-09-28 11:18:56
  • Android WindowManger实现桌面悬浮窗功能

    2023-08-01 02:16:10
  • Java语言实现简单FTP软件 FTP上传下载队列窗口实现(7)

    2021-07-25 04:01:58
  • Seata AT模式TransactionHook被删除探究

    2022-01-12 14:56:49
  • Java 反射机制知识详细介绍及总结

    2023-12-15 01:08:15
  • 使用Flutter实现一个走马灯布局的示例代码

    2023-06-19 03:50:03
  • springboot中PostMapping正常接收json参数后返回404问题

    2021-07-22 20:46:28
  • java compare compareTo方法区别详解

    2022-06-26 08:13:55
  • 使用Jenkins来构建SVN+Maven项目的实现

    2023-07-30 12:45:22
  • Java异常处理try catch的基本使用

    2023-11-24 05:04:38
  • RabbitMQ延迟队列及消息延迟推送实现详解

    2023-11-15 15:31:31
  • 详解SpringBoot如何实现统一后端返回格式

    2022-11-27 05:26:24
  • SrpingDruid数据源加密数据库密码的示例代码

    2021-06-21 03:26:26
  • 详解Java单元测试之Junit框架使用教程

    2022-03-06 02:55:56
  • Java中反射动态 代理接口的详解及实例

    2023-11-28 05:29:36
  • Mybatis中 mapper-locations和@MapperScan的作用

    2023-07-13 08:08:34
  • 详细聊聊SpringBoot中动态切换数据源的方法

    2023-11-24 04:07:49
  • asp之家 软件编程 m.aspxhome.com