proxool mysql_数据库连接池(proxool)的使用

0 为什么要用数据库连接池?

数据库连接是非常占用资源的,尤其是在高并发的情况下,如果每次都去建立数据库连接就会有性能问题,也会影响一个应用程序的延展性,针对这个问题,连接池出现了,连接池就是为了解决这个问题的。

1 数据库连接池原理

数据库连接池负责分配、管理、释放连接,它保证应用程序可以重复使用同一个连接而不需要每次都建立数据库连接,如果数据库连接时间超过设置的最长数据库连接时间会自动释放链接,为了避免因为没有释放链接而导致的数据库连接遗漏,因此,数据库连接池可以明显的提高数据库的连接性能。

数据库连接池在初始化的时候会放入一定数量的连接,这个连接是由最小连接数决定的,就算没有用到这些连接,这个连接也会放在连接池中。如果连接数超过最大连接数,那么会放入队列中等待释放链接再使用。

通俗讲(个人理解)在连接数据库之前, 事先准备好一些数据库连接对象, 放在这个数据库连接池里(好比就是一个池子).等到要使用数据库连接时直接从连接池中获取就行, 不再直接与数据库相连.这样就提高了效率, 并且优化了性能.

2 使用步骤

1)导入相关jar包

177944634_1_20191214083934204.png

图1

177944634_2_20191214083934469.png

图2

2)拷贝proxool.properties配置文件

##proxool.properties配置文件,该文件拷贝到src目录下即可jdbc-1.proxool.alias=test#jdbc-1.proxool.driver-class=oracle.jdbc.OracleDriver#jdbc-1.proxool.driver-url=jdbc:oracle:thin:@127.0.0.1:1521:orcljdbc-1.proxool.driver-class=com.mysql.jdbc.Driverjdbc-1.proxool.driver-url=jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=UTF-8jdbc-1.user=****jdbc-1.password=****jdbc-1.proxool.maximum-connection-count=50jdbc-1.proxool.minimum-connection-count=5jdbc-1.proxool.prototype-count=4jdbc-1.proxool.verbose=truejdbc-1.proxool.statistics=10s,1m,1djdbc-1.proxool.statistics-log-level=error

3)配置web.xml文件ServletConfigurator org.logicalcobwebs.proxool.configuration.ServletConfigurator propertyFileWEB-INF/classes/proxool.properties1

4)测试代码

177944634_3_20191214083934547.png

java源码结构

dao层实现类UserDaoImpl.java

package com.zzuli.dao.impl;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;public class UserDaoImpl{ public Connection getConn(){ Connection conn = null; try { // 利用数据库连接池获取连接 // 加载驱动// Class.forName('org.logicalcobwebs.proxool.ProxoolDriver');// // 获取连接// conn = DriverManager.getConnection('proxool.test'); // 利用原始方式 Class.forName('com.mysql.jdbc.Driver'); conn = DriverManager.getConnection('jdbc:mysql://localhost:3306/dename', '***', '***'); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } return conn; }}

控制层ConnPoolServlet .javapackage com.zzuli.controller;import java.io.IOException;import java.sql.Connection;import java.sql.SQLException;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import com.zzuli.dao.impl.UserDaoImpl;public class ConnPoolServlet extends HttpServlet{ /** * */ private static final long serialVersionUID = 1L; @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException{ UserDaoImpl udi = new UserDaoImpl(); Connection conn = null; long start = System.currentTimeMillis(); // 获取1000次连接 for (int i = 0; i < 1000; i++) { try { conn = udi.getConn(); System.out.println(conn); conn.close(); } catch (SQLException e) { e.printStackTrace(); } } long end = System.currentTimeMillis(); System.out.println('连接1000次用时:' + (end - start) + '毫秒.'); }}

运行结果:

177944634_4_20191214083934641.png

地址栏访问该项目

177944634_5_20191214083934719.png

使用原始方式

177944634_6_20191214083934797.png

使用数据库连接池

可见使用数据库连接池的效率是原始方式的10倍多...

整个测试项目的代码结构

177944634_7_20191214083934922.png

整个项目代码结构.png

完.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值