c3p0在spring中的配置

在大家的开发和学习当中应该经常用到数据库的连接和使用,不过连接

的方式就有很多种方式了,比方说用最最简单的JDBC 也好,还有用比

较复杂一点的就是数据库连接池,当然还有使用DBCP的连接的,各种方

法有各种方法的优势面和缺点,这据需要我们根据具体情况具体分析了

,比方说要是一个并不是很大的项目的话,而且 使用的硬件机器的性

能也不是非常好的话,估计就没有必要使用数据库连接池了,毕竟连接

池平时总是管理着连接, 就会极大的占用这机器的运行性能和效率。

(这里的C3P0的使用是基于Spring框架开发中使用的,IDE工具为

“Myeclipse 9”)

这里我们就介绍一下,在工程中如何使用C3P0 数据库连接池,这是一

种已经写好的, 并且效率很高的一种开源的连接池写法,参数设置的

都比较简单和合理。

首先第一步,将需要使用C3P0的工程建立好,当然,最最简单也是必要

的就是把需要的Jar 包引入:, 这种比较没有营养的东西,我就不贴

出下载地址啦,果断百度之吧,然后当然就是“BuildPath”了,引入包

之后,将 C3P0的配置文件写入到 Spring的配置文件中 当然一般我们

都叫它“Spring.xml”, 在其中填入下列字符:

<!-- 使用c3p0实现datasource,连接池 -->

<bean id="c3p0dataSource"

class="com.mchange.v2.c3p0.ComboPooledDataSource">

<property name="driverClass">

<value>com.mysql.jdbc.Driver</value>

</property>

<property name="jdbcUrl">

<value>jdbc:mysql://localhost:3308/myoa?

useUnicode=true&characterEncoding=UTF-

8&zeroDateTimeBehavior=convertToNull</value>

</property>

<property name="user">

<value>root</value>

</property>

<property name="password">

<value>root</value>

</property>

<!--连接池中保留的最小连接数。-->

<property name="minPoolSize">

<value>5</value>

</property>

<!--连接池中保留的最大连接数。Default: 15 -->

<property name="maxPoolSize">

<value>30</value>

</property>

<!--初始化时获取的连接数,取值应在minPoolSize与maxPoolSize之间

。Default: 3 -->

<property name="initialPoolSize">

<value>10</value>

</property>

<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。

Default: 0 -->

<property name="maxIdleTime">

<value>60</value>

</property>

<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。

Default: 3 -->

<property name="acquireIncrement">

<value>5</value>

</property>

<!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements

数量。但由于预缓存的statements

属于单个connection而不是整个连接池。所以设置这个参数需要考虑

到多方面的因素。

如果maxStatements与maxStatementsPerConnection均为0,则缓存被

关闭。Default: 0-->

<property name="maxStatements">

<value>0</value>

</property>

<!--每60秒检查所有连接池中的空闲连接。Default: 0 -->

<property name="idleConnectionTestPeriod">

<value>60</value>

</property>

<!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30

-->

<property name="acquireRetryAttempts">

<value>30</value>

</property>

<!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异

常。但是数据源仍有效

保留,并在下次调用getConnection()的时候继续尝试获取连接。如

果设为true,那么在尝试

获取连接失败后该数据源将申明已断开并永久关闭。Default:

false-->

<property name="breakAfterAcquireFailure">

<value>true</value>

</property>

<!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每

个connection提交的

时候都将校验其有效性。建议使用idleConnectionTestPeriod或

automaticTestTable

等方法来提升连接测试的性能。Default: false -->

<property name="testConnectionOnCheckout">

<value>false</value>

</property>

</bean>

在里面进行了详细的注解,只要是有一部分JAVA 基础的应该就能看懂

了,剩下的就是在Spring中 使用DataSource 进行调用和使用数据库连

接池了,如果仅仅是要实用的话,完全不用进行 设置了,默认已经设

置好了。

c3p0在spring中的配置,布布扣,bubuko.com

时间: 2024-07-28 18:52:00

c3p0在spring中的配置的相关文章

Velocity初探小结--Velocity在spring中的配置和使用

最近正在做的项目前端使用了Velocity进行View层的数据渲染,之前没有接触过,草草过了一遍,就上手开始写,现在又回头细致的看了一遍,做个笔记. velocity是一种基于java的模板引擎技术,有点类似与JSP,它允许页面设计者引用Java中定义的方法.前端页面设计者和后端Java开发者能够同时使用MVC的模式开发网站,这样前端能够把精力放在页面的设计上,后端也可以把精力放在代码开发上.Velocity把Java代码从Web页面中分离, 使网站可维护性更强. 注:项目使用的是Spring+

spring中xml配置和autowired混用

1.类的混用: 配置文件中的配置: <bean id="a" class="com.ab.cc.A" /> 类中的配置 @Autowired A a; 这样的好处,可以少掉get/set方法 [email protected]和@Resource的区别 Autowired默认是根据byType自动装配,所以有多个类型的xml或者注解某个类的时候,会报错,这时候可以再添加@Qualifier注解,指定名称.这个是spring自带的,换框架的时候,要spri

关于spring中注解配置的问题

今天写spring的时候,想用注解配置,但不巧的是用Junit工具测试的时候出错了,检查了很久的代码,发现并不是代码的问题,那就有些奇怪了. 后来去百度,回答的奇奇怪怪,和我的问题沾边的不多,最后还是FQ找到的答案,废话不多说,先贴出错误提示: org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exception parsing XML document from class path resou

spring中缓存配置

缓存spring文件的配置: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframew

spring-logger spring中日志配置

默认日志 Logback:默认情况下,Spring Boot会用Logback来记录日志,并用INFO级别输出到控制台.在运行应用程序和其他例子时,你应该已经看到很多INFO级别的日志了. 从上图可以看到,日志输出内容元素具体如下: 时间日期:精确到毫秒日志级别:ERROR, WARN, INFO, DEBUG or TRACE进程ID分隔符:— 标识实际日志的开始线程名:方括号括起来(可能会截断控制台输出)Logger名:通常使用源代码的类名日志内容添加日志依赖假如maven依赖中添加了spr

Spring中Hibernate配置笔记

ApplicatonContext.xml中的配置: <jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/global/ds" /> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <proper

c3p0连接池在spring中的配置

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <!-- 指定连接数据库的驱动 --> <property name="driverClass" value="com.mysql.jdbc.Driver"/> <!-- 指定

Spring 中 Xml配置文件属性的说明

Xml配置文件属性的说明: <bean id="TheAction" ⑴ class="net.xiaxin.spring.qs.UpperAction" ⑵ singleton="true" ⑶ init-method="init" ⑷ destroy-method="cleanup" ⑸ depends-on="ActionManager" ⑹ > <propert

redis在spring中的配置及java代码实现

1.建一个redis.properties属性文件 # Redis Setting redis.addr = 127.0.0.1 redis.port = 6379 redis.auth = master redis.maxIdle = 200 redis.maxActive = 1024 redis.maxWait = 10000 redis.timeOut = 10000 redis.testOnBorrow = true 2.新建一个RedisUtil.java文件,文件代码如下: pac