[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]DriverManager.getConnection可能会导致线程挂起

上一篇:[备忘]spring的service里,开新线程,事务是无法传播过去的。
下一篇:[备忘]spring修改事务级别

添加日期:2016/7/11 23:34:32 快速返回   返回列表 阅读2936次
如题吧,原因类似于socket挂起,

服务端闪断,未来得及通知客户端断开连接,客户端就傻乎乎的一直等~~

当然,socket可以设置timeout……

-------------------
jdbc driver同样也是socket与数据库通信的,

一样,socket可能挂起,

但是,通过DriverManager.getConnection是没有超时设置的,

解决办法大概是这样吧,没法尝试啊:

(1)在jdbc连接串上加connectTimeout=3000,单位是毫秒?我说的是mysql啊,看文档吧。

(2)通过DriverManager话,可以传Properties 

Properties properties = new Properties();
properties.put("connectTimeout", "2000");

(3)spring配置数据源的话,可以这样吧:
 <property name="socketTimeout" value="2000"/>

具体看文档,这里只是大概的示意。
-------------------
感受就是:防不胜防啊……

开始是http请求没加超时,结果线程憋死……

这回又变成mysql取连接时憋死了……

赶紧上连接池,伤不起啊~~
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved