有什么方法可以覆盖 logback 配置吗?我知道我们在名为的文件中定义了 logback 配置logback.xml
(通常存储在路径中src/main/resources
)并且我知道通过使用<include>
我们可以设置要添加的外部文件标记logback.xml
就像下面这样:
<configuration>
<!--<include url="file:///d:/ServerConfig.xml"/>-->
<include file="${outPut}/ServerConfig.xml"/>
<logger name="Server" LEVEL="DEBUG">
<appender-ref ref="FILEOUT" />
</logger>
<root level="DEBUG">
<appender-ref ref="STDOUT" />
<!--<appender-ref ref="FILEOUT" />-->
</root>
</configuration>
但是如果我想覆盖这个默认配置怎么办?例如,将根记录器级别设置为 INFO。
这是包含的文件:
<included>
<!-- <property file="d:/ServerSysVar.properties"/>-->
<property file="${outPut}/ServerSysVar.properties"/>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<!-- encoders are assigned the type
ch.qos.logback.classic.encoder.PatternLayoutEncoder by default -->
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<appender name="FILEOUT" class="ch.qos.logback.core.FileAppender">
<file>${Sys_Location}/Serverfile4.log</file>
<!-- encoders are assigned the type
ch.qos.logback.classic.encoder.PatternLayoutEncoder by default -->
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} %class{36}.%M %L CLIENT_PORT:%X{ClientPort}- %msg%n</pattern>
</encoder>
</appender>
<logger name="Service" LEVEL="DEBUG">
<appender-ref ref="FILEOUT" />
</logger>
<root>
<appender-ref ref="STDOUT" />
<!-- <appender-ref ref="FILEOUT" />-->
</root>
</included>
我不认为你可以覆盖logback.xml
-来自包含文件的定义。
但我有一种方法可以解决您关于覆盖 root-logger-level 的问题,使用变量替换 http://logback.qos.ch/manual/configuration.html#variableSubstitution使用默认值:
日志记录文件
<configuration>
<include file="includedFile.xml" />
<!-- STDOUT appender stuff -->
<root level="${root.level:-DEBUG}">
<appender-ref ref="STDOUT" />
</root>
<configuration>
包含文件.xml
<included>
<!-- override the default value; or comment out to leave it at default -->
<property name="root.level" value="INFO" />
</included>
有了这个概念,我什至能够控制包含文件中多个附加程序的输出:
日志记录文件
<configuration>
<include file="includedFile.xml" />
<!-- STDOUT appender stuff -->
<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>${file.level:-ALL}</level>
</filter>
<file>/path/to/logfeil.log</file>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<appender name="SYSLOG" class="ch.qos.logback.classic.net.SyslogAppender">
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>${syslog.level:-OFF}</level>
</filter>
<syslogHost>localhost</syslogHost>
<facility>${syslog.facility:-LOCAL1}</facility>
<suffixPattern>${syslog.pattern:-[%thread] %logger{36} - %msg}</suffixPattern>
</appender>
<logger name="my.package" level="${logging.level:-INFO}" additivity="false">
<appender-ref ref="FILE" />
<appender-ref ref="SYSLOG" />
</logger>
<root level="${root.level:-DEBUG}">
<appender-ref ref="STDOUT" />
</root>
<configuration>
并且在includedFile.xml
我可以控制消息是否以及在什么级别通过附加程序FILE
and SYSLOG
,设置属性file.level
, syslog.level
而且当然logging.level
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)