我面临一个奇怪的生产问题。环境如下:
- JBOSS 4.0.2
- SQL 服务器 2005
- 驱动程序 JTDS 1.2.5
不时会发生以下情况。
SQL 命令无法执行
java.sql.SQLException: I/O Error: Read timed out
(我可以忍受,如果它每天只发生两次左右)
但是从那一刻起,连接似乎在没有池识别的情况下被浪费了,因为我不断收到
java.sql.SQLException: Invalid state, the Connection object is closed.
从那一刻起。唯一有帮助的是重新启动 JBOSS。尽管我有
<check-valid-connection-sql>select getdate()</check-valid-connection-sql>
在我的数据源定义中设置。
我想知道我是否可以使用自定义的 ValidConnectionChecker,它要么重建连接本身,要么显式抛出异常来解决这个问题。也许有人有其他建议。
这是我完整的 DS 定义。
<local-tx-datasource>
<jndi-name>MyDS</jndi-name>
<connection-url>jdbc:jtds:sqlserver://192.168.35.235:1433/MyDb;user=user1;password=pwd;appName=MyApp;loginTimeout=15;socketTimeout=120</connection-url>
<driver-class>net.sourceforge.jtds.jdbc.Driver</driver-class>
<user-name>user1</user-name>
<password>pwd</password>
<min-pool-size>10</min-pool-size>
<max-pool-size>25</max-pool-size>
<blocking-timeout-millis>60000</blocking-timeout-millis>
<idle-timeout-minutes>1</idle-timeout-minutes>
<check-valid-connection-sql>select getdate()</check-valid-connection-sql>
</local-tx-datasource>
任何帮助appriciated。
问候