今天我有一个要求以编程方式更改特定appender的日志级别。用户应该能够通过休息界面或用户输入对话框来设置关卡。我在课堂上玩弄了appender和过滤器,但这不符合我的期望。过滤器列表已经是空的。下面是我配置的简短片段:如何以编程方式更改ThresholdFilter的日志级别?
<?xml version="1.0" encoding="UTF-8" ?>
<Configuration status="warn" name="forum" monitorInterval="30">
<properties>
<property name="logging.statement.pattern">%d{DATE} %-5p %-20.20t %m [|] %l [|] %x [|] %t%n</property>
</properties>
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
</Console>
<RollingFile name="FileLogAppender" fileName="${sys:logging.target.dir}/dicom.log" filePattern="${sys:logging.target.dir}/output-%i.log">
<ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY" />
<PatternLayout>
<Pattern>${logging.statement.pattern}</Pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="10MB" />
</Policies>
<DefaultRolloverStrategy max="10" />
</RollingFile>
</Appenders>
<Loggers>
<Logger name="third.party.package" level="INFO" additivity="false">
<AppenderRef ref="FileLogAppender" />
</Logger>
<Logger name="my.custom.package.internal" level="TRACE" additivity="false">
<AppenderRef ref="FileLogAppender" />
</Logger>
<Logger name="my.standard.package" level="DEBUG" additivity="false">
<AppenderRef ref="FileLogAppender" />
</Logger>
<Root level="INFO">
<AppenderRef ref="Console" />
</Root>
</Loggers>
</Configuration>
我用日志管理类来获取配置,然后首先我想获得通过附加器的名称指定的附加器。但appender不提供过滤器的列表,所以我不能遍历它们以获取ThresholdFilter并设置级别。另一个尝试是直接从配置中获取过滤器列表。但是这个清单似乎每次都是空的。任何人都可以给我一个提示,寻找正确的方法来设置关卡吗?
在此先感谢,哈迪