目录
1.为什么需要连接池呢?
-
Java程序操作数据库,必须获得一个连接Connection
-
实际操作中,我们要先获得连接,使用完成后还有关闭连接。这两个操作都比较耗时。
-
思考:那有没有什么比较方便不耗时的方法呢?当我们要用的时候只需要调用一下就ok,用完了再还回去。这样岂不是免去了【获得、关闭连接】节省了很多时间?那应该怎么实现呢?
-
答疑:连接池,就是用于解决这一问题而被需要的。连接池,将我们所需要的连接,放入池子里,形成公共连接。且该池子中的连接被调用时,有且只能被一个人使用,当该连接被归还时,即可恢复为公共连接,被别人重新调用。
2.什么是连接池
-
一组连接组成的一个池子(集合),称为连接池。
-
1接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。
-
-
在描述连接池的工作原理前,先思考思考几个问题???
问题1:连接池中的连接一开始有几个?
问题2:如果新添加了连接,一次能添加几个?
问题3:如果需要的连接比池子中的连接多,该怎么办?
问题4:是否可以无限添加连接?
问题5:如果都归还连接呢?
3. 问题解答:
- 问题1:一开始连接池会进行系统初始化,根据系统配置建立,并创建几个连接对象【初始化】
- 问题2:添加的新连接不能超过最大连接数
- 问题3:自动创建即可。
如果初始化只有3个连接,但我现在需要第4个连接,该怎么办呢?
第4个连接我们可以自动创建,但是随着我们的需求越来越多,自动创建连接可以无限创建吗?
不能,因为连接池中有最大连接数,最大连接数限制了连接的个数,超过了最大连接数就会报错,栈内存溢出异常
- 问题4:不能,有最大连接数。最大连接数限制了连接的个数,不能超过最大连接数,不然会报栈内存溢出异常。
- 问题5:因为有最小连接数,所有不能让池子全部空闲,占内存。所以池子中总是有这么几个连接【最小连接数】在等待着被人连接使用
3. 连接池的工作原理
-
下面我们用图片的形式,模拟一下连接池的工作原理