连接池
1)传统方式找DriverManager要连接,数目是有限的。
2)传统方式的close(),并没有将Connection重用,只是切断应用程序和数据库的桥梁,即无发送到SQL命令到数据库端执行
3)项目中,对于Connection不说,不会直接使用DriverManager取得,而使用连接池方式。
4)DBCP和C3P0,都是Java开源的,都必须直接或间接实现javax.sql.DataSource接口
5)DBCP连接池需要dbcp.properties文件,同时需加入3个对应的jar包
*6)C3P0连接池需要在/WEB-INF/classes/目录下存放c3p0-config.xml文件,该类ComboPooledDataSource在创建时
会自动在指定的目录下找xml文件,并加载默认设置
7)重构JdbcUtil类
DBCP连接池
l DBCP 是 Apache 软件基金组织下的开源连接池实现,使用DBCP数据源,应用程序应在系统中增加如下两个 jar 文件:
nbsp; commons-dbcp.jar:连接池的实现
nbsp; commons-pool.jar: 连接池实现的依赖类
nbsp; commons-collections.jar :连接池实现的集合类
l Tomcat 的连接池正是采用该连接池来实现的。
#dbcp.properties 配置文件
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/mydb2
username=root
password=root
关键代码
static{
InputStreamin = JdbcUtil.class.getClassLoader().
getResourceAsStream(“dbcp.properties”);
Propertiesprop = new Properties();
prop.load(in);
BasicDataSourceFactoryfactory = new BasicDataSourceFactory();
dataSource = factory.createDataSource(prop);
}
实例代码:
//测试连接池DBCP的用法
publicclass Demo2 {
publicstaticvoid main(String[] args) throws Exception {
long begin = System.currentTimeMillis();
//加载属性文件
InputStream is = Demo2.class.getClassLoader().getResourceAsStream(“dbcp.properties”);
Properties props = new Properties();
props.load(is);
//创建DBCP连接池工厂
BasicDataSourceFactory factory = new BasicDataSourceFactory();
//创建数据源,即连接池
DataSource ds = factory.createDataSource(props);
for(int i=1;i<=50000;i++){
//从连接池中取得一个空闲的连接对象
Connection conn = ds.getConnection();
if(conn!=null){
System.out.println(i+“:取得连接“);
}
//将连接对象还回给连接池
conn.close();
}
long end = System.currentTimeMillis();
System.out.println(“共用“ + (end-begin)/1000+“秒“);
}
}
c3p0:
配置文件:
</span>xml version=“1.0”encoding=“UTF-8”gt;
<!– 文件名不能乱改,须用默认的c3o0-config.xml –>
<c3p0-config>
<default-config>
<property name=“driverClass”>com.mysql.jdbc.Driver</property>
<property name=“user”>root</property>
<property name=“password”>root</property>
<property name=“jdbcUrl”>jdbc:mysql://127.0.0.1:3306/mydb2</property>
</default-config>
</c3p0-config>
/推荐使用c3p0连接池
//测试连接池C3P0的用法
publicclass Demo3 {
publicstaticvoid main(String[] args) throws Exception {
long begin = System.currentTimeMillis();
//创建C3P0连接池
ComboPooledDataSource dataSource = new ComboPooledDataSource();
for(int i=1;i<=100000;i++){
Connection conn = dataSource.getConnection();
if(conn!=null){
System.out.println(i+“:取得连接“);
conn.close();
}
}
long end = System.currentTimeMillis();
System.out.println(“共用“ + (end-begin)/1000+“秒“);
}
}
JdbcUtil工具类,封装从c3p0的连接池获取连接:
//JDBC工具类:关闭流和取得连接
publicfinalclass JdbcUtil3 {
//数据源
privatestatic ComboPooledDataSource dataSource;
static{//静态块,读取c3p0默认配置文件
dataSource = new ComboPooledDataSource();
}
//取得连接
publicstatic Connection getMySqlConnection() throws SQLException{
return dataSource.getConnection();
}
//关闭连接
publicstaticvoid close(Connection conn) throws SQLException{
if(conn!=null){
conn.close();
}
}
}
C3P0连接池具体参数说明如下:
c3p0-config>
<default-config>
<!–当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default:3 –>
<propertyname=”acquireIncrement”>3</property>
<!–定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 –>
<property name=”acquireRetryAttempts”>30</property>
<!–两次连接中间隔时间,单位毫秒。Default:1000 –>
<property name=”acquireRetryDelay”>1000</property>
<!–连接关闭时默认将所有未提交的操作回滚。Default:false –>
<propertyname=”autoCommitOnClose”>false</property>
<!–c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么
属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试
使用。Default:null–>
<propertyname=”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–>
<propertyname=”connectionTesterClassName”></property>
<!–指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可
Default: null–>
<propertyname=”factoryClassLocation”>null</property>
<!–每60秒检查所有连接池中的空闲连接。Default: 0 –>
<property name=”idleConnectionTestPeriod”>60</property>
<!–初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 –>
<property name=”initialPoolSize”>3</property>
<!–最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 –>
<propertyname=”maxIdleTime”>60</property>
 
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!