首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >与sybase的Hikari连接池问题

与sybase的Hikari连接池问题
EN

Stack Overflow用户
提问于 2019-10-15 16:16:21
回答 1查看 1.6K关注 0票数 2

我有一个java spring引导应用程序,它使用Spring驱动程序将大量数据插入到sybase。我使用Sybase JDBC驱动程序,并使用DriverManagerDataSource和HikariConnectionPool进行批量插入。数据资源的创建很好,但是当我尝试创建HikariConnectionPool时,它会给出错误连接,关闭错误。下面是您看到的代码.As,我正在执行一个显式调用,以查看connecton是否已关闭并返回false。我无法理解我在这里缺少的是什么。如有任何建议。

源代码

代码语言:javascript
运行
复制
@Configuration
@Profile("local")
public class SpringJDBCLocalConfiguration {

    Logger logger = LoggerFactory.getLogger(SpringJDBCLocalConfiguration.class);


    @Bean(name = "dataSource")
    public DataSource dataSource() {


        DriverManagerDataSource dataSource = new DriverManagerDataSource(){{
            setDriverClassName("com.sybase.jdbc4.jdbc.SybDriver");
            setUrl("url");
            setUsername("username");
            setPassword("passwd");         
        }};;

        try {
            Connection conn = dataSource.getConnection();
            logger.info("SpringJDBCLocalConfiguration conn "+conn);
            logger.info("SpringJDBCLocalConfiguration conn isClosed "+conn.isClosed());

        }
        catch(Exception exc){
            logger.error("SpringJDBCLocalConfiguration error getting connection in SpringJDBCLocalConfiguration "+exc);
        }

        HikariConfig config = new HikariConfig() {{
            setDataSource(dataSource);
            setConnectionTestQuery("SELECT 1");
        }};

        HikariDataSource hikariDataSource = new HikariDataSource(config);
        return hikariDataSource;
    }


    @Bean
    public JdbcTemplate jdbcTemplate(@Qualifier("dataSource") DataSource dataSource) {

        JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource());        
        return jdbcTemplate;
    }
}   

错误堆栈跟踪

代码语言:javascript
运行
复制
[ main] c.j.a.w.e.d.SpringJDBCLocalConfiguration : inside SpringJDBCLocalConfiguration.dataSource method flushStrategy
[ main] com.zaxxer.hikari.HikariConfig : sybase-pool - idleTimeout is close to or more than maxLifetime, disabling it.
[ main] com.zaxxer.hikari.HikariDataSource : sybase-pool - Starting...
[ main] com.zaxxer.hikari.pool.PoolBase : sybase-pool - Driver does not support get/set network timeout for connections. (com.sybase.jdbc4.jdbc.SybConnection.getNetworkTimeout()I)
[ main] com.zaxxer.hikari.pool.HikariPool : sybase-pool - Exception during pool initialization.
 java.sql.SQLException: JZ0C0: Connection is already closed.
 at com.sybase.jdbc4.jdbc.ErrorMessage.raiseError(ErrorMessage.java:779) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.SybConnection.checkConnection(SybConnection.java:4010) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.SybStatement.close(SybStatement.java:744) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.SybStatement.close(SybStatement.java:719) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.MdaManager.loadMetaData(MdaManager.java:573) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.MdaManager.<init>(MdaManager.java:188) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.MdaManager.<init>(MdaManager.java:171) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.SybConnection.checkMDA(SybConnection.java:4155) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.SybConnection.getMDA(SybConnection.java:3685) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.tds.Tds.setOption(Tds.java:1829) ~[jconn4-7.07-27307.jar!/:na]
 at com.sybase.jdbc4.jdbc.SybConnection.setReadOnly(SybConnection.java:2586) ~[jconn4-7.07-27307.jar!/:na]
 at com.zaxxer.hikari.pool.PoolBase.setupConnection(PoolBase.java:409) ~[HikariCP-2.7.9.jar!/:na]
 at com.zaxxer.hikari.pool.PoolBase.newConnection(PoolBase.java:370) ~[HikariCP-2.7.9.jar!/:na]
 at com.zaxxer.hikari.pool.PoolBase.newPoolEntry(PoolBase.java:194) ~[HikariCP-2.7.9.jar!/:na]
 at com.zaxxer.hikari.pool.HikariPool.createPoolEntry(HikariPool.java:460) [HikariCP-2.7.9.jar!/:na]
 at com.zaxxer.hikari.pool.HikariPool.checkFailFast(HikariPool.java:534) [HikariCP-2.7.9.jar!/:na]
 at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:115) [HikariCP-2.7.9.jar!/:na]
 at com.zaxxer.hikari.HikariDataSource.<init>(HikariDataSource.java:81) [HikariCP-2.7.9.jar!/:na]
EN

回答 1

Stack Overflow用户

发布于 2019-10-28 16:13:41

问题是应用程序在云中运行,并且能够建立数据库连接,但是防火墙似乎扼杀了连接,因此在创建连接池时,没有发现导致此错误的活动连接。我试图显式地白化ip地址和端口,但仍然存在相同的问题,但根本原因是防火墙阻塞连接。

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

https://stackoverflow.com/questions/58398871

复制
相关文章

相似问题

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