`

dom4j/log4j造成线程挂起

阅读更多

 

DOM4J线程挂起信息

 

"MyService.91" prio=10 tid=0x00002aab4034b000 nid=0x4df4 waiting for monitor entry [0x00002aab3fddb000]

   java.lang.Thread.State: BLOCKED (on object monitor)

at java.util.zip.ZipFile.getEntry(ZipFile.java:147)

- waiting to lock <0x00002aaab9505aa8> (a java.util.jar.JarFile)

at java.util.jar.JarFile.getEntry(JarFile.java:206)

at java.util.jar.JarFile.getJarEntry(JarFile.java:189)

at sun.misc.URLClassPath$JarLoader.getResource(URLClassPath.java:754)

at sun.misc.URLClassPath$JarLoader.findResource(URLClassPath.java:732)

at sun.misc.URLClassPath.findResource(URLClassPath.java:145)

at java.net.URLClassLoader$2.run(URLClassLoader.java:362)

at java.security.AccessController.doPrivileged(Native Method)

at java.net.URLClassLoader.findResource(URLClassLoader.java:359)

at java.lang.ClassLoader.getResource(ClassLoader.java:958)

at java.lang.ClassLoader.getResourceAsStream(ClassLoader.java:1148)

at org.apache.xerces.parsers.SecuritySupport$6.run(Unknown Source)

at java.security.AccessController.doPrivileged(Native Method)

at org.apache.xerces.parsers.SecuritySupport.getResourceAsStream(Unknown Source)

at org.apache.xerces.parsers.ObjectFactory.findJarServiceProvider(Unknown Source)

at org.apache.xerces.parsers.ObjectFactory.createObject(Unknown Source)

at org.apache.xerces.parsers.ObjectFactory.createObject(Unknown Source)

at org.apache.xerces.parsers.SAXParser.<init>(Unknown Source)

at org.apache.xerces.parsers.SAXParser.<init>(Unknown Source)

at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.<init>(Unknown Source)

at org.apache.xerces.jaxp.SAXParserImpl.<init>(Unknown Source)

at org.apache.xerces.jaxp.SAXParserFactoryImpl.newSAXParser(Unknown Source)

at org.dom4j.io.JAXPHelper.createXMLReader(JAXPHelper.java:50)

at org.dom4j.io.SAXHelper.createXMLReaderViaJAXP(SAXHelper.java:125)

at org.dom4j.io.SAXHelper.createXMLReader(SAXHelper.java:78)

at org.dom4j.io.SAXReader.createXMLReader(SAXReader.java:894)

at org.dom4j.io.SAXReader.getXMLReader(SAXReader.java:715)

at org.dom4j.io.SAXReader.read(SAXReader.java:435)

at org.dom4j.DocumentHelper.parseText(DocumentHelper.java:278)

 

 

参照http://tech.ddvip.com/2009-09/1253614257133975.html避免了getEntry锁的问题,但是又出现新的Blocked

 

"servce-30" prio=10 tid=0x00002aab41afe000 nid=0xbc8 waiting for monitor entry [0x000000004b0b6000]

   java.lang.Thread.State: BLOCKED (on object monitor)

at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:293)

- waiting to lock <0x00002aaabb244290> (a sun.misc.Launcher$AppClassLoader)

at java.lang.ClassLoader.loadClass(ClassLoader.java:248)

at javax.xml.parsers.FactoryFinder.getProviderClass(FactoryFinder.java:111)

at javax.xml.parsers.FactoryFinder.newInstance(FactoryFinder.java:146)

at javax.xml.parsers.FactoryFinder.find(FactoryFinder.java:187)

at javax.xml.parsers.SAXParserFactory.newInstance(SAXParserFactory.java:128)

at org.dom4j.io.JAXPHelper.createXMLReader(JAXPHelper.java:46)

at org.dom4j.io.SAXHelper.createXMLReaderViaJAXP(SAXHelper.java:125)

at org.dom4j.io.SAXHelper.createXMLReader(SAXHelper.java:78)

at org.dom4j.io.SAXReader.createXMLReader(SAXReader.java:894)

at org.dom4j.io.SAXReader.getXMLReader(SAXReader.java:715)

at org.dom4j.io.SAXReader.read(SAXReader.java:435)

at org.dom4j.io.SAXReader.read(SAXReader.java:365)

 

最终解决方案是org.dom4j.io.JAXPHelper的方法

    public static XMLReader createXMLReader(boolean validating,

            boolean namespaceAware) throws Exception {

        //SAXParserFactory factory = SAXParserFactory.newInstance();

SAXParserFactory factory = new org.apache.xerces.jaxp.SAXParserFactoryImpl();

        factory.setValidating(validating);

        factory.setNamespaceAware(namespaceAware);

 

        SAXParser parser = factory.newSAXParser();

 

        return parser.getXMLReader();

    }



    public static org.w3c.dom.Document createDocument(boolean validating,

            boolean namespaceAware) throws Exception {

        //DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

        DocumentBuilderFactory factory = new org.apache.xerces.jaxp.DocumentBuilderFactoryImpl

()

        factory.setValidating(validating);

        factory.setNamespaceAware(namespaceAware);

 

        DocumentBuilder builder = factory.newDocumentBuilder();

 

        return builder.newDocument();

    }

 

LOG4J线程挂起信息

 

"MyService.76" prio=10 tid=0x00002aab40ebf000 nid=0x4d52 waiting for monitor entry [0x000000007a60c000]

   java.lang.Thread.State: BLOCKED (on object monitor)

at org.apache.log4j.Category.callAppenders(Category.java:201)

- waiting to lock <0x00002aaabd724fd0> (a org.apache.log4j.Logger)

at org.apache.log4j.Category.forcedLog(Category.java:388)

at org.apache.log4j.Category.info(Category.java:663)

 

 

dbcp线程挂起信息

 

"MyService-85" prio=10 tid=0x00002aab39af3000 nid=0x68a4 waiting for monitor entry [0x000000005a444000]

   java.lang.Thread.State: BLOCKED (on object monitor)

at org.apache.commons.dbcp.PoolableConnectionFactory.makeObject(PoolableConnectionFactory.java:294)

- waiting to lock <0x00002aaaba871308> (a org.apache.commons.dbcp.PoolableConnectionFactory)

at org.apache.commons.pool.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:974)

at org.apache.commons.dbcp.PoolingDataSource.getConnection(PoolingDataSource.java:96)

at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:880)

分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    DOM4j和log4j例子详解

    DOM4j和log4j简单例子详解,综合网上例子,和大家一起分享。导入Eclipse中就可。谢谢!

    dom4j_1_6_1 完整支持包下载

    dom4j-1.6.1.jar jaxen-1.1-beta-6.jar jaxme-api-0.3.jar jsr173_1.0_api.jar msv-20030807.jar pull-parser-2.1.10.jar relaxngDatatype-20030807.jar xml-apis-2.0.2.jar xpp3-1.1.3.3.jar xsdlib-20030807.jar ...

    log4j和dom4j jar包

    此包包含log4j,dom4j jar包

    dom4j-2.1.3.jar

    dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的软件。 dom4j-2.1.3 XML Document Object Model based on Java ...

    DOM4J jar包 xml解析 所有的dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1包 导入直接使用

    DOM4J jar包 所有的包 xml解析 dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1 导入直接使用

    开发JAR包集合-cxf/dom4j/jaxb/json/jta/jxl

    开发JAR包集合-cxf/dom4j/jaxb/json/jta/jxl 解压文件得到如下jar包 cxf-2.2.8.jar dom4j-1.6.1.jar ehcache-core-2.2.0.jar jaxb-api-2.2.jar jaxb-impl-2.2.jar json-lib-2.4-jdk15.jar json-lib-ext-...

    dom4j dom4j dom4j dom4j

    dom4j dom4j dom4j dom4j dom4j dom4j

    dom4j-2.1.1-API文档-中英对照版.zip

    赠送jar包:dom4j-2.1.1.jar; 赠送原API文档:dom4j-2.1.1-javadoc.jar; 赠送源代码:dom4j-2.1.1-sources.jar; 赠送Maven依赖信息文件:dom4j-2.1.1.pom; 包含翻译后的API文档:dom4j-2.1.1-javadoc-API文档-...

    JavaEE源代码 dom4j-1.6.1

    JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源...

    log4j和dom4j插件

    log4j dom4j 插件 以及log4j\dom4j的相关例子和帮助文档

    poi-3.9的jar包,包含dom4j/stax-api-1.0.1/xmlbeans-2.3.0

    poi-3.9的jar包,包含dom4j/stax-api-1.0.1/xmlbeans-2.3.0

    dom4j-2.1.1-API文档-中文版.zip

    赠送jar包:dom4j-2.1.1.jar; 赠送原API文档:dom4j-2.1.1-javadoc.jar; 赠送源代码:dom4j-2.1.1-sources.jar; 赠送Maven依赖信息文件:dom4j-2.1.1.pom; 包含翻译后的API文档:dom4j-2.1.1-javadoc-API文档-...

    dom4j-1.6.1 与 dom4j-2.0.0-ALPHA

    dom4j-1.6.1.zip与 dom4j-2.0.0-ALPHA-2.jar

    Dom4j-1.6.1 API文档.chm

    dom4j 1.6.1 API,dom4j是一个优秀的xml解析工具包

    dom4j_dom4j1.6.1安装包_

    maven dom4j 1.6.1安装包

    Dom4j 1.6.1 JAVA API

    dom4j帮助文档 官方API All Classes Packages org.dom4j org.dom4j.bean org.dom4j.datatype org.dom4j.dom org.dom4j.dtd org.dom4j.io org.dom4j.jaxb org.dom4j.rule org.dom4j.rule.pattern org.dom...

    dom4j-1.6.1.jar (dom4j) 欢迎下载

    dom4j-1.6.1.jar,Dom4j是一个Java的XML API接口,是jdom的进化版,dom4j基本用来读写xml文件,是一个十分优秀的JavaXML API接口

    dom4j-1.6.1.jar.zip

    mvn install:install-file -Dfile=d:\Downloads\dom4j-1.6.1.jar -DgroupId=org.dom4j -DartifactId=dom4j -Dversion=1.6.1 -Dpackaging=jar &lt;groupId&gt;org.dom4j&lt;/groupId&gt; &lt;artifactId&gt;dom4j&lt;/artifactId&gt; ...

    DOM4J帮助文档及使用教程

    这个压缩包是一个关于DOM4J的压缩包,里面包含了DOM4J的帮助文档,DOM4J的使用教程,以及DOM4J这个JAVA包。保证这个压缩包是网上面最全的有关DOM4J的文档。

    资源jar包dom4j-1.6.1.rar

    dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的...

Global site tag (gtag.js) - Google Analytics