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?
一个连接池的执行时间提前创建连接的工作运行.对于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)