密封冲突:软件包 oracle.jdbc.pool 是密封的 oracle UCP 连接池



我的项目正在使用ojdbc6c3p0连接池。这是我搬到ojdbc8UCP(Oracle's universal connection pooling).但是我得到以下错误:

使用UCP Config

try
{
//Creating a pool-enabled data source
pds= PoolDataSourceFactory.getPoolDataSource();
String dbURL="jdbc:oracle:thin:@(DESCRIPTION = (CONNECT_TIMEOUT= 15)(RETRY_COUNT=20)(RETRY_DELAY=3) (ADDRESS_LIST =(LOAD_BALANCE=on)(ADDRESS = (PROTOCOL = TCP) (HOST = vm-host-101) (PORT = 1521))) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = S1NAME)))";
//this is where am using that package 
pds.setConnectionFactoryClassName("oracle.jdbc.pool.OracleDataSource");
pds.setURL(dbURL);
pds.setUser("username");
pds.setPassword("password");
pds.setInitialPoolSize(5);
pds.setMinPoolSize(5);
pds.setMaxPoolSize(10);
pds.setFastConnectionFailoverEnabled(false);
return pds;
}
catch(SQLException e)
{
e.printStackTrace();
}
return pds;
}

错误:

Caused by: java.sql.SQLException: Unable to create factory class instance with provided factory class name: java.lang.SecurityException: sealing violation: package oracle.jdbc.pool is sealed
at oracle.ucp.util.UCPErrorHandler.newSQLException(UCPErrorHandler.java:456) ~[ucp-12.2.0.1.jar:12.2.0.1.0]
at oracle.ucp.util.UCPErrorHandler.throwSQLException(UCPErrorHandler.java:133) ~[ucp-12.2.0.1.jar:12.2.0.1.0]
at oracle.ucp.jdbc.PoolDataSourceImpl.initConnectionFactory(PoolDataSourceImpl.java:3243) ~[ucp-12.2.0.1.jar:12.2.0.1.0]
at oracle.ucp.jdbc.PoolDataSourceImpl.createUniversalConnectionPool(PoolDataSourceImpl.java:1105) ~[ucp-12.2.0.1.jar:12.2.0.1.0]
... 61 common frames omitted
Caused by: java.lang.SecurityException: sealing violation: package oracle.jdbc.pool is sealed

我知道当我们从同一package加载 2 个class时会出现错误。但是我在intellij中签入了外部依赖项mvn dependency:tree并尝试了maven命令。我在classpath中找不到重复的OJDBC jars.

这还有其他原因吗?

当您classpath中有多个ojdbc*.jar时,通常会发生这种情况。

在您的问题中,您明确表示您已验证没有重复项,但必须有重复项。如果从Maven加载ojdbc8,则需要确保它不是从本地filesystem手动添加的。

ucp.jar也是一样.您可能需要扫描filesystem以查找ojdbc6.jar or ojdbc6dms.jar (or ojdbc8.jar and ojdbc8dms.jar or ojdbc10 - just scan for ojdbc*)并将 jar 重命名为其他名称(或删除它们(。

有时很难看到完整的类路径 - 具体取决于您的框架。在linux a "ps -af" command将显示用于启动java的完整命令行,这些命令行有时会提供有关classpath的有用信息。

相关内容

  • 没有找到相关文章

最新更新