druid连接池配置

阿里巴巴推出的国产数据库连接池,据网上测试对比,比目前的DBCP或C3P0数据库连接池性能更好,Druid与其他数据库连接池使用方法基本一样(与DBCP非常相似),将数据库的连接信息全部配置给DataSource对象。

基于纯Java代码使用:

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

package demo.test;

import java.io.InputStream;

import java.sql.Connection;

import java.sql.SQLException;

import java.util.Properties;

import javax.sql.DataSource;

import com.alibaba.druid.pool.DruidDataSourceFactory;

public class DBUtil {

    private static DataSource ds = null;  

    

    static {

        try{

            InputStream in = DBUtil.class.getClassLoader()

                                   .getResourceAsStream("ds.properties");

            Properties props = new Properties();

            props.load(in);

            ds = DruidDataSourceFactory.createDataSource(props);

        }catch(Exception ex){

            ex.printStackTrace();

        }

    }

    

    public static Connection openConnection() throws SQLException{

        return ds.getConnection();

    }  

    

}

ds.properties内容: 

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

driverClassName = oracle.jdbc.driver.OracleDriver

url = jdbc:oracle:thin:@127.0.0.1:1521:ORCL

username = ******

password = ******

initialSize = 5

maxActive = 10

minIdle = 3

maxWait = 60000

removeAbandoned = true

removeAbandonedTimeout = 180

timeBetweenEvictionRunsMillis = 60000

minEvictableIdleTimeMillis = 300000

validationQuery = SELECT 1 FROM DUAL

testWhileIdle = true

testOnBorrow = false

testOnReturn = false

poolPreparedStatements = true

maxPoolPreparedStatementPerConnectionSize = 50

filters = stat

 基于Spring的配置: 

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

<bean id="druidDataSource" class="com.alibaba.druid.pool.DruidDataSource"

        init-method="init" destroy-method="close">

        <!-- 数据库基本信息配置 -->

        <property name="driverClassName" value="${oracle.driver}" />

        <property name="url" value="${oracle.url}" />

        <property name="username" value="${oracle.username}" />

        <property name="password" value="${oracle.password}" />       

        <!-- 初始化连接数量 -->

        <property name="initialSize" value="${druid.initialSize}" />

        <!-- 最大并发连接数 -->

        <property name="maxActive" value="${druid.maxActive}" />

        <!-- 最大空闲连接数 -->

        <property name="maxIdle" value="${druid.maxIdle}" />

        <!-- 最小空闲连接数 -->

        <property name="minIdle" value="${druid.minIdle}" />

        <!-- 配置获取连接等待超时的时间 -->

        <property name="maxWait" value="${druid.maxWait}" />

        <!-- 超过时间限制是否回收 -->

        <property name="removeAbandoned" value="${druid.removeAbandoned}" />

        <!-- 超过时间限制多长; -->

        <property name="removeAbandonedTimeout" value="${druid.removeAbandonedTimeout}" />

        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->

        <property name="timeBetweenEvictionRunsMillis" value="${druid.timeBetweenEvictionRunsMillis}" />

        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->

        <property name="minEvictableIdleTimeMillis" value="${druid.minEvictableIdleTimeMillis}" />

        <!-- 用来检测连接是否有效的sql,要求是一个查询语句-->

        <property name="validationQuery" value="${druid.validationQuery}" />

        <!-- 申请连接的时候检测 -->

        <property name="testWhileIdle" value="${druid.testWhileIdle}" />

        <!-- 申请连接时执行validationQuery检测连接是否有效,配置为true会降低性能 -->

        <property name="testOnBorrow" value="${druid.testOnBorrow}" />

        <!-- 归还连接时执行validationQuery检测连接是否有效,配置为true会降低性能  -->

        <property name="testOnReturn" value="${druid.testOnReturn}" />

        <!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->

        <property name="poolPreparedStatements" value="${druid.poolPreparedStatements}" />    

        <property name="maxPoolPreparedStatementPerConnectionSize" value="${druid.maxPoolPreparedStatementPerConnectionSize}" />

        <!--属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:                

                监控统计用的filter:stat

                日志用的filter:log4j

               防御SQL注入的filter:wall -->

        <property name="filters" value="${druid.filters}" />      

    </bean>

 启用Web监控统计功能需要在Web应用的web.xml中加入以下内容: 

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

