Druid连接池的使⽤
Druid简介
Druid是阿⾥开源的数据库连接池,作为后起之秀,性能⽐dbcp、c3p0更⾼,使⽤也越来越⼴泛。
当然Druid不仅仅是⼀个连接池,还有很多其他的功能。
druid的优点
⾼性能。性能⽐dbcp、c3p0⾼很多。
只要是jdbc⽀持的数据库,druid都⽀持,对数据库的⽀持性好。并且Druid针对oracle、mysql做了特别优化。
提供监控功能。可以监控sql语句的执⾏时间、ResultSet持有时间、返回⾏数、更新⾏数、错误次数、错误堆栈等信息,来了解连接池、sql语句的⼯作情况,⽅便统计、分析SQL的执⾏性能
Druid的使⽤
添加druid的依赖、数据库驱动
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.8</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.19</version>
</dependency>
纯代码⽅式
    //数据源配置
DruidDataSource dataSource = new DruidDataSource();
dataSource.setUrl("jdbc:mysql://127.0.0.1/db_student?serverTimezone=UTC");
dataSource.setDriverClassName("sql.cj.jdbc.Driver"); //这个可以缺省的,会根据url⾃动识别
dataSource.setUsername("root");
dataSource.setPassword("abcd");
//下⾯都是可选的配置
dataSource.setInitialSize(10);  //初始连接数,默认0
dataSource.setMaxActive(30);  //最⼤连接数,默认8
dataSource.setMinIdle(10);  //最⼩闲置数
dataSource.setMaxWait(2000);  //获取连接的最⼤等待时间,单位毫秒
dataSource.setPoolPreparedStatements(true); //缓存PreparedStatement,默认false
dataSource.setMaxOpenPreparedStatements(20); //缓存PreparedStatement的最⼤数量,默认-1(不缓存)。⼤于0时会⾃动开启缓存PreparedStatement,所以可以省略上⼀句代码        //获取连接
Connection connection = Connection();
//Statement接⼝
Statement statement = ateStatement();
String sql1 = "insert into tb_student (name,age) values ('chy',20)";
//PreparedStatement接⼝
String sql2 = "insert into tb_student (name,age) values ('chy',21)";
PreparedStatement preparedStatement = connection.prepareStatement(sql2);
//关闭连接
connection.close();
配置⽂件⽅式
1、在sources下新建druid.properties
url=jdbc:mysql://127.0.0.1/db_student?serverTimezone=UTC
#这个可以缺省的,会根据url⾃动识别
sql.cj.jdbc.Driver
username=root
password=abcd
##初始连接数,默认0
initialSize=10
#最⼤连接数,默认8
maxActive=30
#最⼩闲置数
minIdle=10
#获取连接的最⼤等待时间,单位毫秒
maxWait=2000
#缓存PreparedStatement,默认false
poolPreparedStatements=true
#缓存PreparedStatement的最⼤数量,默认-1(不缓存)。⼤于0时会⾃动开启缓存PreparedStatement,所以可以省略上⼀句设置maxOpenPreparedStatements=20
2、使⽤
public class Test {
public static void main(String[] args) throws Exception {
//数据源配置
Properties properties=new Properties();
//通过当前类的class对象获取资源⽂件
InputStream is = ResourceAsStream("/druid.properties");
properties.load(is);
//返回的是DataSource,不是DruidDataSource
DataSource dataSource = ateDataSource(properties);
//获取连接
Connection connection = Connection();
//Statement接⼝
Statement statement = ateStatement();
String sql1 = "insert into tb_student (name,age) values ('chy',20)";
//PreparedStatement接⼝
String sql2 = "insert into tb_student (name,age) values ('chy',22)";
PreparedStatement preparedStatement = connection.prepareStatement(sql2);
//关闭连接
connection.close();
}
}
这种⽅式对properties的key有严格要求,必须值指定的字符串,容易写错。
如果觉得⽼调不好,可以DruidDataSource dataSource = new DruidDataSource();  再调⽤setter⽅法使⽤配置⽂件的值,不过很⿇烦。
在Spring中使⽤Druid
1、resources下新建druid.properties
druid.url=jdbc:mysql://127.0.0.1/db_student?serverTimezone=UTC
#这个可以缺省的,会根据url⾃动识别
druid.sql.cj.jdbc.Driver
druid.username=root
druid.password=abcd
##初始连接数,默认0
druid.initialSize=10
#最⼤连接数,默认8
druid.maxActive=30
#最⼩闲置数
druid.minIdle=10
#获取连接的最⼤等待时间,单位毫秒
druid.maxWait=2000
#缓存PreparedStatement,默认false
druid.poolPreparedStatements=true
#缓存PreparedStatement的最⼤数量,默认-1(不缓存)。⼤于0时会⾃动开启缓存PreparedStatement,所以可以省略上⼀句设置druid.maxOpenPreparedStatements=20
2、spring配置⽂件
<!--引⼊druid配置⽂件-->
<context:property-placeholder location="classpath:druid.properties"/>
<!--druid连接池-->
<bean name="druidDataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="url" value="${druid.url}"/>
<property name="driverClassName" value="${druid.driverClassName}"/>
<property name="username" value="${druid.username}"/>
<property name="password" value="${druid.password}"/>
<property name="initialSize" value="${druid.initialSize}"/>
<property name="maxActive" value="${druid.maxActive}"/>
<property name="minIdle" value="${druid.minIdle}"/>
<property name="maxWait" value="${druid.maxWait}"/>
<property name="poolPreparedStatements" value="${druid.poolPreparedStatements}"/>
<property name="maxOpenPreparedStatements" value="${druid.maxOpenPreparedStatements}"/>
</bean>
注意要配置包扫描,扫描注解。
3、使⽤
@Repository
public class Xxx {
@Resource
private DruidDataSource dataSource;
public void xxx() throws SQLException {
//获取连接
Connection connection = Connection();
//Statement接⼝
Statement statement = ateStatement();
String sql1 = "insert into tb_student (name,age) values ('chy',20)";
//PreparedStatement接⼝
String sql2 = "insert into tb_student (name,age) values ('chy',22)";
PreparedStatement preparedStatement = connection.prepareStatement(sql2);
//关闭连接
connection.close();
druid连接池配置详解
}
}
在SpringBoot中使⽤Druid
SpringBoot默认提供了DBCP连接池的配置,只需要在配置⽂件中配置即可。
C3P0、Druid没有提供配置,需要我们在配置⽂件中添加配置,并⾃⼰写⼀个配置类来创建连接池。
使⽤durid的监控功能
1、在druid数据源⾥启⽤stat过滤器
<property name="filters" value="stat" />
2、在l中配置StatViewServlet
  <servlet>
<servlet-name>DruidStatView</servlet-name>
<servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>
<!--<!– 是否允许清空统计数据,不写时默认true –>-->
<!--<init-param>-->
<!--    <param-name>resetEnable</param-name>-->
<!--    <param-value>false</param-value>-->
<!--</init-param>-->
<!--<!– ⽤户名。⽤户名和密码可以不配置,不配置时进⼊监控页⾯时不需要输⼊⽤户名、密码 –>-->        <!--<init-param>-->
<!--    <param-name>loginUsername</param-name>-->
<!--    <param-value>chy</param-value>-->
<!--</init-param>-->
<!--<!– 密码 –>-->
<!--<init-param>-->
<!--    <param-name>loginPassword</param-name>-->
<!--    <param-value>abcd</param-value>-->
<!-- </init-param>-->
</servlet>
<servlet-mapping>
<servlet-name>DruidStatView</servlet-name>
<url-pattern>/druid/*</url-pattern>
</servlet-mapping>
启动web应⽤,在  localhost:8080/druid  可看到sql的执⾏情况统计。(注意不是项⽬下)
druid默认会清空统计数据,所以只能看到当时的情况,应⽤需要持续操作数据库才好看到效果。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。