1.原理
应用初始化阶段根据driver(Class.forName(driver)),
url,username,password(DriverManager.getConnection(url, username,password)
创建多个连接,然后将连接添加到LinkedList<Connection>中,
当需要conn时,从List中获取getConnection()单个conn (list.removeFirst())
当调用conn.close()时,将conn返回到List中
当min不够用时,连接池中新建connection,但不超过max
当连接数超过max时,排队
2.开源连接池
- DBCP 数据库连接池
- C3P0 数据库连接池
3.tomcat连接池
- 在META-INF目录下新建context.xml文件配置连接池
<Context>
<Resource
name="jdbc/datasource"
auth="Container"
type="javax.sql.DataSource"
username="root"
password="XDP"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/jdbcstudy"
maxActive="8"
maxIdle="4"/>
</Context>
- 将mysql驱动包添加到tomcat的lib目录下
- 在JNDI容器中获取连接池
(tomcat会将连接池发布到JNDI容器中,JNDI容器以 名称-资源 形式保存资源)
Context initCtx = new InitialContext();
Context envCtx = (Context) initCtx.lookup("java:comp/env");
dataSource = (DataSource)envCtx.lookup("jdbc/datasource");
本文介绍数据库连接池的工作原理,包括应用初始化阶段如何根据driver、url、username和password创建多个连接并将其添加到连接池中。此外,还介绍了两种常见的开源连接池:DBCP和C3P0,并详细说明了如何在Tomcat服务器中配置和使用内置连接池。
1152

被折叠的 条评论
为什么被折叠?



