|
數(shù)據(jù)庫連接緩沖池
一個(gè)數(shù)據(jù)庫緩沖池指的是緩存于內(nèi)存空間中的數(shù)據(jù)庫物理連接,這些數(shù)據(jù)庫連接可以被重復(fù)使用。數(shù)據(jù)庫緩沖池對于提高Java 數(shù)據(jù)庫應(yīng)用程序的性能十分重要,尤其是當(dāng)這個(gè)Java 數(shù)據(jù)庫應(yīng)用程序運(yùn)行于中間層服務(wù)器環(huán)境時(shí)。 數(shù)據(jù)緩沖池存在于中間層服務(wù)器環(huán)境當(dāng)中,可以被不同的Java 應(yīng)用程序所調(diào)用。javax.sql.RowSet 包添加了對緩沖數(shù)據(jù)源的支持,即可以將緩沖池緩沖的數(shù)據(jù)庫連接看作是一個(gè)是實(shí)實(shí)在在的數(shù)據(jù)源服務(wù)來使用。RowSet 包提供了好幾個(gè)接口用于處理數(shù)據(jù)庫緩沖池,主要的接口有: 例 <% 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 代碼段的運(yùn)行機(jī)理如下 1、首先程序代碼獲取初始化的JNDI 環(huán)境并且調(diào)用Context.lookup()方法從JNDI服務(wù)提供者那里獲一個(gè)DataSource 對象 2、中間層JNDI 服務(wù)提供者返回一個(gè)DataSource 對象給當(dāng)前的Java 應(yīng)用程序這個(gè)DataSource 對象代表了中間層服務(wù)上現(xiàn)存的緩沖數(shù)據(jù)源 3、 應(yīng)用程序調(diào)用DataSource 對象的getConnection()方法 4、當(dāng)DataSource 對象的getConnection()方法被調(diào)用時(shí)中間層服務(wù)器將查詢數(shù)據(jù)庫連接緩沖池中有沒有PooledConnection 接口的實(shí)例對象這個(gè)PooledConnection對象將被用于與數(shù)據(jù)庫建立物理上的數(shù)據(jù)庫連接 5、如果在緩沖池中命中了一個(gè)PooledCoonection 對象那么連接緩沖池將簡單地更新內(nèi)部的緩沖連接隊(duì)列并將該PooledConnection 對象返回如果在緩沖池內(nèi)沒有找到現(xiàn)成的PooledConnection 對象那么ConnectionPoolDataSource 接口將會(huì)被用來產(chǎn)生一個(gè)新的PooledConnection 對象并將它返回以便應(yīng)用程序使用 6\中間層服務(wù)器調(diào)用PooledConnection 對象的getConnection()方法以便返還一個(gè)java.sql.Connection 對象給當(dāng)前的Java 應(yīng)用程序 7、當(dāng)中間層服務(wù)器調(diào)用PooledConnection 對象的getConnection()方法時(shí)JDBC 數(shù)據(jù)庫驅(qū)動(dòng)程序?qū)?huì)創(chuàng)建一個(gè)Connection 對象并且把它返回中間層服務(wù)器 8、中間層服務(wù)器將Connection 對象返回給應(yīng)用程序Java 應(yīng)用程序可以認(rèn)為這個(gè)Connection 對象是一個(gè)普通的JDBC Connection 對象使用它可以和數(shù)據(jù)庫建立事實(shí)上的連接與數(shù)據(jù)庫引擎產(chǎn)生交互操作 9、當(dāng)應(yīng)用程序不需要使用Connection 對象時(shí),可以調(diào)用Connection 接口的close()方法。請注意這種情況下close()方法并沒有關(guān)閉事實(shí)上的數(shù)據(jù)庫連接,僅僅是釋放了被應(yīng)用程序占用的數(shù)據(jù)庫連接,并將它還給數(shù)據(jù)庫連接緩沖池,數(shù)據(jù)庫連接緩沖池會(huì)自動(dòng)將這個(gè)數(shù)據(jù)庫連接交給請求隊(duì)列中下一個(gè)的應(yīng)用程序使用。 |
|
|