`
sjsky
  • 浏览: 916782 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

c3p0配置介绍

    博客分类:
  • Java
阅读更多

   blog迁移至 :http://www.micmiu.com

 
继上一篇介绍dbcp的配置,本文重点介绍下c3p0的配置及实例演示。

 

上一篇DBCP的配置可以参见:http://sjsky.iteye.com/blog/1105674

 

proxool的配置介绍也已经发表:http://sjsky.iteye.com/blog/1108808

 

本文的目录结构大致如下

  • 一、参数介绍
  • 二、结合spring、hibernate中的配置示例

[ 一 ]、参数介绍

 

<c3p0-default-config>
	<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->

	<property name="acquireIncrement">3</property>

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

	<property name="acquireRetryAttempts">30</property>

	<!--两次连接中间隔时间,单位毫秒。Default: 1000 -->

	<property name="acquireRetryDelay">1000</property>

	<!--连接关闭时默认将所有未提交的操作回滚。Default: false -->

	<property name="autoCommitOnClose">false</property>

	<!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。
		如果定义了这个参数那么属性preferredTestQuery将被忽略。
		你不能在这张Test表上进行任何操作,它将只供c3p0测试使用。Default: null-->
	<property name="automaticTestTable">Test</property>

	<!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。
		但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。
		如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->
	  
	<property name="breakAfterAcquireFailure">false</property>

	<!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,
		超时后将抛出SQLException,如设为0则无限期等待。单位毫秒。Default: 0 -->
	  
	<property name="checkoutTimeout">100</property>

	<!--通过实现ConnectionTester或QueryConnectionTester的类来测试连接。
		类名需制定全路径。Default: com.mchange.v2.c3p0.impl.DefaultConnectionTester-->
	  
	<property name="connectionTesterClassName"></property>

	<!--指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可Default: null-->
	<property name="factoryClassLocation">null</property>
	<!--作者强烈建议不使用的一个属性-->
	<property name="forceIgnoreUnresolvedTransactions">false</property>
	  
	<!--每60秒检查所有连接池中的空闲连接。Default: 0 -->

	<property name="idleConnectionTestPeriod">60</property>
	  
	<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
	  
	<property name="initialPoolSize">3</property>
	  
	<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
	  
	<property name="maxIdleTime">60</property>
	  
	<!--连接池中保留的最大连接数。Default: 15 -->
	  
	<property name="maxPoolSize">15</property>
	  
	<!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。
		但由于预缓存的Statements属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素.
		如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
	  
	<property name="maxStatements">100</property>
	  
	<!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
	  
	<property name="maxStatementsPerConnection"></property>
	  
	<!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能
		通过多线程实现多个操作同时被执行。Default: 3-->
	  
	<property name="numHelperThreads">3</property>
	  
	<!--当用户调用getConnection()时使root用户成为去获取连接的用户。
		主要用于连接池连接非c3p0的数据源时。Default: null-->
	  
	<property name="overrideDefaultUser">root</property>

	<!--与overrideDefaultUser参数对应使用的一个参数。Default: null-->
	  
	<property name="overrideDefaultPassword">password</property>
	  <!--密码。Default: null-->
	  
	<property name="password"></property>
	  
	<!--定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。
		注意:测试的表必须在初始数据源的时候就存在。Default: null-->
	  
	<property name="preferredTestQuery">
		select id from tb_c3p0_test where id=1
	</property>
	  
	<!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->
	  
	<property name="propertyCycle">300</property>
	  
	<!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的时候都将校验其有效性。
		建议使用idleConnectionTestPeriod或automaticTestTable等方法来提升连接测试的性能。Default: false -->
	  
	<property name="testConnectionOnCheckout">false</property>
	<!--如果设为true那么在取得连接的同时将校验连接的有效性。Default: false -->
	  
	<property name="testConnectionOnCheckin">true</property>
	<!--用户名。Default: null-->
	<property name="user">root</property>
	<!--密码。Default: null-->
	<property name="password"></property>

</c3p0-default-config>

 

和hibernate配置属性的对照表:

 

c3p0-native property name hibernate configuration key
c3p0.acquireIncrement hibernate.c3p0.acquire_increment
c3p0.idleConnectionTestPeriod hibernate.c3p0.idle_test_period
c3p0.initialPoolSize not available -- uses minimum size
c3p0.maxIdleTime hibernate.c3p0.timeout
c3p0.maxPoolSize hibernate.c3p0.max_size
c3p0.maxStatements hibernate.c3p0.max_statements
c3p0.minPoolSize hibernate.c3p0.min_size
c3p0.testConnectionsOnCheckout 

hibernate.c3p0.validate hibernate 2.x only!

 

 

[ 二 ]、spring、hibernate中的配置示例

 

c3p0.jdbc.properties

    jdbc.driverClassName=com.mysql.jdbc.Driver  
    jdbc.url=jdbc:mysql://localhost/iecms  
    jdbc.username=root  
    jdbc.password=  
 

[ 1 ]、基础测试

 

package michael.jdbc.c3p0;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

import javax.sql.DataSource;

import michael.jdbc.dbcp.DbcpDataSourceExample;

import com.mchange.v2.c3p0.ComboPooledDataSource;

/**
 * @see http://sjsky.iteye.com
 * @author michael sjsky007@gmail.com
 */
public class C3p0DataSourceExample {

    /**
     * @param args
     */
    public static void main(String[] args) {

        String testSql = "select * from TB_MYTEST";
        String cfgFileName = "c3p0.jdbc.properties";

        System.out.println("init c3p0 ComboPooledDataSource start ");
        DataSource dataSource = initDataSource(cfgFileName);
        System.out.println("ComboPooledDataSource init done.");

        Connection conn = null;
        Statement stmt = null;
        ResultSet rset = null;

        try {
            System.out.println("Creating connection start.");
            conn = dataSource.getConnection();

            System.out.println("Creating statement start.");
            stmt = conn.createStatement();

            System.out.println("Executing statement start.");
            rset = stmt.executeQuery(testSql);

            System.out.println("executeQuery Results:");
            int numcols = rset.getMetaData().getColumnCount();

            while (rset.next()) {
                for (int i = 1; i <= numcols; i++) {
                    System.out.print("\t" + rset.getString(i));
                }
                System.out.println("");
            }
            System.out.println("Results display done.");
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (rset != null)
                    rset.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            try {
                if (stmt != null)
                    stmt.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            try {
                if (conn != null)
                    conn.close();
            } catch (Exception e) {
                e.printStackTrace();
            }

        }
    }

    /**
     * @param cfgFileName
     * @return DataSource
     */
    public static DataSource initDataSource(String cfgFileName) {
        ComboPooledDataSource ds = new ComboPooledDataSource();
        try {
            Properties cfgpp = new Properties();
            cfgpp.load(C3p0DataSourceExample.class
                    .getResourceAsStream(cfgFileName));
            ds.setDriverClass(cfgpp.getProperty("jdbc.driverClassName"));
            ds.setJdbcUrl(cfgpp.getProperty("jdbc.url"));
            ds.setUser(cfgpp.getProperty("jdbc.username"));
            ds.setPassword(cfgpp.getProperty("jdbc.password"));
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }

        return ds;
    }

}

 

运行结果
init c3p0 ComboPooledDataSource start
ComboPooledDataSource init done.
Creating connection start.
Creating statement start.
Executing statement start.
executeQuery Results:
1 batch_add_0 2011-06-16 14:29:08.0
2 batch_add_1 2011-06-16 14:29:08.0
3 batch_add_2 2011-06-16 14:29:08.0
4 batch_add_3 2011-06-16 14:29:08.0
5 batch_add_4 2011-06-16 14:29:08.0
Results display done.
 

[ 2 ]、结合spring的配置测试

 

c3p0.ds.spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
	<bean id="propertyConfigurer"
		class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<property name="locations">
			<list>
				<value>
					classpath:michael/jdbc/c3p0/c3p0.jdbc.properties
				</value>
			</list>
		</property>
	</bean>

	<bean id="c3p0DataSource"
		class="com.mchange.v2.c3p0.ComboPooledDataSource"
		destroy-method="close">
		<property name="driverClass" value="${jdbc.driverClassName}" />
		<property name="jdbcUrl" value="${jdbc.url}" />
		<property name="user" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />

		<property name="minPoolSize" value="1" />
		<property name="maxPoolSize" value="20" />
		<property name="maxIdleTime" value="1800" />
		<property name="acquireIncrement" value="2" />
		<property name="maxStatements" value="0" />
		<property name="initialPoolSize" value="2" />
		<property name="idleConnectionTestPeriod" value="1800" />
		<property name="acquireRetryAttempts" value="30" />
		<property name="breakAfterAcquireFailure" value="true" />
		<property name="testConnectionOnCheckout" value="false" />
	</bean>

</beans>

 

package michael.jdbc.c3p0;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.sql.DataSource;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.mchange.v2.c3p0.ComboPooledDataSource;

/**
 * @see http://sjsky.iteye.com
 * @author michael sjsky007@gmail.com
 */
public class C3p0SpringExample {

    /**
     * @param args
     */
    public static void main(String[] args) {

        System.out.println("c3p0.ds.spring.xml init start ");
        ApplicationContext appCt = new ClassPathXmlApplicationContext(
                "michael/jdbc/c3p0/c3p0.ds.spring.xml");

        System.out.println("spring bean create ComboPooledDataSource");
        DataSource dataSource = (ComboPooledDataSource) appCt
                .getBean("c3p0DataSource");

        String testSql = "select * from TB_MYTEST";

        Connection conn = null;
        Statement stmt = null;
        ResultSet rset = null;

        try {
            System.out.println("Creating connection start.");
            conn = dataSource.getConnection();

            System.out.println("Creating statement start.");
            stmt = conn.createStatement();

            System.out.println("Executing statement start.");
            rset = stmt.executeQuery(testSql);

            System.out.println("executeQuery Results:");
            int numcols = rset.getMetaData().getColumnCount();

            while (rset.next()) {
                for (int i = 1; i <= numcols; i++) {
                    System.out.print("\t" + rset.getString(i));
                }
                System.out.println("");
            }
            System.out.println("Results display done.");
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (rset != null)
                    rset.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            try {
                if (stmt != null)
                    stmt.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            try {
                if (conn != null)
                    conn.close();
            } catch (Exception e) {
                e.printStackTrace();
            }

        }

    }
}
 
运行结果:
c3p0.ds.spring.xml init start
spring bean create ComboPooledDataSource
Creating connection start.
Creating statement start.
Executing statement start.
executeQuery Results:
1 batch_add_0 2011-06-16 14:29:08.0
2 batch_add_1 2011-06-16 14:29:08.0
3 batch_add_2 2011-06-16 14:29:08.0
4 batch_add_3 2011-06-16 14:29:08.0
5 batch_add_4 2011-06-16 14:29:08.0
Results display done.

 

 

[ 3 ]、结合hibernate的配置测试

 

hibernate.cfg.xm

<!DOCTYPE hibernate-configuration
    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

	<session-factory>
		<property name="connection.driver_class">
			com.mysql.jdbc.Driver
		</property>

		<!-- 连接数据库的URL-->
		<property name="connection.url">
			jdbc:mysql://localhost:3306/iecms
		</property>

		<property name="connection.useUnicode">true</property>
		<property name="connection.characterEncoding">UTF-8</property>

		<!--连接的登录名-->
		<property name="connection.username">root</property>

		<!--登录密码-->
		<property name="connection.password"></property>

		<!-- C3P0连接池设定-->
		<property name="hibernate.connection.provider_class">
			org.hibernate.connection.C3P0ConnectionProvider
		</property>
		<!-- 最大连接数 -->
		<property name="hibernate.c3p0.max_size">20</property>
		<!-- 最小连接数 -->
		<property name="hibernate.c3p0.min_size">5</property>
		<!-- 获得连接的超时时间,如果超过这个时间,会抛出异常,单位毫秒 -->
		<property name="hibernate.c3p0.timeout">120</property>
		<!-- 最大的PreparedStatement的数量 -->
		<property name="hibernate.c3p0.max_statements">100</property>
		<!-- 每隔120秒检查连接池里的空闲连接 ,单位是秒-->
		<property name="hibernate.c3p0.idle_test_period">120</property>
		<!-- 当连接池里面的连接用完的时候,C3P0一下获取的新的连接数 -->
		<property name="hibernate.c3p0.acquire_increment">2</property>
		<!-- 每次都验证连接是否可用 -->
		<property name="hibernate.c3p0.validate">true</property>

		<property name="show_sql">true</property>

		<property name="current_session_context_class">thread</property>

		<property name="dialect">
			org.hibernate.dialect.MySQL5Dialect
		</property>

		<property name="hbm2ddl.auto">update</property>
	</session-factory>
</hibernate-configuration>

 

package michael.jdbc.c3p0;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.cfg.Configuration;

/**
 * @see http://sjsky.iteye.com
 * @author michael sjsky007@gmail.com
 */
public class C3p0HibernateExample {

    /**
     * @param args
     */
    public static void main(String[] args) {
        SessionFactory sessionFactory = null;
        try {
            System.out.println("c3p0/hibernate.cfg.xml configure");
            Configuration config = new AnnotationConfiguration()
                    .configure("michael/jdbc/c3p0/hibernate.cfg.xml");

            System.out.println(" create sessionFactory ");
            sessionFactory = config.buildSessionFactory();

            System.out.println(" create session ");
            Session session = sessionFactory.getCurrentSession();
            String testSql = "select * from TB_MYTEST";

            System.out.println(" beginTransaction ");
            Transaction ta = session.beginTransaction();
            org.hibernate.Query query = session.createSQLQuery(testSql);
            List<Object[]> list = query.list();
            System.out.println(" createSQLQuery list: ");
            for (Object[] objArr : list) {
                for (Object obj : objArr) {
                    System.out.print("\t" + obj);
                }
                System.out.println("");
            }
            System.out.println(" beginTransaction commit ");
            ta.commit();

        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (null != sessionFactory) {
                sessionFactory.close();
            }

        }

    }
}
运行结果:
c3p0/hibernate.cfg.xml configure
create sessionFactory
create session
beginTransaction
Hibernate: select * from TB_MYTEST
createSQLQuery list:
1 batch_add_0 2011-06-16 14:29:08.0
2 batch_add_1 2011-06-16 14:29:08.0
3 batch_add_2 2011-06-16 14:29:08.0
4 batch_add_3 2011-06-16 14:29:08.0
5 batch_add_4 2011-06-16 14:29:08.0
beginTransaction commit
 

转载请注明来自:Michael's blog @ http://sjsky.iteye.com



------------------------------ 分 ------------------------------ 隔 ------------------------------ 线 ------------------------------

 

 

 

 

 

 

 

8
3
分享到:
评论

相关推荐

    c3p0配置文件

    c3p0配置文件

    C3P0配置文件

    &lt;c3p0-config&gt; &lt;!--默认配置--&gt; &lt;default-config&gt; &lt;property name="initialPoolSize"&gt;10&lt;/property&gt; &lt;property name="maxIdleTime"&gt;30&lt;/property&gt; &lt;property name="maxPoolSize"&gt;100&lt;/property&gt; ...

    C3P0用到的jar包和配置文件.zip

    在你的博客文章(链接已提供)中,你应该会详细介绍如何集成C3P0,包括如何在代码中创建数据源,如何加载配置文件,以及如何在实际应用中使用连接池服务。通过这种方式,你可以避免频繁的数据库连接创建和关闭,提高...

    c3p0配置mysql8.0.21的3个jar包

    4. **优化C3P0配置**:根据实际应用的负载情况,调整C3P0的配置参数,例如测试发现数据库访问高峰时经常出现连接不足的情况,可以适当增加`maxPoolSize`;如果服务器资源有限,可以降低`minPoolSize`以减少内存占用...

    c3p0配置说明

    下面将详细介绍C3P0的配置及其相关知识点。 1. **C3P0基本概念** - **数据源(DataSource)**:是JDBC API中用于管理数据库连接的接口,它提供了一种存储和获取数据库连接的方式。 - **连接池(Connection Pool)...

    c3p0详细配置

    C3P0 配置是通过一个 XML 文件(通常命名为 `c3p0-config.xml`)进行的,该文件包含了各种属性来调整连接池的行为和性能。以下是一些关键的 C3P0 配置属性的详细解释: 1. **acquireIncrement**: 这个属性定义了当...

    spring c3p0配置详解

    下面我们将详细介绍 Spring 配置 C3P0 的各项参数及其意义。 1. **driverClass**:指定数据库驱动类,例如 `com.mysql.jdbc.Driver`,这是连接 MySQL 数据库的驱动。 2. **jdbcUrl**:数据库连接字符串,包含了...

    C3P0连接池配置需要的jar包

    配置C3P0连接池时,开发者通常需要在配置文件(如Hibernate的`hibernate.cfg.xml`或Spring的`applicationContext.xml`)中指定以下参数: - `driver_class`: 数据库驱动类名,例如`com.mysql.jdbc.Driver`。 - `...

    spring 配置c3p0

    本篇将详细介绍如何在Spring中配置C3P0连接池。 首先,我们需要理解C3P0的基本概念。C3P0是由Miquel Delgado开发的,它提供了数据库连接的自动管理,包括连接创建、回收、测试等。C3P0的主要特点包括支持JDBC3规范...

    c3p0jar包及配置文件(可用)

    内容概要:c3p0连接池需要jar包.rar以及相关配置文件 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate、Spring等。 适合人群:正在学习...

    c3p0配置及jar包

    下面我们将详细介绍c3p0的配置以及在Spring中的使用,并讨论与Hibernate集成的优势。 **一、c3p0的核心概念** 1. **连接池**: c3p0维护了一个数据库连接的池,通过复用已存在的连接而不是每次请求时创建新的连接,...

    c3p0配置文件和操作说明

    以下将详细介绍c3p0的核心概念、配置方法以及基本操作。 1. **核心概念** - **连接池(Connection Pool)**: c3p0维护一个数据库连接的池,而不是每次需要时都去数据库申请新的连接,这大大提高了数据库访问效率。...

    c3p0配置需要jar包

    2. **配置C3P0**:在Hibernate的配置文件(通常是`hibernate.cfg.xml`)中添加C3P0的相关配置,例如设置初始连接数、最大连接数、最小空闲连接数、超时时间等参数。 ```xml &lt;property name="hibernate.c3p0.min_...

    c3p0简易配置

    ### c3p0简易配置详解 c3p0是一个开源的JDBC连接池实现,它提供了对数据库连接的管理和优化,能够显著提升基于数据库的应用程序性能。本文将深入解析c30p配置中的关键参数,帮助理解其工作原理及如何进行有效配置。...

    C3P0详细配置C3P0详细配置.docC3P0详细配置.docC3P0详细配置.doc

    以下是对C3P0配置中各个属性的详细解释: 1. `acquireIncrement`:当连接池中的连接耗尽时,C3P0一次性尝试获取的连接数。默认值为3,意味着如果连接池中没有可用连接,会尝试同时获取3个新的连接。 2. `...

    c3p0数据源连接池的配置

    C3P0的配置通常通过`c3p0.properties`文件完成,该文件一般位于项目的`WEB-INF\classes`目录下,确保被类加载器正确加载。配置文件中的参数众多,下面列举几个关键参数及其作用: - `c3p0.driverClass`:指定数据库...

    C3P0连接池配置

    **C3P0连接池配置详解** C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。C3P0的主要特点是轻量级、高效且稳定,广泛应用于各种Java Web应用中。在本文中,我们将深入探讨...

Global site tag (gtag.js) - Google Analytics