Exploring
首页
  • Java

    • 面向对象的思想OOP
    • 浅谈Java反射原理
    • endorsed覆盖JDK中的类
  • 认证与授权

    • LDAP概念和原理介绍
    • OAuth2介绍
  • Impala

    • Impala 介绍
  • MySQL

    • 关于MySQL的一些面试题
    • 解决MySQL不到中文数据
    • 数据库之事务与实现原理
  • Oracle

    • oracle的表空间,用户管理,表操作,函数
    • oracle的查询、视图、索引
    • plsql简单入门
  • Redis

    • 数据类型详解
    • 跳越表
    • 数据持久化的两种方式
  • 共识算法

    • gossip
  • RPC

    • GRPC初识与快速入门
    • ProtocolBuffer基本语法
  • RabbitMQ

    • RabbitMQ入门程序之HelloWorld
    • RabbitMQ之工作模式
  • Zookeeper

    • Zookeeper一文入门
  • Docker

    • Docker入门初体验
  • Maven

    • 把自己的包到Maven中央仓库
    • Maven之自定义插件
  • Nginx

    • nginx的安装
    • nginx的配置文件
    • nignx 的变量
  • Tomcat

    • Servlet3通过SPI进行注册组件
  • Vagrant

    • vagrant 初始化
    • vagrant 常用配置
    • vagrant 自己制作 box
  • Linux

    • 启动方式 Systemd
    • 后台服务
    • 防火墙与 Iptables
  • 设计模式

    • 设计模式-代理
    • 设计模式-单例模式
    • 设计模式-迭代器
  • 分布式

    • CAP 理论
  • 数据结构

    • 数据结构之堆Heap
    • 数据结构之哈希表
    • 数据结构之队列
  • 计算机网络

    • HTTP与HTTPS详解
    • 浅谈DNS协议
    • ISP中的网络层
  • 算法

    • 常用查找算法及Java实现
    • 常用排序算法及Java实现
    • 迪杰斯特拉算法
  • 操作系统

    • 操作系统之进程调度算法
    • 操作系统之进程通讯IPC
    • 操作系统之内存管理
  • 抓包

    • 生成安卓系统证书
  • 加解密

    • 常见加密算法
    • 公开秘钥基础知识
    • RSA 解析
  • Windows

    • scoop 包管理
    • windows-terminal 配置
    • 增强 PowerShell
归档
Github (opens new window)
首页
  • Java

    • 面向对象的思想OOP
    • 浅谈Java反射原理
    • endorsed覆盖JDK中的类
  • 认证与授权

    • LDAP概念和原理介绍
    • OAuth2介绍
  • Impala

    • Impala 介绍
  • MySQL

    • 关于MySQL的一些面试题
    • 解决MySQL不到中文数据
    • 数据库之事务与实现原理
  • Oracle

    • oracle的表空间,用户管理,表操作,函数
    • oracle的查询、视图、索引
    • plsql简单入门
  • Redis

    • 数据类型详解
    • 跳越表
    • 数据持久化的两种方式
  • 共识算法

    • gossip
  • RPC

    • GRPC初识与快速入门
    • ProtocolBuffer基本语法
  • RabbitMQ

    • RabbitMQ入门程序之HelloWorld
    • RabbitMQ之工作模式
  • Zookeeper

    • Zookeeper一文入门
  • Docker

    • Docker入门初体验
  • Maven

    • 把自己的包到Maven中央仓库
    • Maven之自定义插件
  • Nginx

    • nginx的安装
    • nginx的配置文件
    • nignx 的变量
  • Tomcat

    • Servlet3通过SPI进行注册组件
  • Vagrant

    • vagrant 初始化
    • vagrant 常用配置
    • vagrant 自己制作 box
  • Linux

    • 启动方式 Systemd
    • 后台服务
    • 防火墙与 Iptables
  • 设计模式

    • 设计模式-代理
    • 设计模式-单例模式
    • 设计模式-迭代器
  • 分布式

    • CAP 理论
  • 数据结构

    • 数据结构之堆Heap
    • 数据结构之哈希表
    • 数据结构之队列
  • 计算机网络

    • HTTP与HTTPS详解
    • 浅谈DNS协议
    • ISP中的网络层
  • 算法

    • 常用查找算法及Java实现
    • 常用排序算法及Java实现
    • 迪杰斯特拉算法
  • 操作系统

    • 操作系统之进程调度算法
    • 操作系统之进程通讯IPC
    • 操作系统之内存管理
  • 抓包

    • 生成安卓系统证书
  • 加解密

    • 常见加密算法
    • 公开秘钥基础知识
    • RSA 解析
  • Windows

    • scoop 包管理
    • windows-terminal 配置
    • 增强 PowerShell
