SpringBoot——》配置logback日志文件

news/2024/7/8 3:58:40 标签: spring boot, logback, log

推荐链接:
    总结——》【Java】
    总结——》【Mysql】
    总结——》【Redis】
    总结——》【Kafka】
    总结——》【Spring】
    总结——》【SpringBoot】
    总结——》【MyBatis、MyBatis-Plus】
    总结——》【Linux】
    总结——》【MongoDB】
    总结——》【Elasticsearch】

SpringBoot——》配置logback>logback日志文件

  • 一、application.yml
  • 二、logback>logback-spring.xml

一、application.yml

logging:
  # logback>logback.xml配置文件的位置
  config: classpath:logback>logback-spring.xml

logback>logbackspringxml_21">二、logback>logback-spring.xml

log.csdnimg.cn/img_convert/7b1431b5f2e376718c41f204d3e187a7.png" alt="afe57d60960ff0dd151704f3ad96a42a.png" />

log"><?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE xml>
<!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->
<!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true -->
<!-- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。 -->
<!-- debug:当此属性设置为true时,将打印出logback>logback内部日志信息,实时查看logback>logback运行状态。默认值为false。 -->
<configuration scan="true" scanPeriod="10 seconds">

  <property name="CONTEXT_NAME" value="facade-portal" />
  <property name="LOG_PATH" value="logs" />
  <property name="MAX_FILE_SIZE" value="100MB" />
  <property name="MAX_HISTORY" value="30" />
  <!--读取配置中心的属性 -->
  <!-- <springProperty scope="context" name="LOG_PATH_NAME" source="logging.file.name"/> -->
  <!-- <springProperty scope="context" name="springProfile" source="spring.profiles.active" defaultValue="dev"/> -->

  <contextName>${CONTEXT_NAME}</contextName>

  <!--输出到控制台 -->
  <!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,%-5level:级别从左显示5个字符宽度,%logger{50}:表示logger名字最长50个字符,否则按照句点分割,%msg:日志消息,%i索引【从数字0开始递增】 -->
  <appender name="CONSOLE" class="ch.qos.logback>logback.core.ConsoleAppender">
    <filter class="ch.qos.logback>logback.classic.filter.ThresholdFilter">
      <level>INFO</level>
    </filter>
    <encoder>
      <!--在控制台使用caller方式打印堆栈信息有超链接,使用replace去掉换行符-->
      <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %replace(%caller{1}){'\t|Caller.{1}0|\r\n', ''} -- %msg%n</Pattern>
      <!-- 设置字符集 -->
      <charset>UTF-8</charset>
    </encoder>
  </appender>

  <!--所有日志输出到文件 -->
  <appender name="FILE" class="ch.qos.logback>logback.core.rolling.RollingFileAppender">
    <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
    <File>${LOG_PATH}/${CONTEXT_NAME}.log</File>
    <!--日志文件输出格式 -->
    <encoder>
      <!--%logger{50}:表示logger名字最长50个字符,否则按照句点分割。
      %M:输出执行日志请求的方法名。尽量避免使用,除非执行速度不造成任何问题。
      %line:输出执行日志请求的行号。尽量避免使用,除非执行速度不造成任何问题。 -->
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50}.%M\(%line\) -- %msg%n</pattern>
      <charset>UTF-8</charset> <!-- 设置字符集 -->
    </encoder>
    <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
    <rollingPolicy class="ch.qos.logback>logback.core.rolling.TimeBasedRollingPolicy">
      <!-- 日志归档 后面可以加.zip -->
      <fileNamePattern>${LOG_PATH}/${CONTEXT_NAME}-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
      <!--日志文件保留天数 -->
      <maxHistory>${MAX_HISTORY}</maxHistory>
      <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback>logback.core.rolling.SizeAndTimeBasedFNATP">
        <!--文件达到 最大时会被压缩和切割 -->
        <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
      </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
  </appender>

  <!-- ERROR 日志 -->
  <appender name="ERROR_FILE" class="ch.qos.logback>logback.core.rolling.RollingFileAppender">
    <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
    <File>${LOG_PATH}/${CONTEXT_NAME}-error.log</File>
    <encoder>
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50}.%M\(%line\) -- %msg%n</pattern>
            <charset>UTF-8</charset> <!-- 此处设置字符集 -->
        </encoder>
        <rollingPolicy class="ch.qos.logback>logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/${CONTEXT_NAME}_error-%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>${MAX_HISTORY}</maxHistory>
        </rollingPolicy>
        <!-- 此日志文件只记录ERROR级别的 -->
        <filter class="ch.qos.logback>logback.classic.filter.LevelFilter">
            <!-- 指定级别 -->
            <level>ERROR</level>
            <!-- onMatch:意思是>=指定级别 接受 -->
            <onMatch>ACCEPT</onMatch>
            <!-- onMismatch:意思是<指定级别 拒绝 -->
            <onMismatch>DENY</onMismatch>
          <!-- onMatch="ACCEPT" 表示匹配该级别及以上
            onMatch="DENY" 表示不匹配该级别及以上
            onMatch="NEUTRAL" 表示该级别及以上的,由下一个filter处理,如果当前是最后一个,则表        示匹配该级别及以上
            onMismatch="ACCEPT" 表示匹配该级别以下
            onMismatch="NEUTRAL" 表示该级别及以下的,由下一个filter处理,如果当前是最后一个,则不匹配该级别以下的
            onMismatch="DENY" 表示不匹配该级别以下的 -->
        </filter>
    </appender>

    <!-- 异步日志输出看情况配置 -->
    <appender name="ASYNC_FILE" class="ch.qos.logback>logback.classic.AsyncAppender">
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender,最多只能添加一个 -->
        <appender-ref ref="FILE" />
    </appender>
    <appender name="ASYNC_ERROR_FILE" class="ch.qos.logback>logback.classic.AsyncAppender">
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender,最多只能添加一个 -->
        <appender-ref ref="ERROR_FILE" />
    </appender>
    
    <!-- 统一配置日志输出,root标签和logger标签,如果这开启了就把不同环境的关上 -->
    <!-- root标签:相当于开关,只有把定义的appender添加到这里 才会生效有日志 -->
    <!-- <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="ASYNC_FILE" />
        <appender-ref ref="ASYNC_ERROR_FILE" />
    </root> -->
  
    <!-- logger标签:用来设置某一个包或者具体的某一个类的日志打印级别 -->
    <!-- <logger name="com.test.springboot.admin" level="DEBUG" /> -->


    <!-- 配置不同环境的日志输出,root标签和logger标签 -->
    <springProfile name="dev"> 
        <logger name="com.test.dao" level="debug"/> 
        <root level="DEBUG"> 
            <appender-ref ref="CONSOLE" /> 
            <appender-ref ref="ASYNC_FILE" />
            <appender-ref ref="ASYNC_ERROR_FILE" /> 
        </root> 
    </springProfile>

    <springProfile name="prod"> 
        <root level="INFO"> 
            <appender-ref ref="ASYNC_FILE" /> 
            <appender-ref ref="ASYNC_ERROR_FILE" /> 
        </root>
    </springProfile>
