我的项目正在使用ojdbc6
和c3p0
连接池。这是我搬到ojdbc8
和UCP(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
的有用信息。