首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C3P0半开连接关闭

C3P0半开连接关闭
EN

Stack Overflow用户
提问于 2018-05-31 13:48:38
回答 1查看 135关注 0票数 0

在我的应用程序中,使用C3P0连接到DB服务器。在这里,DB服务器正在防火墙后面运行。

防火墙有时是错误的,因为TCP连接变得半开着,C3P0认为这些是有效的连接,并试图触发查询。C3P0帮助线程正在接受这些半打开的查询,而应用程序线程则急需连接。

代码语言:javascript
复制
`"com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread-#1" daemon prio=10 tid=0x00007fec0865d000 nid=0xc1fe runnable [0x00007fec4cb66000]
       java.lang.Thread.State: RUNNABLE
        at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.read(SocketInputStream.java:152)
        at java.net.SocketInputStream.read(SocketInputStream.java:122)
        at com.ingres.gcf.dam.IoBuff.fillBuffer(Unknown Source)
        at com.ingres.gcf.dam.IoBuff.next(Unknown Source)
        - locked <0x0000000782455468> (a com.ingres.gcf.dam.InBuff)
        at com.ingres.gcf.dam.InBuff.receive(Unknown Source)
        at com.ingres.gcf.dam.MsgIn.receive(Unknown Source)
        at com.ingres.gcf.dam.MsgConn.receive(Unknown Source)
        at com.ingres.gcf.jdbc.DrvObj.readResults(Unknown Source)
        at com.ingres.gcf.jdbc.JdbcConn.connect(Unknown Source)
        at com.ingres.gcf.jdbc.JdbcConn.<init>(Unknown Source)
        at com.ingres.gcf.jdbc.JdbcDrv.connect(Unknown Source)
        at com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManagerDataSource.java:81)
        - locked <0x0000000780025b10> (a com.mchange.v2.c3p0.DriverManagerDataSource)
        at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:96)
        - locked <0x0000000780025b70> (a com.mchange.v2.c3p0.WrapperConnectionPoolDataSource)
        at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool$1.acquireResource(C3P0PooledConnectionPool.java:89)
        at com.mchange.v2.resourcepool.BasicResourcePool.acquireUntil(BasicResourcePool.java:665)
        at com.mchange.v2.resourcepool.BasicResourcePool.access$500(BasicResourcePool.java:32)
        at com.mchange.v2.resourcepool.BasicResourcePool$AcquireTask.run(BasicResourcePool.java:1206)
        at com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread.run(ThreadPoolAsynchronousRunner.java:368)
    `

有什么工作可以克服这种情况吗?

所使用的数据库是VECTORWISE数据库。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-31 18:12:07

如果套接字读取,从应用程序的角度来看,是无限期挂起的-- Exception既不成功,也不失败-- c3p0唯一能做的事情就是暂停它们并尝试中断它们。

上面显示的失败不是在查询中,而是在Connection获取中。您可以尝试将maxAdministrativeTaskTime设置为超时。显然,如果c3p0无法获取连接,使用DataSource的尝试仍将失败。但是他们应该(最终,经过大量超时,看到acquireRetryAttemptsacquireRetryDelay)显式地中断,使用Exceptions到客户端,而不是永远等待

(这取决于挂起对Thread.interrupt()的敏感性。如果他们不能被打断,maxAdministrativeTaskTime就帮不了什么忙。)

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

https://stackoverflow.com/questions/50625901

复制
相关文章

相似问题

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