</configuration>

http://www.niftyadmin.cn/n/5202289.html

相关文章

【JavaEE初阶】 JavaScript基础语法——壹

文章目录 &#x1f38b;初识JavaScript&#x1f6a9;JavaScript 是什么&#x1f6a9;JavaScript 和 HTML 和 CSS 之间的关系&#x1f6a9;JavaScript 运行过程&#x1f6a9;JavaScript 的组成 &#x1f38d;前置知识&#x1f6a9;第一个JS程序&#x1f6a9;JavaScript 的书写形…

ES7-ES13有何新特性?

目录 ES7 ES8 ES9 ES10 ES11 ES12 ES13 hello&#xff0c;大家好呀&#xff01;之前发布的两篇关于ES6新特性的文章学习完了吗&#xff1f;今天来给大家介绍ES6之后&#xff0c;截止到2022年的ES13每个时期新增的一些新特性&#xff01;快来一起学习吧&#xff01; ES7 …

Mysql查看Binlog文件

前期准备 检查是否开启binlog mysql> SHOW VARIABLES LIKE log_bin; // 或者 mysql> SHOW VARIABLES LIKE log%;ON代表开启&#xff0c;OFF代表关闭。如为OFF需 开启 后才能查看&#xff0c;但只能查看开启之后时间点的。 查看binlog文件有哪些 一般yum安装的mysql…

拼多多商品详情api接口

pdd的反爬虫机制十分严&#xff0c;而很多时候&#xff0c;没办法高效的拿到数据内容响应终端需求&#xff0c;而依赖爬虫就会造成动不动就出现滑块验证&#xff0c;让人很无解&#xff0c;正好&#xff0c;公司有这样的需求&#xff0c;让我负责解决这个问题&#xff0c;刚开始…

html实现计算器源码

文章目录 1.设计来源1.1 主界面1.2 计算效果界面 2.效果和源码2.1 动态效果2.2 源代码 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/134532725 html实现计算器源码&#xff0c;计算器源码&#xff0c;简易计…

Redis的高可用

Redis的高可用&#xff1a; 在集群当中有一个非常重要的指标&#xff0c;提供正常服务的时间的百分比&#xff08;365天&#xff09;99.9% Redis的高可用含义更加宽泛&#xff0c;正常服务是指标之一&#xff0c;数据容量的扩展&#xff0c;数据的安全&#xff0c;在Reid中实…

2024湖南师范大学计算机考研分析

24计算机考研|上岸指南 湖南师范大学 湖南师范大学创建于1938年&#xff0c;位于历史文化名城长沙&#xff0c;是国家“211工程”重点建设大学、国家“双一流”建设高校、教育部普通高等学校本科教学工作水平评估优秀高校。学校拥有6个“十二五”国家重点学科、21个博士学位授…

某60区块链安全之Call函数簇滥用实战一学习记录

区块链安全 文章目录 区块链安全Call函数簇滥用实战一实验目的实验环境实验原理实验内容实验过程 Call函数簇滥用实战一 实验目的 学会使用python3的web3模块 学会以太坊Delegatecall漏洞分析及利用 实验环境 Ubuntu18.04操作机 实验工具 python3 实验原理 call 外部调用…