首页 > 作文

Springboot内外部logback多环境配置详解

更新时间:2023-04-04 16:02:24 阅读: 评论:0

目录
一、概述二、项目内外配置三、使用自定义appender四、logback查找配置源码五、案例源码

一、概述

springboot官方文档
springboot 默认读取的是项目内的 resources 中 logback 配置文件。
如果 classpath(resources) 下有logback-test.xml会优先生效,并且会和其他logback文件同时生效。
springboot 默认日志级别是debug,所以在logback初始化之前,会有debug日志输出。

二、项目内外配置

注意:logback-{xxx}.xml不能直接放在resources目录下,否则logback-test.xml会优先生效。

1.application.yml指定 activeprofiles

# spr百家争鸣的意义ing配置spring:  profiles:    active: test

2.activeprofiles指定logback-{xxx}.xml

########## logback-{xxx}.xml 文件打包在项目内部 ##########logging: config: classpath:logback/logback-test.xml########## logback-{xxx}.xml 文件打包在项目外部(去掉classpath) ##########logging: config: /urs/wangfugui/downloads/logback/logback-test.xml

3.logback-{xxx}.xml

<?xml version="1.0" encoding="utf-8"?><configuration>  <!--************************** 测试环境 ****************************-->  <!-- 日志根路径(绝对路径) -->  <!--  <property name="log.bapath" value="/urs/wangfugui/downloads/appname"/>-->  <!-- 日志根路径(相对路径),如果使用外部 tomcat,则日志会在bin目录,需要加../ -->  <property name="log.bapath" value="logs-test"/>  <!-- 日志存放路径 -->  <property name="log.path" value="/" />  <!-- 不同的appender,统一日志输出格式 -->  <property name="log.pattern" value="%d{yyyy-mm-dd hh:mm:ss.sss} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n" />  <!-- 控制台输出 -->  <appender name="console" class="ch.qos.logback.core.consoleappender">    <encoder>      <pattern>${log.pattern}</pattern>    </encoder>  </appender>  <!-- info日志输出 -->  <appender name="file_info" class="ch.qos.logback.core.rolling.rollingfileappender">    <file>${log.bapath}/${log.path}/sys-info.log</file>    <!-- 循环政策:基于时间创建日志文件 -->    <rollingpolicy class="ch.qos.logback.core.rolling.timebadrollingpolicy">      <!-- 日志文件名格式 -->      <filenamepattern>${log.bapath}/${log.path}/sys-info.%d{yyyy-mm-dd}.log</filenamepattern>      <!-- 日志最大的历史 60天 --&g当兵体检要求t;      <maxhistory>60</maxhistory>    </rollingpolicy>    <encoder>      <pattern>${log.pattern}</pattern>    </encoder>    <filter class="ch.qos.logback.classic.filter.levelfilter">      <!-- 过滤的级别 -->      <level>info</level>      <!-- 匹配时的操作:接收(记录) -->      <onmatch>accept</onmatch>      <!-- 不匹配时的操作:拒绝(不记录) -->      <onmismatch>deny</onmismatch>    </filter>  </appender>  <!-- error日志输出 -->  <appender name="file_error" class="ch.qos.logback.core.rolling.rollingfileappender">    <file>${log.bapath}/${log.path}/sys-error.log</file>    <!-- 循环政策:基于时间创建日志文件 -->    <rollingpolicy class="ch.qos.logback.core.rolling.timebadrollingpolicy">      <!-- 日志文件名格式 -->      <filenamepattern>${log.bapath}/${log.path}/sys-error.%d{yyyy-mm-dd}.log</filenamepattern>      <!-- 日志最大的历史 60天 -->      <maxhistory>60</maxhistory>    </rollingpolicy>    <encoder>      <pattern>${log.pattern}</pattern>    </encoder>    <filter class="ch.qos.logback.classic.filter.levelfilter">      <!-- 过滤的级别 -->      <level>error</level>      <!-- 匹配时的操作:接收(记录) -->      旅游销售<onmatch>accept</onmatch>      <!-- 不匹配时的操作:拒绝(不记录) -->      <onmismatch>deny</onmismatch>    </filter>  </appender>  <!-- 自定义appender:用户访问日志输出 -->  <appender name="sys-ur" class="ch.qos.logback.core.rolling.rollingfileappender">    <file>${log.bapath}/${log.path}/sys-ur.log</file>    <rollingpolicy class="ch.qos.logback.core.rolling.timebadrollingpolicy">      <!-- 按天回滚 daily -->      <filenamepattern>${log.bapath}/${log.path}/sys-ur.%d{yyyy-mm-dd}.log</filenamepattern>      <!-- 日志最大的历史 60天 -->      <maxhistory>60</maxhistory>    </rollingpolicy>    <encoder>      <pattern>${log.pattern}</pattern>    </encoder>  </appender>  <!-- 自定义appender :日志级别控制 -->  <logger name="sys-ur" level="info">    <appender-ref ref="sys-ur"/>  </logger>  <!-- 当前系统全局 :日志级别控制 -->  <logger name="com.example" level="info" />  <!-- 第三方系统:spring日志级别控车间主任的职责制 -->  <logger name="org.springframework" level="warn" />  <!-- 第三方系统:关闭kafka日志 -->  <!--<logger name="org.apache.kafka" level="off"/>-->  <!-- 单独指定控制台打印级别 -->  <root level="info">    <appender-ref ref="console" />  </root>  <!-- 指定上面appender的日志打印级别 -->  <root level="info">    <appender-ref ref="file_info" 农行心得体会/>    <appender-ref ref="file_error" />  </root></configuration>

三、使用自定义appender

使用lombok
lombok 内置 @slf4j 、@log4j2 两种日志注解。

@log4j2(topic = "sys-ur")@slf4j(topic = "sys-ur")

不使用lombok

logger logger = loggerfactory.getlogger("sys-ur");

四、logback查找配置源码

org.springframework.boot.logging.logback.logbackloggingsystem

    protected string[] getstandardconfiglocations() {        return new string[]{"logback-test.groovy", "logback-test.xml", "logback.groovy", "logback.xml"};    }

五、案例源码

github : https://github.com/duke147/springboot-logback.git

到此这篇关于springboot内外部logback多环境配置详解的文章就介绍到这了,更多相关springboot logback多环境配置内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-04 16:00:47,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/4d1c8eb0e3015c293350c83aad86e95a.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Springboot内外部logback多环境配置详解.doc

本文 PDF 下载地址:Springboot内外部logback多环境配置详解.pdf

标签:日志   级别   自定义   文件
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图