Logback JaninoEventEvaluator 将日志事件定向到特定的附加程序
Logback JaninoEventEvaluator to direct log events to a specific appender
我有一个 logback-test xml 如下。我想从控制台和 GENERIC_LOG_FILE 中过滤掉包 org.jdbcds 中的所有日志,并将它们放在附加程序 SQLFILE 下的单独文件中。但它们都不起作用。 org.jdbcdslog 中的所有日志都记录在控制台和 GENERIC_LOG_FILE 中,但不在 appender SQLFILE 中给定的文件下。请帮忙。
<configuration scan="true">
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("org.jdbcdslog")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
</appender>
<appender name="GENERAL_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("org.jdbcdslog")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SQLFILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<!--<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>-->
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("org.jdbcdslog");</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/all_query.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<logger name="org.jdbcdslog.SlowQueryLogger" level="INFO"/>
<logger name="org.jdbcdslog.StatementLogger" level="INFO"/>
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="GENERAL_LOG_FILE" />
<appender-ref ref="ERROR_LOG_FILE" />
<appender-ref ref="PERF_LOG_FILE" />
<appender-ref ref="SQLFILE" />
<appender-ref ref="SLOWQUERY_SQLFILE" />
</root>
更新 1:
这里是修改后的XML
<configuration scan="true">
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
</appender>
<appender name="GENERAL_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>ACCEPT</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="ERROR_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.error.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="PERF_LOG_FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/perf.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/all_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SLOWQUERY_SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/slow_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<logger name="ab.xyz" level="INFO" />
<logger name="bd.xyz" level="INFO" />
<logger name="net.sf.hibernate" level="WARN" />
<logger name="org.springframework" level="WARN" />
<logger name="jdbc.sqlonly" level="ERROR" />
<logger name="Perf" level="INFO" />
<logger name="org.jdbcdslog.SlowQueryLogger" level="INFO" additivity="false">
<appender-ref ref="SLOWQUERY_SQLFILE" />
</logger>
<logger name="org.jdbcdslog.StatementLogger" level="INFO" additivity="false">
<appender-ref ref="SQLFILE" />
</logger>
<logger name="org.jdbcdslog.ConnectionLogger" level="ERROR"/>
<logger name="org.jdbcdslog.ResultSetLogger" level="ERROR"/>
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="GENERAL_LOG_FILE" />
<appender-ref ref="ERROR_LOG_FILE" />
<appender-ref ref="PERF_LOG_FILE" />
</root>
</configuration>
更新 2:
<configuration scan="true">
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
</appender>
<appender name="GENERAL_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>ACCEPT</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="ERROR_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.error.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="PERF_LOG_FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/perf.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/all_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SLOWQUERY_SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/slow_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<logger name="ab.xyz" level="INFO" />
<logger name="cd.xyz" level="INFO" />
<logger name="net.sf.hibernate" level="WARN" />
<logger name="org.springframework" level="WARN" />
<logger name="jdbc.sqlonly" level="ERROR" />
<logger name="Perf" level="INFO" />
<logger name="org.jdbcdslog.SlowQueryLogger" level="INFO" additivity="false">
<appender-ref ref="SLOWQUERY_SQLFILE" />
</logger>
<logger name="org.jdbcdslog.StatementLogger" level="INFO" additivity="false">
<appender-ref ref="SQLFILE" />
</logger>
<logger name="org.jdbcdslog.ConnectionLogger" level="ERROR"/>
<logger name="org.jdbcdslog.ResultSetLogger" level="ERROR"/>
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="GENERAL_LOG_FILE" />
<appender-ref ref="ERROR_LOG_FILE" />
<appender-ref ref="PERF_LOG_FILE" />
<appender-ref ref="SQLFILE" />
<appender-ref ref="SLOWQUERY_SQLFILE" />
</root>
</configuration>
为了实现这个:
I wanted to filter out any logs from package org.jdbcds from console and from GENERIC_LOG_FILE and have them in a seperate file under appender SQLFILE
我认为您不需要使用 Janino,您可以改为将 org.jdbcds
记录器与 SQLFILE
附加程序相关联并使用 additivity=false
以防止将此记录器转发给其他附加程序。
例如:
<!-- direct logging from org.jdbcds to the SQLFILE appender and _only_ to the SQLFILE appender -->
<logger name="org.jdbcds" additivity="false">
<appender-ref ref="SQLFILE" />
</logger>
我有一个 logback-test xml 如下。我想从控制台和 GENERIC_LOG_FILE 中过滤掉包 org.jdbcds 中的所有日志,并将它们放在附加程序 SQLFILE 下的单独文件中。但它们都不起作用。 org.jdbcdslog 中的所有日志都记录在控制台和 GENERIC_LOG_FILE 中,但不在 appender SQLFILE 中给定的文件下。请帮忙。
<configuration scan="true">
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("org.jdbcdslog")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
</appender>
<appender name="GENERAL_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("org.jdbcdslog")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SQLFILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<!--<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>-->
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("org.jdbcdslog");</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/all_query.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<logger name="org.jdbcdslog.SlowQueryLogger" level="INFO"/>
<logger name="org.jdbcdslog.StatementLogger" level="INFO"/>
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="GENERAL_LOG_FILE" />
<appender-ref ref="ERROR_LOG_FILE" />
<appender-ref ref="PERF_LOG_FILE" />
<appender-ref ref="SQLFILE" />
<appender-ref ref="SLOWQUERY_SQLFILE" />
</root>
更新 1:
这里是修改后的XML
<configuration scan="true">
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
</appender>
<appender name="GENERAL_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>ACCEPT</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="ERROR_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.error.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="PERF_LOG_FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/perf.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/all_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SLOWQUERY_SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/slow_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<logger name="ab.xyz" level="INFO" />
<logger name="bd.xyz" level="INFO" />
<logger name="net.sf.hibernate" level="WARN" />
<logger name="org.springframework" level="WARN" />
<logger name="jdbc.sqlonly" level="ERROR" />
<logger name="Perf" level="INFO" />
<logger name="org.jdbcdslog.SlowQueryLogger" level="INFO" additivity="false">
<appender-ref ref="SLOWQUERY_SQLFILE" />
</logger>
<logger name="org.jdbcdslog.StatementLogger" level="INFO" additivity="false">
<appender-ref ref="SQLFILE" />
</logger>
<logger name="org.jdbcdslog.ConnectionLogger" level="ERROR"/>
<logger name="org.jdbcdslog.ResultSetLogger" level="ERROR"/>
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="GENERAL_LOG_FILE" />
<appender-ref ref="ERROR_LOG_FILE" />
<appender-ref ref="PERF_LOG_FILE" />
</root>
</configuration>
更新 2:
<configuration scan="true">
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
</appender>
<appender name="GENERAL_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>ACCEPT</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="ERROR_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/server.abacus.error.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="PERF_LOG_FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>message.contains("TestFinished()")</expression>
</evaluator>
<OnMatch>DENY</OnMatch>
<OnMismatch>NEUTRAL</OnMismatch>
</filter>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator>
<expression>return logger.startsWith("Perf");</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/perf.abacus.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>${user.home}/all_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<appender name="SLOWQUERY_SQLFILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<append>true</append>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss}|%level|%logger|%msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${user.home}/slow_query.%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>14</maxHistory>
</rollingPolicy>
</appender>
<logger name="ab.xyz" level="INFO" />
<logger name="cd.xyz" level="INFO" />
<logger name="net.sf.hibernate" level="WARN" />
<logger name="org.springframework" level="WARN" />
<logger name="jdbc.sqlonly" level="ERROR" />
<logger name="Perf" level="INFO" />
<logger name="org.jdbcdslog.SlowQueryLogger" level="INFO" additivity="false">
<appender-ref ref="SLOWQUERY_SQLFILE" />
</logger>
<logger name="org.jdbcdslog.StatementLogger" level="INFO" additivity="false">
<appender-ref ref="SQLFILE" />
</logger>
<logger name="org.jdbcdslog.ConnectionLogger" level="ERROR"/>
<logger name="org.jdbcdslog.ResultSetLogger" level="ERROR"/>
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="GENERAL_LOG_FILE" />
<appender-ref ref="ERROR_LOG_FILE" />
<appender-ref ref="PERF_LOG_FILE" />
<appender-ref ref="SQLFILE" />
<appender-ref ref="SLOWQUERY_SQLFILE" />
</root>
</configuration>
为了实现这个:
I wanted to filter out any logs from package org.jdbcds from console and from GENERIC_LOG_FILE and have them in a seperate file under appender SQLFILE
我认为您不需要使用 Janino,您可以改为将 org.jdbcds
记录器与 SQLFILE
附加程序相关联并使用 additivity=false
以防止将此记录器转发给其他附加程序。
例如:
<!-- direct logging from org.jdbcds to the SQLFILE appender and _only_ to the SQLFILE appender -->
<logger name="org.jdbcds" additivity="false">
<appender-ref ref="SQLFILE" />
</logger>