配置java连接池,tomcat、Spring配置文件两种方法实例介绍。

一、首先配置连接池

1、tomcat下配置连接池

*>在tomcat下的context.xml配置连接池代码
name=”jdbc/sqlserver” //连接池名称
type=”javax.sql.DataSource”
password=”syl6413″
driverClassName=”com.microsoft.sqlserver.jdbc.SQLServerDriver”
maxIdle=”5″
maxWait=”5000″
username=”sa”
url=”jdbc:sqlserver://192.168.0.9:1433; DatabaseName=disasterSystem”
maxActive=”10″/>
*>tomcat连接池中配置web.xml代码
SQLServer2005 Datasource disasterSystem
jdbc/sqlserver
javax.sql.DataSource
Container

*>在Spring配置tomcat连接池的JNDI代码

自此tomcat连接池已配置完毕,若不用Spring管理连接池,也可以不配Spring,这样即可以在程序中使用tomcat连接池了.若使用Spring来统一管理连接池,也就是统一SessionFactory,配置方式如下:

class=”org.springframework.orm.hibernate3.LocalSessionFactoryBean”>
org.hibernate.dialect.SQLServerDialect
true
true
true
utf-8
true
true
after_transaction

2、tomcat下配置连接池

Spring不通过用tomcat中配置的JNDI来连接,但是它也是通过用commons.dbcp.jar连接池来管理的,也可以通过其他的开源连接池工具如:C3P0等。配置又分为两种,具体代码如下:

*>一种是直接配置applicationContext.xml

*>另一种是通过perportise配置文件:datasource.properties再通过applicationContext.xml得到

datasource.properties代码:
datasource.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
datasource.url=jdbc:sqlserver://192.168.0.9:1433;DatabaseName=disasterSystem
datasource.username=sa
datasource.password=syl6413
datasource.maxActive=10
datasource.maxIdle=5
datasource.maxWait=5000
datasource.defaultAutoCommit=true
applicationContext.xml代码:
classpath:/datasource.properties
${datasource.driverClassName}
${datasource.url}
${datasource.username}
${datasource.password}
${datasource.maxActive}
${datasource.maxIdle}
${datasource.maxWait}
${datasource.defaultAutoCommit}

二、测试配置连接池

1、测试tomcat连接池
*>不用Spring管理的tomcat连接池测试代码(只能在jsp里面测试):
Context initContext = new InitialContext();
Context envContext =(Context)initContext.lookup(“java:comp/env”);
DataSource ds = (DataSource) envContext.lookup(“jdbc/sqlserver”);
Connection con = ds.getConnection();
if (con != null) {
System.out.println(“已经得到连接”);
} else {
System.out.println(“没有得到连接”);
}

*>用Spring管理tomcat连接池的测试代码:

//ApplicationContext ctx = new FileSystemXmlApplicationContext(“src/applicationContext.xml”);//两种得到bean工厂的代码,任选其一
ApplicationContext ctx = new ClassPathXmlApplicationContext(“applicationContext.xml”);
DataSource ds = (DataSource) ctx.getBean(“dataSource”);
Connection con = ds.getConnection();
if(con != null){
System.out.println(“连接成功”);
}else{
System.out.println(“连接不成功”);
}

2.测试Spring连接池

其实测试Spring连接池的代码和上面Spring管理tomcat连接池测试代码一样:
//ApplicationContext ctx = new FileSystemXmlApplicationContext(“src/applicationContext.xml”);//两种得到bean工厂的代码,任选其一
ApplicationContext ctx = new ClassPathXmlApplicationContext(“applicationContext.xml”);
DataSource ds = (DataSource) ctx.getBean(“dataSource”);
Connection con = ds.getConnection();
if(con != null){
System.out.println(“连接成功”);
}else{
System.out.println(“连接不成功”);
}

三、两种连接池比较

tomcat连接池因为配置tomcat下面的,所有最好用jsp或者maven(模拟窗口测试方法)来测试,但是跟我们的测试带了很多的不变啊,若能在普通java application或者junit方法测试就不容易,也不知道杂写,若高手知道请指教

而Spring连接池与HTTP协议无关,可直接通过java application或junit直接使用,大大地方便了测试和使用.

在效率方面,我倒没认真测试有什么不同,但是我觉得,都是用的第三方连接池管理,应该差别不大,有不同见解的朋友请指出来,共同学习!!