数据库连接池为什么要用ThreadLocal呢?
1、【建议收藏】面试官会问的位运算奇淫技巧 2、Top 16 的 Java 工具类,你用过几个? 3、到底可不可以用 kill -9 关闭程序? 4、IDEA 2021首个大版本发布,新增了这几个超实用功能! 5、Optional 是个好东西,你真的会用么?
来源:blog.csdn.net/qq_42405666/article/details/108258820
1、两者有根本性的区别,用处不一样!
2、重点要理解“连接池”。
题外话:如果直接通过 Java原生API 获取“直连”的话:
java.sql.DriverManager.getConnection(url, props);
java.sql.Driver.connect(url, props);
PS:所以说:使用数据库连接池时,还是要显式的调用数据库连接池API提供的关闭连接的方法。
不同的线程在同一个时间( 或者 同一个线程在多个地方)从连接池中拿到的Connection,肯定不是同一个连接。(反过来讲:不同时间的两个线程,一前一后,则有可能拿到同一个连接)
总结:
首先,我们为了避免单一数据库连接的创建和关闭耗费时间和性能,引入了数据库连接池,提前创建好了n条连接放入池中,如果是单线程情况下,那这样挺好的 那如果是多线程情况下呢?还是上面那段话,假设同一时间多个线程从数据库连接池获取连接,那肯定拿的是不同的连接,我当前线程和别的线程拿的连接不一样,那我当前在crud的时候,不在一个事务之内。 假设不同时间的多个线程要从数据库连接池拿连接,那这个时候就可能拿到的是同一个连接了,那我多个线程线程拿到的是同一个连接,也就是说在多个线程在同一个事务之内,线程a执行了插入还没来得及提交,线程b此时来了个更新,在线程a还未操作完之前,线程b更新完了后,直接把连接给close了,线程a插了一半发现插不了了。。。此时肯定在想,这™是谁在搞我。 为了确保不同时间多个线程可能拿到的是同一个连接,那么此时threadlocal闪亮登场,就算我拿的是“同一个连接”,在引入了threadlocal后,每个线程之间都会创建独立的连接副本,将collection各自copy一份,这样就互相不干扰了。
以上是我的个人见解。
往期热门文章:
1、《历史文章分类导读列表!精选优秀博文都在这里了!》
2、七种方式教你在Spring Boot初始化时搞点事情
3、ConcurrentHashMap有十个提升性能的地方,你都知道吗? 4、程序员等级图鉴 5、Java 中的 Switch 都支持 String 了,为什么不支持 long? 6、为什么数据库字段要使用NOT NULL? 7、CTO 说了,用错 @Autowired 和 @Resource 的人可以领盒饭了 8、程序员离职事件始末
9、别总写代码,这130个网站比涨工资都重要 10、程序员养生指北
评论