2012-03-09 539 views
1

我想使用BoneCP执行连接池。但我得到了无法加载资源工厂类的日志。 我得到了这个错误日志上Tomcat启动无法加载资源工厂类java.lang.ClassNotFoundException:com.jolbox.bonecp.BoneCPDataSource

SEVERE: Exception processing Global JNDI Resources 
javax.naming.NamingException: Could not load resource factory class [Root exception is java.lang.ClassNotFoundException: com.jolbox.bonecp.BoneCPDataSource] 
    at org.apache.naming.factory.ResourceFactory.getObjectInstance(ResourceFactory.java:81) 
    at javax.naming.spi.NamingManager.getObjectInstance(NamingManager.java:304) 
    at org.apache.naming.NamingContext.lookup(NamingContext.java:793) 
    at org.apache.naming.NamingContext.lookup(NamingContext.java:140) 
    at org.apache.naming.NamingContextBindingsEnumeration.nextElementInternal(NamingContextBindingsEnumeration.java:113) 
    at org.apache.naming.NamingContextBindingsEnumeration.next(NamingContextBindingsEnumeration.java:71) 
    at org.apache.catalina.mbeans.GlobalResourcesLifecycleListener.createMBeans(GlobalResourcesLifecycleListener.java:137) 
    at org.apache.catalina.mbeans.GlobalResourcesLifecycleListener.createMBeans(GlobalResourcesLifecycleListener.java:109) 
    at org.apache.catalina.mbeans.GlobalResourcesLifecycleListener.lifecycleEvent(GlobalResourcesLifecycleListener.java:81) 
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142) 
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:747) 
    at org.apache.catalina.startup.Catalina.start(Catalina.java:595) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) 
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414) 
Caused by: java.lang.ClassNotFoundException: com.jolbox.bonecp.BoneCPDataSource 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:200) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:188) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:251) 
    at org.apache.naming.factory.ResourceFactory.getObjectInstance(ResourceFactory.java:79) 
    ... 17 more 

我已经将资源添加到server.xml中是这样的。

<GlobalNamingResources> 
    <!-- Editable user database that can also be used by 
     UserDatabaseRealm to authenticate users 
    --> 
    <Resource name="UserDatabase" auth="Container" 
       type="org.apache.catalina.UserDatabase" 
       description="User database that can be updated and saved" 
       factory="org.apache.catalina.users.MemoryUserDatabaseFactory" 
       pathname="conf/tomcat-users.xml" /> 

     <Resource type='javax.sql.DataSource' 
       name='demodb' 
      factory='com.jolbox.bonecp.BoneCPDataSource' 
    driverClassName='oracle.jdbc.driver.OracleDriver' 
      jdbcUrl='jdbc:oracle:thin:@localhost:1521:XE' 
      username='system' 
      password='system' 
     idleMaxAge='240' 
    idleConnectionTestPeriod='60' 
    partitionCount='3' 
    acquireIncrement='5' 
    maxConnectionsPerPartition='10' 
    minConnectionsPerPartition='5' 
      statementsCacheSize='50' 
     releaseHelperThreads='5' 
     /> 
    </GlobalNamingResources> 

谁能告诉我问题是什么?

回答

0

该例外说明类com.jolbox.bonecp.BoneCPDataSource未找到。你是否确定该类是由服务器或你的应用程序加载的?

应设在这些jars.

希望这有助于之一,玩得开心!

+0

我正在使用NetBeans,我已经在库中加载了(BoneCP 0.7.1)jar文件,但仍然在服务器启动时出现此错误。 – Hablu 2012-03-12 06:48:15

+0

好的,请确保* BoneCP 0.7.1.jar *由服务器加载,或者通过将其复制到服务器库目录中,或者告诉netbeans将其与项目一起导出。我不知道如何在NetBeans中正确执行此操作,但是我发现[this](http://stackoverflow.com/questions/8096232/how-to-have-netbeans-projects-export-their-dependencies-like-eclipse - ),并希望这会让你走上正轨。干杯! – SimonSez 2012-03-12 09:07:13

+0

好吧,让我们假设我手动在库中添加了该jar文件。 之后,我创建了我的应用程序战争文件。如果我必须在联机服务器上托管该战争文件,那么我如何将该jar文件添加到联机服务器库中? – Hablu 2012-03-12 13:40:26

0

你必须加上此行:

 <pathelement location="/path/bonecp-0.7.1.RELEASE.jar"/> 

到类路径中。如果你想使用Netbeans,请修改路径。

0

有时,错误可能是由于混合罐子。连接池使用自定义类加载器,不会允许来自不同BoneCP/Datanucleus版本的jar。