gpt4 book ai didi

postgresql - OSGI & Apache Commons-DBCP 类加载问题

转载 作者:行者123 更新时间:2023-11-29 12:06:53 26 4
gpt4 key购买 nike

我继承了一些在 OSGi 包中使用 Apache commons-dbcp 连接池的代码。此代码适用于 Eclipse/Equinox OSGi 版本 3.4.3 (R34x_v20081215)、commons-dbcp 1.2.2 和来自 springsource.org 的 postgres jdbc3 8.3.603 包。

我想现代化,也许这是我的第一个错误!

当我将新版本的 Felix 或 Equinox OSGI 核心与新的 postgresql JDBC3 或 JDBC4 bundle 以及最新版本的 commons-dbcp (1.4.1) 一起使用时,我遇到了类加载问题。我做了很多搜索,发现 commons-dbcp 代码应该有一个修复 DBCP-214 , 但它似乎仍然失败。

我试图将 org.postgresql 放在 commons-dbcp MANIFEST.MF import-package 行上,但这也不起作用。

我在激活器中编写了一个简单的测试,它首先执行基本的 class.forName() 和 DriverManager.getConnection(),这工作正常,但是当我添加 BasicDataSource() 并设置与 BasicDataSource.getConnection() 的连接时,我得到了 ClassNotFoundException。请参阅下面的代码示例。

在此先感谢您的帮助、建议...

秀!

// This one fails with an exception
public void dsTest() {
BasicDataSource bds = new BasicDataSource();
ClassLoader cl;

try {
logger.debug("ContextClassLoader: {}",
Thread.currentThread().getContextClassLoader().toString());
cl = this.getClass().getClassLoader();
logger.debug("ClassLoader: {}", cl);

if (bds.getDriverClassLoader() != null) {
logger.debug(bds.getDriverClassLoader().toString());
}
// The failure is the same with and with the setDriverClassLoader() line
bds.setDriverClassLoader(cl);
bds.setDriverClassName("org.postgresql.Driver");
bds.setUrl("jdbc:postgresql://127.0.0.1/dbname");
bds.setUsername("user");
bds.setPassword("pword");
Class.forName("org.postgresql.Driver").newInstance();
conn = bds.getConnection();
Statement st = conn.createStatement();
ResultSet rs = st.executeQuery("SELECT COUNT(*) FROM table");
conn.close();
logger.debug("Closed DataSource Test");
} catch (Exception ex) {
ex.printStackTrace();
logger.debug("Exception: {} ", ex.getMessage());
}
}

// This one works
public void managerTest() {
ClassLoader cl;
try {
cl = this.getClass().getClassLoader();
logger.debug("ClassLoader: {}", cl);
Class.forName("org.postgresql.Driver").newInstance();
String url = "jdbc:postgresql://127.0.0.1/dbname";
conn = DriverManager.getConnection(url, "user", "pword");

Statement st = conn.createStatement();
ResultSet rs = st.executeQuery("SELECT COUNT(*) FROM table");
conn.close();
logger.debug("Closed Manger Test");
} catch (Exception ex) {
ex.printStackTrace();
logger.debug("Exception: {} ", ex.getMessage());
}
}

最佳答案

这是因为 commons-dbcp 包无法查看实际的驱动程序类,因为 osgi 类加载器。解决方案是使用 Dynamic Import * 将片段附加到 commons-dbcp 类。您在 MANIFEST 中需要的实际 header 如下:

片段宿主:org.apache.commons.dbcp动态导入包:*

在此之后,您提到的代码起作用了。希望这不会来得太晚。

关于postgresql - OSGI & Apache Commons-DBCP 类加载问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2502308/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com