项目中将DBCP连接换成阿里云的Druid连接方式

mysql数据库的环境下,把dbcp连接方式换成阿里云druid的原因是:

性能上提高很多,之后附上测试结果:

最新版本:0.2.6

maven管理:

<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>druid</artifactId>
            <version>0.2.6</version>
		</dependency>

替换很简单:

把applicationContext.xml中的:

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
		<!-- Connection Info -->
		<property name="driverClassName" value="${jdbc.driver}" />
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />

		<!-- Connection Pooling Info -->
		<property name="defaultAutoCommit" value="false" />
		<!-- 连接Idle一个小时后超时 -->
		<property name="timeBetweenEvictionRunsMillis" value="3600000" />
		<property name="minEvictableIdleTimeMillis" value="3600000" />
	</bean>

替换成:

<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
        <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />

        <property name="filters" value="stat" />

        <property name="maxActive" value="20" />
        <property name="initialSize" value="1" />
        <property name="maxWait" value="60000" />
        <property name="minIdle" value="1" />

        <property name="timeBetweenEvictionRunsMillis" value="3600000" />
        <property name="minEvictableIdleTimeMillis" value="3600000" />

        <property name="validationQuery" value="SELECT 'x'" />
        <property name="testWhileIdle" value="true" />
        <property name="testOnBorrow" value="false" />
        <property name="testOnReturn" value="false" />

        <property name="poolPreparedStatements" value="true" />
        <property name="maxPoolPreparedStatementPerConnectionSize" value="50" />
    </bean>

如果为了简单:

Druid的配置和DBCP是基本一致的,如果你原来是使用DBCP,迁移是十分方便的,只需要把corg.apache.commons.dbcp.BasicDataSource修改为om.alibaba.druid.pool.DruidDataSource就好了。

配置参数的含义:看连接:http://code.alibabatech.com/wiki/pages/viewpage.action?pageId=6947005

性能测试结果看连接:http://code.alibabatech.com/wiki/pages/viewpage.action?pageId=2916539

附上测试图:

2:

后续有很多开发填坑的文章发布,如果对你有帮助,请支持和加关注一下

http://e22a.com/h.05ApkG?cv=AAKHZXVo&sm=339944

https://shop119727980.taobao.com/?spm=0.0.0.0 

转载于:https://my.oschina.net/baishi/blog/159790

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C3P0 和 DBCP 都是连接池技术,可以有效地管理数据库连接,减少连接建立和释放的消耗。Druid 技术比 C3P0 和 DBCP 更加先进,它具有更高的性能和安全性,并且支持对数据库的实时监控和统计分析。 ### 回答2: c3p0,DBCP,和Druid都是Java中常用的数据库连接池技术,它们各自有不同的技术侧重和优势。 c3p0连接池是一个开源的JDBC连接池,侧重于提供高性能和可靠的连接池管理。其优势包括: 1. 可以自动缓存和重用数据库连接,避免频繁创建和销毁连接,提高了数据库访问的性能。 2. 提供连接断线自动恢复功能,能够检测并处理数据库连接的断开和超时问题,保证系统的稳定性。 3. 支持连接池的配置和监控,可以通过配置文件或者代码动态调整连接池的参数,满足不同业务需求。 4. 能够处理不同数据库连接,支持主流数据库如MySQL、Oracle等。 DBCP连接池是Apache Commons项目中的一个模块,侧重于提供简单易用的连接池实现。其优势包括: 1. 配置简单,可以通过简单的配置文件即可完连接池的创建和管理。 2. 轻量级,与应用程序集方便,对代码的侵入性较小。 3. 支持基本的连接池功能,如连接的管理、复用和释放。 4. 良好的可扩展性,可以通过集其他组件来实现更高级的功能。 Druid连接池是阿里巴巴开源的一款高性能、可扩展和功能丰富的数据库连接池,侧重于提供全方位的数据库连接管理。其优势包括: 1. 提供性能监控和统计功能,可以实时监控数据库连接池的状态和性能指标,方便线上问题的排查和性能优化。 2. 支持连接池的防火墙功能,可以通过配置白名单、黑名单等规则来过滤恶意或异常的数据库连接。 3. 内置了SQL防注入功能,能够自动检测和阻止恶意SQL注入攻击。 4. 提供了数据库连接的可视化接口,方便开发人员查看和管理连接池的状态和连接使用情况。 总的来说,c3p0、DBCPDruid都是熟、稳定的数据库连接池技术,根据实际需求和性能要求选择合适的连接池可以提升应用的数据库访问性能和稳定性。 ### 回答3: c3p0,DBCPDruid都是常用的数据库连接池技术,它们都有各自的侧重和优势。 c3p0是一种快速而可靠的JDBC连接池,侧重于提供高性能的连接缓存和连接池管理。它可以对JDBC连接进行管理和重用,有效地降低了数据库连接的创建和关闭的消耗。同时,c3p0还支持连接池的配置,可以根据应用的负载情况进行自动调整,保证连接池的稳定性。 DBCP数据库连接池)也是一种常用的连接池技术,它侧重于提供简单易用的连接池解决方案。DBCP提供了基本的连接池功能,并且可以通过配置文件进行定制。它的优势在于使用简单,不需要过多的配置和调整,适用于一些简单的应用场景。 Druid是阿里巴巴开源的数据库连接池,侧重于提供高性能和可扩展性。它支持了连接池的所有功能,同时还提供了一些监控和统计功能,可以方便地监控和定位问题。Druid还内置了SQL防火墙和统计功能,可以有效地防止SQL注入攻击和性能问题。 总的来说,c3p0,DBCPDruid都是优秀的连接池技术,具有各自的特点和优势。根据应用的需求和场景,可以选择合适的连接池技术来提高数据库访问的性能和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值