这篇文章给大家分享的是有关Springboot内外部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
# Spring配置
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: /Users/wangfugui/Downloads/logback/logback-test.xml
3.logback-{xxx}.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!--************************** 测试环境 ****************************-->
<!-- 日志根路径(绝对路径) -->
<!-- <property name="log.basePath" value="/Users/wangfugui/Downloads/appname"/>-->
<!-- 日志根路径(相对路径),如果使用外部 tomcat,则日志会在bin目录,需要加../ -->
<property name="log.basePath" 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.basePath}/${log.path}/sys-info.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.basePath}/${log.path}/sys-info.%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>INFO</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<!-- ERROR日志输出 -->
<appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.basePath}/${log.path}/sys-error.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.basePath}/${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-user" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.basePath}/${log.path}/sys-user.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 按天回滚 daily -->
<fileNamePattern>${log.basePath}/${log.path}/sys-user.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<encoder>
<pattern>${log.pattern}</pattern>
</encoder>
</appender>
<!-- 自定义appender :日志级别控制 -->
<logger name="sys-user" level="info">
<appender-ref ref="sys-user"/>
</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>
使用Lombok
Lombok 内置 @Slf4j 、@Log4j2 两种日志注解。
@Log4j2(topic = "sys-user")
@Slf4j(topic = "sys-user")
不使用Lombok
Logger logger = LoggerFactory.getLogger("sys-user");
org.springframework.boot.logging.logback.LogbackLoggingSystem
protected String[] getStandardConfigLocations() {
return new String[]{"logback-test.groovy", "logback-test.xml", "logback.groovy", "logback.xml"};
}
感谢各位的阅读!关于“Springboot内外部logback多环境配置的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。