日志配置,主要要配置三大项
1.父logger:即rootLogger
2.子logger: 控制一定范围内的日志输出,某个包或类
3. appender:日志输出的目的地,可以是控制台、文件等
logger的继承关系,additivity属性
使A类的日志输出到testA这个appender下,而且不叠加到父logger的日志中
log4j.logger.cn.hancloud.databus.A=DEBUG, testA
log4j.additivity.cn.hancloud.databus.A= false
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
<!-- 区分不同应用程序的记录,默认为default -->
<contextName>hyserver</contextName>
<!-- 定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径 -->
<statusListener class="ch.qos.logback.core.status.NopStatusListener" />
<!-- 获取application-xxx.yaml 中得值,由于logback-spring.xml加载早于application.yaml,故需要通过springProperty -->
<springProperty scope="context" name="logPath" source="hyserver.logger.log-path"/>
<springProperty scope="context" name="logLevel" source="hyserver.logger.level"/>
<springProperty scope="context" name="csvPath" source="extract.plugin.csvPath"/>
<springProperty scope="context" name="maxHistory" source="extract.plugin.maxHistory"/>
<springProperty scope="context" name="maxFileSize" source="extract.plugin.maxFileSize"/>
<springProperty scope="context" name="totalSizeCap" source="extract.plugin.totalSizeCap"/>
<!-- 定义日志文件的存储地址 windows 默认为开发环境, linux 为生产环境 -->
<if condition='p("os.name").contains("Windows")'>
<then>
<property name="LOG_PATH" value="c:/${logPath}" />
<property name="CSV_PATH" value="c:${csvPath}" />
</then>
<else>
<property name="LOG_PATH" value="