javaweb之数据库连接池

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");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值