<filter>

      <filter-name>DruidWebStatFilter</filter-name>

      <filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class>

      <init-param>

       <param-name>exclusions</param-name>

       <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*</param-value>

      </init-param>

</filter>

<filter-mapping>

     <filter-name>DruidWebStatFilter</filter-name>

     <url-pattern>/*</url-pattern>

</filter-mapping>

<servlet>

    <servlet-name>DruidStatView</servlet-name>

    <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>  

</servlet>   

<servlet-mapping>

    <servlet-name>DruidStatView</servlet-name>

    <url-pattern>/druid/*</url-pattern>

</servlet-mapping>

访问监控页面:http://ip:port/projectName/druid/index.html

时间: 2024-10-12 15:45:47

druid连接池配置的相关文章

Spring Boot2.x 的Druid连接池配置[附带监控]

父依赖[Spring Boot 2.1.x版本] <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.1.RELEASE</version> </parent> 主要依赖[3个] <!--Druid 连接池与Spring B

阿里巴巴Druid连接池配置

Druid 是阿里巴巴的开源数据库连接池技术,相比dbcp.c3p0更优秀,具有密码加密.sql连接监控功能,无论在性能还是稳定性上表现都十分出色. spring.xml <context:property-placeholder location="classpath:jdbc.properties"/> <bean id="druidDataSource" class="com.alibaba.druid.pool.DruidData

SpringBoot2.0 基础案例(07):集成Druid连接池,配置监控界面

一.Druid连接池 1.druid简介 Druid连接池是阿里巴巴开源的数据库连接池项目.Druid连接池为监控而生,内置强大的监控功能,监控特性不影响性能.功能强大,能防SQL注入,内置Loging能诊断Hack应用行为.Druid连接池是阿里巴巴内部唯一使用的连接池,在内部数据库相关中间件TDDL/DRDS 都内置使用强依赖了Druid连接池,经过阿里内部数千上万的系统大规模验证,经过历年双十一超大规模并发验证. 2.druid特点 1)稳定性特性,阿里巴巴的业务验证 2)完备的监控信息,

SpringMVC+Spring+Mybatis整合,使用druid连接池,声明式事务,maven配置

一直对springmvc和mybatis挺怀念的,最近想自己再搭建下框架,然后写点什么. 暂时没有整合缓存,druid也没有做ip地址的过滤.Spring的AOP简单配置了下,也还没具体弄,不知道能不能用,log也不知道能不能用,`(*∩_∩*)′哈哈,有点不负责任...... 直接上代码: 使用的eclipse和eclipse自带的maven,参考了网上的资料,有些代码是拷贝的,不过都自己测试过了.嗯,可以跑起来... 先上项目结构: 新建maven项目,选择web,然后配置pom: <pro

spring 4 + jpa(hibernate 3/4) + spring mvc 多数据源配置(二)+Druid连接池

接上一个博文(http://www.loveweir.com/html/18.html),没有数据库连接池,纯粹用jpa的官方链接. 所以这次要加上连接池本文用Druid连接池来实现多数据源的配置. persistence.xml 这个文件可以省略了,全部配置在applicationContext.xml 里面: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www

Druid连接池及监控在spring中的配置

Druid连接池及监控在Spring配置如下: [html] view plaincopy <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> <!-- 基本属性 url.user.password --> <property 

使用druid连接池,配置sql防火墙发现的sql注入问题

最近在使用druid连接池,同时也配置了web和spring的关联监控,检测到select * from tables param like #{param1} "%"的语句被拦截了.做个笔记. 解决方法有两种: 一. select * from tables param like concat(${param1},"%"). 二.传入 参数的时候动态拼接 param1=param1+"%"; select * from tables param

SpringBoot配置MySql数据库和Druid连接池

1.pom文件增加相关依赖,我这里因为上面引入了父pom,所以不需要在当前pom文件下加版本 <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifact

springboot+druid连接池及监控配置

1. 问题描述 阿里巴巴的数据库连接池Druid在效率与稳定性都很高,被很多开发团队使用,并且自带的Druid监控也很好用,本章简单介绍下springboot+druid配置连接池及监控. 2. 解决方案 2.1 pom.xml springboot 已经有druid的starter,但是好像有点问题,不知道为什么没拿到jar包,有可能是网络问题,还是使用了原生的druid gav. <dependency> <groupId>com.alibaba</groupId>