连接池的应用

连接池:初始化(建立)一些连接,常驻内存,用的时候向连接池要,用完由连接池回收,然后给需要的地方用。如果不够用的话,可以继续初始化一些连接。当发现有些连接处于休眠状态,就会自动把它关掉;当有过多的连接请求,则会让其排队(同步)。

可以创建多个连接池,每个连接池都有一个别名。在项目启动的时候,连接池就会创建好。

一、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();

你可能感兴趣的:(sql,xml,应用服务器,mysql,servlet)