归档
Github (opens new window)
  • Java

    • 基础

    • 并发与多线程

    • 日志系统

      • 初识Java中的日志
      • 两种常用日志框架搭配快速上手
      • logback介绍
      • logback的架构
      • logback的配置
        • 配置文件的加载
        • 打印配置初始化信息
        • 自动扫描更改并且更新配置文件
        • 启用在堆栈跟踪中显示Jar包信息
        • 停止日志记录
        • 参考
      • logback配置文件语法
      • logback中的Appender
      • logback配置中的Encoder
      • logback中的Layouts
      • logback中的Filter
      • logback中使用MDC
      • logback源码分析
      • 好看的彩色日志输出
    • 单元测试

    • JVM

    • Spring

    • SpringBoot

    • 一些工具

  • 语言
  • Java
  • 日志系统
unclezs
2020-12-03
0
目录

logback的配置

# 配置文件的加载

顺序依次:

  1. classpath下的logback-test.xml
  2. classpath下的logback.groovy
  3. classpath下的logback.xml
  4. 通过SPI机制加载META-INF/services/com.qos.logback.classic.spi.Configurator文件,里面写配置类的全限定类名
  5. 以上都没有则使用自带的BasicConfigurator配置一个控制台输出日志的配置

设置其他方式加载配置文件

  1. 通过vm参数指定配置文件 -Dlogback.configurationFile=/path/to/config.xml
  2. 通过代码内设置
System.setProperty(ContextInitializer.CONFIG_FILE_PROPERTY, "/path/to/config.xml");
1

# 打印配置初始化信息

  1. 手动打印
public static void main(String[] args) {
  Logger logger = LoggerFactory.getLogger("ROOT");
  logger.info("internal info");
  // assume SLF4J is bound to logback in the current environment
  LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();
  // print logback's internal status
  StatusPrinter.print(lc);
  ...
}
1
2
3
4
5
6
7
8
9
  1. 自动打印
<configuration debug="true">
      ...
</configuration>
1
2
3
  1. StatusListener方式

自带的有OnConsoleStatusListener,也可以自己实现

<configuration>
  <statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />  
</configuration>
1
2
3

# 自动扫描更改并且更新配置文件

设置scan为true,则会启动ReconfigureOnChangeTask按照指定周期更新配置。

<configuration scan="true" scanPeriod="30 seconds" > 
  ...
</configuration> 
1
2
3
/**
 * @author blog.unclezs.com
 * @since 2020/12/02 19:54
 */
public class ScanConfigModifySample {
  public static void main(String[] args) throws InterruptedException {
    Logger logger = LoggerFactory.getLogger(ScanConfigModifySample.class);
    while (true) {
      logger.info("scan period by 1 seconds");
      Thread.sleep(2000);
    }
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13

然后修改编译后的target/的配置文件,自动更新。

# 启用在堆栈跟踪中显示Jar包信息

也就是在打印除了打印堆栈信息外还会显示这一栈信息中属于哪个jar包合jar包的版本信息。这个计算代价很高,特别是在异常频繁发生的情况下。

  1. 配置中启用
<configuration packagingData="true">
  ...
</configuration>
1
2
3
  1. 代码中启用
LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();
lc.setPackagingDataEnabled(true);
1
2

# 停止日志记录

代码控制直接停止日志记录器。

LoggerContext context = (LoggerContext) LoggerFactory.getILoggerFactory();
Logger logger = context.getLogger("ROOT");
logger.info("stop start");
context.stop();
//不显示
logger.info("is stop?");
1
2
3
4
5
6

注册日志停止记录的shutdownHook,在独立的Java应用程序中,向配置文件中添加指令是确保JVM退出之前允许任何正在进行的压缩任务完成的简便方法,在web应用中,这个会自动注册,shutdownHook />指令是多余的。

可以通过class来指定自己的showdownHook

<configuration debug="true">
   <shutdownHook/>
  .... 
</configuration>
1
2
3
4

# 参考

Chapter 3: Logback configuration (opens new window)

在 GitHub 编辑此页 (opens new window)
上次更新: 2024/02/25, 12:11:11
logback的架构
logback配置文件语法

← logback的架构 logback配置文件语法→

Theme by Vdoing | Copyright © 2018-2024 unclezs
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式