一個(gè)數據庫緩沖池指的是緩存于內存空間中的數據庫物理連接,這些數據庫連接可以被重復使用。數據庫緩沖池對于提高Java 數據庫應用程序的性能十分重要,尤其是當這個(gè)Java 數據庫應用程序運行于中間層服務(wù)器環(huán)境時(shí)。
數據緩沖池存在于中間層服務(wù)器環(huán)境當中,可以被不同的Java 應用程序所調用。javax.sql.RowSet 包添加了對緩沖數據源的支持,即可以將緩沖池緩沖的數據庫連接看作是一個(gè)是實(shí)實(shí)在在的數據源服務(wù)來(lái)使用。RowSet 包提供了好幾個(gè)接口用于處理數據庫緩沖池,主要的接口有:
1、DataSource 接口:DataSource 接口的實(shí)例對象代表了存在于中間層服務(wù)器中的緩沖數據源服務(wù)。使用它可以返還數據庫緩沖池中現存的數據庫連接,DataSource 接口的實(shí)例對象實(shí)際上是某個(gè)JNDI 服務(wù)的提供者,在使用它之前,該JNDI 服務(wù)對象必須先在中間層服務(wù)器環(huán)境中注冊,并且和某個(gè)服務(wù)名綁定在一起,然后它才能被別的Java 應用程序調用。
2、ConnectionPoolDataSource 接口:該接口可以用于創(chuàng )建一個(gè)被緩沖于緩沖池的數據庫物理連接,它有可能會(huì )被DataSource 接口的實(shí)例對象調用。
3、PooledConnection 接口:該接口代表被緩沖的數據庫連接,它定義了一個(gè)getConnection()方法使用這個(gè)方法可以返回java.sql.Connection 接口的實(shí)例對象。
如何使用RowSet 包定義的類(lèi)和接口操作數據庫緩沖池,下面的JSP 代碼段提供了一個(gè)簡(jiǎn)單的不完整的例子
例
<%
Context ctx = new InitialContext();
DataSource ds = (DataSource)ctx.lookup(“jdbc/EmployeeDB”);
// First get a Connection. Connection pooling is done
// internally by the DataSource object.
Connection con = ds.getConnection(jdbc/webDatabase” "sa” “");
// Do all the work as a single transaction (optional).
con.setAutoCommit(false);
// The actual work (queries and updates) would go here.
// Work is done using standard JDBC code as defined in the
// rest of the JDBC API.
// Commit the transaction.
con.commit();
// Close the connection. This returns the underlying physical
// database connection to the pool.
con.close();
%>
上面的JSP 代碼段的運行機理如下
1、首先程序代碼獲取初始化的JNDI 環(huán)境并且調用Context.lookup()方法從JNDI服務(wù)提供者那里獲一個(gè)DataSource 對象
2、中間層JNDI 服務(wù)提供者返回一個(gè)DataSource 對象給當前的Java 應用程序這個(gè)DataSource 對象代表了中間層服務(wù)上現存的緩沖數據源
3、 應用程序調用DataSource 對象的getConnection()方法
4、當DataSource 對象的getConnection()方法被調用時(shí)中間層服務(wù)器將查詢(xún)數據庫連接緩沖池中有沒(méi)有PooledConnection 接口的實(shí)例對象這個(gè)PooledConnection對象將被用于與數據庫建立物理上的數據庫連接
5、如果在緩沖池中命中了一個(gè)PooledCoonection 對象那么連接緩沖池將簡(jiǎn)單地更新內部的緩沖連接隊列并將該PooledConnection 對象返回如果在緩沖池內沒(méi)有找到現成的PooledConnection 對象那么ConnectionPoolDataSource 接口將會(huì )被用來(lái)產(chǎn)生一個(gè)新的PooledConnection 對象并將它返回以便應用程序使用
6\中間層服務(wù)器調用PooledConnection 對象的getConnection()方法以便返還一個(gè)java.sql.Connection 對象給當前的Java 應用程序
7、當中間層服務(wù)器調用PooledConnection 對象的getConnection()方法時(shí)JDBC 數據庫驅動(dòng)程序將會(huì )創(chuàng )建一個(gè)Connection 對象并且把它返回中間層服務(wù)器
8、中間層服務(wù)器將Connection 對象返回給應用程序Java 應用程序可以認為這個(gè)Connection 對象是一個(gè)普通的JDBC Connection 對象使用它可以和數據庫建立事實(shí)上的連接與數據庫引擎產(chǎn)生交互操作
9、當應用程序不需要使用Connection 對象時(shí),可以調用Connection 接口的close()方法。請注意這種情況下close()方法并沒(méi)有關(guān)閉事實(shí)上的數據庫連接,僅僅是釋放了被應用程序占用的數據庫連接,并將它還給數據庫連接緩沖池,數據庫連接緩沖池會(huì )自動(dòng)將這個(gè)數據庫連接交給請求隊列中下一個(gè)的應用程序使用。
聯(lián)系客服