连接池:初始化(建立)一些连接,常驻内存,用的时候向连接池要,用完由连接池回收,然后给需要的地方用。如果不够用的话,可以继续初始化一些连接。当发现有些连接处于休眠状态,就会自动把它关掉;当有过多的连接请求,则会让其排队(同步)。
可以创建多个连接池,每个连接池都有一个别名。在项目启动的时候,连接池就会创建好。
一、proxool
(1)加载驱动 library proxool0.9.jar
(2)配置连接池的配置文件proxool.xml
<?xml version="1.0" encoding="UTF-8"?>
<something-else-entirely>
<proxool>
<alias>xml-test</alias>
<driver-url>jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb</driver-url>
<driver-class>com.microsoft.jdbc.sqlserver.SQLServerDriver</driver-class>
<driver-properties>
<property name="user" value="sa"/>
<property name="password" value=""/>
</driver-properties>
<maximum-connection-count>50</maximum-connection-count>
<maximum-active-time>1</maximum-active-time>
<house-keeping-test-sql>select getdate()</house-keeping-test-sql>
</proxool>
<proxool>
<alias>xml-test2</alias>
<driver-url>jdbc:mysql://localhost:3306/mydb</driver-url>
<driver-class>com.mysql.jdbc.Driver</driver-class>
<driver-properties>
<property name="user" value="root"/>
<property name="password" value=""/>
</driver-properties>
<maximum-connection-count>50</maximum-connection-count>
<maximum-active-time>1</maximum-active-time>
<house-keeping-test-sql>select curdate()</house-keeping-test-sql>
</proxool>
</something-else-entirely>
(3)把配置文件配到web.xml,让web服务器在启动时加载配置文件proxool.xml
<servlet>
<servlet-name>AdminServlet</servlet-name>
<servlet-class>org.logicalcobwebs.proxool.admin.servlet.AdminServlet</servlet-class>
</servlet>
<servlet>
<servlet-name>ServletConfigurator</servlet-name>
<servlet-class>org.logicalcobwebs.proxool.configuration.ServletConfigurator</servlet-class>
<init-param>
<param-name>xmlFile</param-name>
<param-value>WEB-INF/proxool.xml</param-value>
</init-param>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>AdminServlet</servlet-name>
<url-pattern>/adminservlet</url-pattern>
</servlet-mapping>
(4)在连接数据库的类中使用
Class.forName("org.logicalcobwebs.proxool.ProxoolDriver").newInstance();//加载连接池的驱动类
conn=DriverManager.getConnection("proxool.xml-test");//从连接池取的连接,其中xml-test为连接池的别名
二、apache的dbcp连接池
(1)导入3个驱动library的jar包
commons-collections.jar
commons-dbcp-1.2.1.jar
commons-pool-1.3.jar
(2)在连接数据库的类中使用
BasicDataSource bs=new BasicDataSource();//通过数据源来创建连接池
bs.setUrl(this.url);
bs.setDriver(this.driver);
bs.setUsername(this.user);
bs.setPassword("");
bs.setInitialSize(4);//初始化尺寸
bs.setMaxActive(100);
conn=bs.getConnection();