如何从Log4j中筛选特定异常



我正在桌面应用程序上实现Java 8的一些新功能,Hibernate 3.6似乎不喜欢它

我给一个接口添加了一个"默认方法",从那以后Hibernate就抛出了:

2014-10-02 14:01:25,538 WARN entity.PojoEntityTuplizer  - could not create proxy factory for:modelo.ChequeTercero
org.hibernate.HibernateException: Javassist Enhancement failed: modelo.ChequeTercero
at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.getProxyFactory(JavassistLazyInitializer.java:169)
at org.hibernate.proxy.pojo.javassist.JavassistProxyFactory.postInstantiate(JavassistProxyFactory.java:65)
Caused by: java.lang.VerifyError: (class: modelo/ChequeTercero_$$_javassist_45, method: _d21getNumeroValor signature: ()Ljava/lang/String;) Illegal use of nonvirtual function call

实现接口的EACH类乘以接口中的EACH默认方法。

由于此日志是Level.WARN,因此每当用户打开应用程序时,它都会在用户身上生成biiiiiiiig日志文件。

我试图制作一些记录器过滤器,但不起作用:

<filter class="org.hibernate.proxy.pojo.BasicLazyInitializer">
<param name="LevelMin" value="FATAL" />
<param name="LevelMax" value="FATAL" />
    </filter>
<filter class="org.apache.log4j.filter.ExpressionFilter">
        <param name="expression" value="EXCEPTION ~= org.hibernate.proxy.pojo.BasicLazyInitializer"/>
        <param name="acceptOnMatch" value="false"/>
    </filter>
    <filter class="org.apache.log4j.varia.StringMatchFilter">
        <param name="StringToMatch" value="org.hibernate.HibernateException: Javassist Enhancement failed"/>
        <param name="AcceptOnMatch" value="false" />
    </filter>
    <!--<filter class="org.apache.log4j.varia.DenyAllFilter"/> -->

我做错了什么?此外,如果我取消对DenyAllFilter的注释,则不再显示日志。

我找到了解决方案-RegexFilter

这是相关的Log4j 2.x配置,它允许我从日志文件控制台附加程序中排除特定消息。

<Appenders>
    <Console name="console" target="System.out">
        <RegexFilter regex=".*(Javassist Enhancement failed|could not create proxy factory for).*" onMatch="DENY" onMismatch="ACCEPT"/>
        <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} %-2p %c{1.} %x - %m%n"/> 
    </Console>
    <File name="logfile" filename="./app.log" append="true">
        <!--Evita cargar en el log el error que tira hibernate por Java 8 (default method en Interfaces)-->
        <RegexFilter regex=".*(Javassist Enhancement failed|could not create proxy factory for).*" onMatch="DENY" onMismatch="ACCEPT"/>
        <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{-1} %X{userName} - %m%n"/> 
    </File>
</Appenders>

使用log4j 1.2,我能够使用Appender中的ExpressionFilter筛选出特定的异常。

<appender name="LOGFILE" class="com.me.RollingFileAppender">
    <param name="File" value="..." />
    ...
    <layout .../>
    <!-- Exclude expected exceptions -->
    <filter class="org.apache.log4j.filter.ExpressionFilter">
        <param name="Expression" value="EXCEPTION ~= 'String found in the exception message'"/>
        <param name="AcceptOnMatch" value="false"/>
    </filter>
</appender>

请参阅http://blog.trifork.com/2011/08/23/filtering-specific-exceptions-when-using-log4j/

公认的答案是使用RegexFilter,这是一个在Log4j2中管理日志过滤的优雅解决方案。

在实现时,遇到了一种需要将特定的Hibernate错误排除在日志之外的情况。在我们的项目中,我们使用的是YAML配置,因此发现在这里分享这种方法很有价值,特别是因为互联网上大多数可用的示例都倾向于关注XML配置。

以下是如何在YAML Log4j2配置中使用RegexFilter的示例:

  Loggers:
    logger:
      - name: org.hibernate.orm.jdbc.batch
        level: ERROR
        Filters:
          # Ignore log events with 'org.hibernate.StaleStateException' exception
          - RegexFilter:
              regex: ".*org.hibernate.StaleStateException.*"
              onMatch: DENY
              onMismatch: NEUTRAL

在上面的例子中,目的是过滤掉与org.hibernate.StaleStateException相关的日志,防止它们被记录。这是在允许捕获来自org.hibernate.orm.jdbc.batch记录器的所有其他error日志的同时实现的。

您可以根据自己的喜好进一步定制。

最新更新