当前位置:首页 > 开发 > 互联网 > 正文

一些排错方法

发表于: 2014-09-04   作者:文强chu   来源:转载   浏览:
摘要: 1、java.lang.IllegalStateException: Class invariant violation at org.apache.log4j.LogManager.getLoggerRepository(LogManager.java:199)at org.apache.log4j.LogManager.getLogger(LogManager.java:228) at o

1、java.lang.IllegalStateException: Class invariant violation

at org.apache.log4j.LogManager.getLoggerRepository(LogManager.java:199)
at org.apache.log4j.LogManager.getLogger(LogManager.java:228)

at org.apache.log4j.Logger.getLogger(Logger.java:117)

 

这个是log4j的一个已知bug。

org.apache.catalina.loader.WebappClassLoader.ENABLE_CLEAR_REFERENCES这个属性引起。它默认是TRUE,将其设置成FALSE就可以规避这个错误。

这个问题在TOMCAT和Glassfish两个容器里都会出现,不知道其他的会不会。

原因当这个属性为TRUE的时候,会在应用停止的时候会试图将所有为NULL的静态或不可修改字段(final)从已加载类里清除。tomcat下是在catalina.properties文件中添加org.apache.catalina.loader.WebappClassLoader.ENABLE_CLEAR_REFERENCES=false

一些排错方法

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号