阿里面试官:数据库连接池有必要吗?你对它的底层实现了解过没?

本文探讨了数据库连接池的基本思想,强调了其在分布式系统中的重要性,并以C3P0、DBCP、Druid为例。文章还介绍了如何手写一个简单的数据库连接池,包括接口设计、实现、管道管理及并发控制,通过示例代码展示了其实现过程。
摘要由CSDN通过智能技术生成

前言

数据库连接池的基本思想是:为数据库连接建立一个“缓冲池”,预先在池中放入一定数量的数据库连接管道,需要时,从池子中取出管道进行使用,操作完毕后,再将管道放入池子中,从而避免了频繁的向数据库申请资源,释放资源带来的性能损耗。在如今的分布式系统当中,系统的QPS瓶颈往往就在数据库,所以理解数据库连接池底层构造原理与设计思想是很有益处的。我们常用的数据库连接池有C3P0,DBCP,Druid等,下面我们就来分析下数据库连接池应该有些什么,以及手写一个迷你版的数据库连接

对数据库连接池的一点思考
在这里插入图片描述

第一,数据库连接池中存放的就是数据库操作管道,不仅仅是存放,而且应该是管理这些管道;

第二,应该提供外部配置文件去初始化数据库连接池;

第三,如果一个数据库操作管道已经被占用,那么其他请求是否应该得到这个管道,也就是说我们要考虑多线程并发下,管道的分配问题;

第四,如果做到管道的复用?放回池子中,表示可用,并不是真正的关闭管道;

写一个迷你版数据库连接池

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值