28

我正在尝试在 Ubuntu 12.X 下的 Tomcat 7 中设置 JDBC 数据源,因此我在 context.xml 文件中添加了以下内容:

<Resource name="jdbc/myDS" auth="Container" type="javax.sql.DataSource"
    maxActive="5" maxIdle="2" maxWait="5000"
    driverClassName="org.postgresql.Driver" username="usr" password="***" url="jdbc:postgresql://localhost:5432/db" />

显然,使用正确且经过测试的数据库用户名和密码。当我重新启动 Tomcat 时,我收到此错误:

Feb 05, 2013 1:10:01 PM org.apache.catalina.core.NamingContextListener addResource
WARNING: Failed to register in JMX: javax.naming.NamingException: Could not create resource factory instance [Root exception is java.lang.ClassNotFoundException: org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory]

我用谷歌搜索,发现 JDBC 驱动程序必须复制到 $CATALINA_HOME/lib 文件夹,所以我将 postgresql-9.2-1000.jdbc4.jar 复制到 /usr/share/tomcat7/lib,但没有帮助. 我尝试将文件复制到其他位置,结果相同。

另一种尝试是将 /usr/share/tomcat7/lib 中的 tomcat-dbcp.jar 符号链接从 ../../java/tomcat-dbcp-7.0.30.jar 更改为 ../../java/tomcat- dbcp.jar。唯一的变化是我只收到一个警告而不是四个,但数据源也不起作用。

爪哇版:

jdoe@sever:~$ java -version
java version "1.7.0_09"
OpenJDK Runtime Environment (IcedTea7 2.3.4) (7u9-2.3.4-0ubuntu1.12.10.1)
OpenJDK 64-Bit Server VM (build 23.2-b09, mixed mode)

任何提示,非常欢迎。

干杯。

4

6 回答 6

38

存储库tomcat-dbcp-7.0.30.jar中的库已损坏。

将其替换为:

sudo wget -O /usr/share/java/tomcat-dbcp-7.0.30.jar http://search.maven.org/remotecontent?filepath=org/apache/tomcat/tomcat-dbcp/7.0.30/tomcat-dbcp-7.0.30.jar

于 2013-04-08T13:46:31.010 回答
26

原因是 Tomcat7 的 Ubuntu 构建/打包过程中存在问题。如果我正确理解了这个问题,Apache 从二进制文件构建 tomcat-dbcp.jar,而 Ubuntu 仅从源代码构建包。Ubuntu 项目最终需要更改 Java 包名称,这往往会给我们这些可怜的用户带来麻烦。血淋淋的细节可以在Ubuntu 问题列表中找到。

我找到的解决方案是在定义资源时给数据源工厂命名。在一种情况下,我有一个 META-INF/context.xml 文件,其中包含:

<Resource name="jdbc/myDataSource"
    auth="Container"
    type="javax.sql.DataSource"
    driverClassName="com.mysql.jdbc.Driver"
    url="jdbc:mysql://localhost:3306/myDatabase"
    username="username" password="password"
    validationQuery="SELECT COUNT(*) FROM MY_TABLE"
    factory="org.apache.commons.dbcp.BasicDataSourceFactory" />

关键元素是“工厂”声明,它覆盖了内置默认值。

在我们的生产机器上,资源在 server.xml 文件的 GlobalNamingResources 元素中定义。仅在 Ubuntu 系统上需要指定工厂。

于 2013-02-16T15:08:32.897 回答
1

我在 CentOS 上遇到了同样的问题。我通过从站点下载一个新的 tomcat 副本并将 tomcat-dbcp.jar 上传到我的在线服务器库来解决这个问题,重新启动服务器:)

于 2014-02-18T14:32:31.333 回答
1

我在使用 Tomcat 7.0.55 的 Fedora 20 上遇到了同样的问题。我在文件路径和文件名中用 7.0.55 替换了 7.0.30,这对我有用。不知道为什么,但是这个文件在 tomcat 7 的 YUM 安装中完全丢失。没有它就不能使用数据库。

于 2014-09-19T19:42:57.303 回答
0

做到了。

确保如果 tomcat-dbcp-7.0.30.jar 文件没有以下大小,那么它可能已损坏,您可能需要用上面的 sudo wget 命令替换它。

-rw-r--r-- 1 根 235411 2013 年 5 月 1 日 tomcat-dbcp-7.0.30.jar

lrwxrwxrwx 1 根 2013 年 1 月 10 日 22 日 tomcat-dbcp.jar -> tomcat-dbcp-7.0.30.jar

于 2014-01-28T20:43:46.480 回答
0

如果您不想修补 tomcat,您也可以(在 CentOS 上)将以下内容添加到 JAVA_OPTS(例如,通过将其添加到 /usr/share/tomcat/conf/context.xml

JAVA_OPTS="-Djavax.sql.DataSource.Factory=org.apache.commons.dbcp.BasicDataSourceFactory"
于 2019-08-06T11:44:57.270 回答