如何在java中进行连接池?

suj*_*jit 4 java oracle servlets connection-pooling jdbc

我想了解connection pooling in java,我jsp, servlet and tomcat 6 server在我的申请中使用.我在以下代码中编写了以下代码java class dbconnection.java:

我在windows Xp OS中使用类型4 jdbc连接与oracle 10g EE

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

    public class dbconnection {   
     public Connection con = null;    
      public Connection getConnection() throws Exception, SQLException
       {
         try
           {
          Class.forName("oracle.jdbc.driver.OracleDriver");
           con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:abc","abc", "abc");           
           }
           catch(Exception e)
           {          
           }
        return con;
        }
    public void removeConnection() throws SQLException
  {
    con.close();
  }
 }
Run Code Online (Sandbox Code Playgroud)

然后我connection在servlet中重试如下:

try{
 dbconnection db= new dbconnection();

 Connection con=db.getConnection();
 }
 catch(Exception e){
 } 
finally{
 db.removeConnection();//removes connection
}
Run Code Online (Sandbox Code Playgroud)

connection pooling或某些配置是否需要tomcat server

Rut*_*war 6

一个连接池的执行时间提前创建连接的工作运行.对于JDBC连接池,在应用程序服务器启动时会创建一个Connection对象池.客户端可以访问连接池中的连接对象,并在完成db工作后将对象返回到池.

的context.xml

   <Resource name="jdbc/TestDB" auth="Container" type="javax.sql.DataSource" 
maxActive="100" maxIdle="30" maxWait="10000" username="root" password="" 
driverClassName="com.mysql.jdbc.Driver"               
url="jdbc:mysql://localhost:3306/cdcol"/>
Run Code Online (Sandbox Code Playgroud)

//这应该添加到服务器上下文xml文件中.例如,如果您使用的是apache服务器,则可以在C:\ apache-tomcat-6.0.26\conf\Context.xml中找到context.xml.

web.xml中

  <resource-ref>
      <description>DB Connection</description>
      <res-ref-name>jdbc/TestDB</res-ref-name>
      <res-type>javax.sql.DataSource</res-type>
      <res-auth>Container</res-auth>
  </resource-ref>
Run Code Online (Sandbox Code Playgroud)

//这应该添加到本地项目的web.xml中.(不在服务器的web.xml中).

Context ctx=new InitialContext();
          Context envContext = (Context)ctx.lookup("java:comp/env");
          DataSource ds=(DataSource)envContext.lookup("jdbc/TestDB");//TestDB is the Database Name
          con=ds.getConnection();
          stmt = con.createStatement();
Run Code Online (Sandbox Code Playgroud)