首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java: JDBC数据库连接池

Java: JDBC数据库连接池
EN

Stack Overflow用户
提问于 2011-07-21 01:01:25
回答 2查看 1.6K关注 0票数 1

嗨:我有一个多线程Java数据库应用程序,我们必须创建一个自定义的数据库池。原因是我们的一些准备好的语句必须缓存在连接中。我们的原始解决方案基于一个免费的hashmap,另一个锁定的hashmap。使用hashmap,我们必须使用同步的方法,那么我们的吞吐量就会受到影响。选择是使用concurrentHashMap,这样同步部分就会尽可能小。有没有一些示例代码?或者我应该下载apache DBCP源代码来阅读?

EN

回答 2

Stack Overflow用户

发布于 2011-07-21 01:22:55

使用synchronized将花费您大约1-2微秒。如果这对您很重要,那么您就不应该使用JDBC。我的天。仅仅通过TCP连接访问服务就可能花费100微秒,而许多JDBC数据库的延迟为1-10毫秒。

我怀疑每次查询/更新几毫秒就可以了,在这种情况下,使用同步不太可能有什么问题。

根据您有多少个线程,您可以为每个线程提供一个线程本地连接。这尽可能地减少了开销。

票数 1
EN

Stack Overflow用户

发布于 2011-07-21 01:31:28

您有一个多线程应用程序,但是是否有许多线程同时使用相同的数据库连接?由于PreparedStatement缓存将在连接级完成,如果您的连接同时由单个线程使用(我认为应该是这样),则不需要同步。

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

https://stackoverflow.com/questions/6765630

复制
相关文章

相似问题

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