首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >UCP PoolDataSourceImpl与ConnectionInitializationCallback

UCP PoolDataSourceImpl与ConnectionInitializationCallback
EN

Stack Overflow用户
提问于 2014-04-08 22:02:32
回答 1查看 1.4K关注 0票数 0

我正在尝试用一个PoolDataSourceImpl配置一个UCP PoolDataSourceImpl。这是我的配置:

代码语言:javascript
复制
private static DataSource createDataSource(Properties properties) throws SQLException, UniversalConnectionPoolException {
    UniversalConnectionPoolManager ucpm        = UniversalConnectionPoolManagerImpl.getUniversalConnectionPoolManager();
    PoolDataSource                 pds         = PoolDataSourceFactory.getPoolDataSource();
    final String                   editionName = properties.getProperty("jdbc.editionName", "ora$base");

    pds.registerConnectionInitializationCallback(new oracle.ucp.jdbc.ConnectionInitializationCallback() {
        public void initialize(Connection connection) throws SQLException {
            LOG.debug("Attempting to set edition to: {}", editionName);
            try (Statement statement = connection.createStatement()) {
                statement.executeUpdate("ALTER SESSION SET EDITION = " + editionName);
            }
            LOG.debug("Edition set to: {}", editionName);
        }
    });

    pds.setConnectionFactoryClassName("oracle.jdbc.pool.OracleDataSource");
    pds.setUser(properties.getProperty("jdbc.username"));
    pds.setPassword(properties.getProperty("jdbc.password"));
    pds.setURL(properties.getProperty("jdbc.url"));
    pds.setConnectionPoolName("demo-pool");
    pds.setInitialPoolSize(3);
    pds.setMaxPoolSize(3);
    pds.setValidateConnectionOnBorrow(true);

    LOG.debug("Created DataSource Pool");
    ucpm.createConnectionPool((UniversalConnectionPoolAdapter)pds);
    ucpm.startConnectionPool("demo-pool");

    return pds;
}

但是,从未调用过初始化方法。我在以下Oracle中使用java 1.7.0_51:

ojdbc6.jar - v12.1.0.1.0 ucp.jar - v12.1.0.0.0

通过删除对"registerConnectionInitializationCallback“的调用并将其替换为对"registerConnectionLabelingCallback”的调用,我成功地完成了这项工作,但据我的理解,这将在每次从池中请求连接时而不是在实际创建连接时退出ALTER。

任何帮助使ConnectionInitializationCallback工作将是非常感谢的。

亲切的问候

EN

回答 1

Stack Overflow用户

发布于 2015-04-07 13:19:15

ConnectionInitializationCallback机制似乎是12c发布的"应用连续性“特性的一部分。应用程序的连续性要求您使用以下DataSource实现之一:

  • oracle.jdbc.replay.OracleDataSourceImpl
  • oracle.jdbc.replay.OracleConnectionPoolDataSourceImpl

我还没有亲自尝试过,但我猜如果您使用这些DataSource实现之一,您的ConnectionInitializationCallback就能工作。

如果把它作为标准UCP实现的一部分,就像连接标签一样,那就太好了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22949081

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档