`

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例子详解

    在提供的"TestDom4jLog4j"项目中,应该包含了使用DOM4j处理XML和log4j记录日志的示例代码,通过阅读和运行这些代码,可以更好地理解DOM4j和log4j的使用方法。对于初学者来说,这是一个很好的实践和学习资源。

    log4j和dom4j jar包

    在Java开发领域,`log4j`和`dom4j`是两个非常重要的库,它们分别专注于日志管理和XML处理。下面将详细讲解这两个库的功能、用途以及如何使用。 首先,`log4j`是一个开源的日志记录框架,由Apache软件基金会开发。它...

    dom4j-1.6.1.zip

    《深入理解DOM4J:XML解析利器》 在IT领域,XML(eXtensible Markup Language)作为一种数据交换和存储的格式,广泛应用于系统间的数据交互。为了方便地解析和操作XML文档,DOM4J应运而生。本文将详细探讨DOM4J库...

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

    在项目中使用DOM4J时,只需将相应的jar包(如dom4j-1.6.1.jar、dom4j-2.0.2.jar或dom4j-2.1.1.jar)导入到类路径中,即可开始利用其功能处理XML文档。导入后,可以按照DOM4J提供的API进行编程,快速实现XML的读写...

    dom4j_dom4j1.6.1安装包_

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效的API,使得XML的解析、创建、查询和修改变得更为简单。在本文中,我们将深入探讨DOM4J 1.6.1版本的安装及其在Maven项目中的应用。 首先,DOM4J...

    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 ...

    dom4j-1.6.1 与 dom4j-2.0.0-ALPHA

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效的API,使得XML的解析、创建、修改和查询变得简单。这次我们有两个版本的DOM4J库:1.6.1和2.0.0-ALPHA。这两个版本在功能、性能和API设计上都有所...

    dom4j_1.6.1.jar dom4j_2.1.0.jar

    标题提及的"dom4j_1.6.1.jar"和"dom4j_2.1.0.jar"是两个不同版本的DOM4J库的Java档案文件,DOM4J是一个非常流行的Java XML API,用于处理XML文档。这两个版本的差异在于功能、性能优化和可能存在的bug修复。描述中...

    dom4j-2.1.3.jar

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

    dom4j dom4j dom4j dom4j

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单易行。在Java世界中,DOM4J是与DOM、SAX和JDOM等其他XML处理库并驾齐驱的一个选择,尤其在处理...

    dom4j-2.1.3.zip

    另一份重要的资源是"dom4j-2.1.3-sources.jar",它提供了DOM4J库的源代码,允许开发者深入研究DOM4J的内部实现,对于理解DOM4J的工作原理、进行扩展或者调试都是不可或缺的。通过阅读源代码,开发者可以学习到如何...

    开发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/JDOM对XML的操作

    DOM4J和JDOM是Java中处理XML的主要库,提供了XML的解析、创建和修改功能。 JDOM是Java中一个专注于XML处理的库,它提供了一种简单和直接的方式来构建和操作XML文档。在提供的`parse()`方法中,可以看到如何使用JDOM...

    log4j和dom4j插件

    `log4j`和`dom4j`就是分别在这两个领域中非常流行的工具。本文将详细讲解这两个插件的功能、用法以及它们在实际开发中的应用场景。 首先,我们来了解`log4j`。`log4j`是由Apache软件基金会开发的一款Java日志框架,...

    dom4j dom4j1.6 dom4j最新版

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J 1.6是该库的一个较新版本,提供了完整的功能集以及对XML标准的广泛支持。 DOM4J的核心...

    dom4j-2.0.3.zip

    《深入解析DOM4J——基于Java的XML处理框架》 DOM4J,作为一个强大的Java XML API,是处理XML文档的主流工具之一。它提供了一套简单而高效的方式来操作XML文档,包括读取、写入、修改和遍历XML结构。在Java开发中,...

    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工具包

    标题提到的"所有版本的dom4j工具包"表明这是一个包含多版本DOM4J库的集合,可能包括了从早期到较新的一些版本,如dom4j-1.4.jar、dom4j-1.6.1.jar和dom4j-1.5.2.jar。这些不同版本的库可能分别对应于不同的功能特性...

    dom4j.jar 下载

    DOM4J是一个强大的Java库,专门用于处理XML文档。它是一个灵活且高性能的XML解析器,提供了丰富的API来创建、修改和操作XML数据。在Java应用程序中,DOM4J作为一个流行的选择,尤其在处理复杂的XML结构时,因为它...

    dom4j所依赖的所有jar包

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了简单而直观的API,使得开发者可以方便地读取、写入、修改以及操作XML文件。DOM4J 1.6.1是这个库的一个稳定版本,发布于较早时期,但依然广泛应用于许多Java...

Global site tag (gtag.js) - Google Analytics