趙登峰+朱洪濤
【摘 要】 本文探討了數(shù)據(jù)庫連接池的原理,并給出了一個在Tomcat服務(wù)器上配置了數(shù)據(jù)庫連接池的實例。
【關(guān)鍵詞】 數(shù)據(jù)庫連接池 Jsp Tomcat服務(wù)器
1 引言
在實際開發(fā)中,特別是在Web應(yīng)用中,如果JSP使用JDBC直接訪問數(shù)據(jù)庫中的數(shù)據(jù),每一次數(shù)據(jù)訪問請求都必須經(jīng)歷建立數(shù)據(jù)庫連接、打開數(shù)據(jù)庫、存取數(shù)據(jù)和關(guān)閉數(shù)據(jù)庫連接等步驟,而連接并打開數(shù)據(jù)庫是一件既消耗系統(tǒng)內(nèi)存又耗費時間的工作,而且如果頻繁執(zhí)行這些數(shù)據(jù)庫操作,勢必占用很多系統(tǒng)資源,系統(tǒng)的性能必然會急劇下降,甚至?xí)?dǎo)致系統(tǒng)崩潰。數(shù)據(jù)庫連接池技術(shù)[1]是解決這個問題最常用的方法。
2 數(shù)據(jù)庫連接池實現(xiàn)原理
為了解決消耗系統(tǒng)資源問題,可以事先先創(chuàng)建一定數(shù)量的連接放入連接池中提供給用戶使用,用戶使用完后把連接返回連接池。
2.1 創(chuàng)建連接池
首先要創(chuàng)建一個靜態(tài)的連接池。這里的“靜態(tài)”是指池中的連接是在系統(tǒng)初始化時就分配好的,并且不隨意關(guān)閉。Java提供了很多容器類可用來構(gòu)建連接池,例如Stack,Vector等。在系統(tǒng)初始化時,根據(jù)配置創(chuàng)建連接并放置在連接池中,以后所使用的連接都是從該連接池中獲取的,這樣就可以避免連接隨意建立、關(guān)閉造成的系統(tǒng)浪費。
2.2 分配、釋放策略
創(chuàng)建好連接池后,需要提供一套自定義的分配、釋放策略以保證數(shù)據(jù)庫連接的有效復(fù)用。當(dāng)客戶請求數(shù)據(jù)庫連接時,首先看連接池中是否有空閑連接,如果存在空閑連接則把連接分配給客戶,并作相應(yīng)處理;若池中沒有空閑連接,就在已經(jīng)分配出去的連接中,尋找一個合適的連接給客戶,此時該連接在多個客戶間復(fù)用。當(dāng)客戶釋放數(shù)據(jù)庫連接時,可以根據(jù)該連接是否被復(fù)用,進(jìn)行不同的處理。如果連接沒有使用者,就再重新放入池中,而不是被關(guān)閉。
2.3 配置策略
數(shù)據(jù)庫連接池中到底放多少個連接,連接耗盡后該如何處理,這就是配置策略需要解決的問題。在一般情況下,配置策略[2]在開始時就根據(jù)具體的應(yīng)用需求,給出一個初始的連接池中的數(shù)目以及一個連接池可以擴張的最大連接數(shù)目。
3 Tomcat中數(shù)據(jù)連接池的配置實例
以上講述了數(shù)據(jù)庫連接池的原理,下面給出一個具體的實例來說明如何配置Tomcat服務(wù)器的連接池。以SQL Sever 2005數(shù)據(jù)庫為例。
首先在進(jìn)行Tomcat連接池配置之前,先將SQL Server 2005數(shù)據(jù)庫連接驅(qū)動程序包sqljdbc.jar放置于Tomcat 5.5安裝目錄下的lib目錄中。然后在Tomcat 5.5安裝目錄下的conf目錄中的context.xml文件的
在項目的/WEB-INF/目錄想的web.xml配置文件中添加數(shù)據(jù)連接池的引用代碼,具體配置代碼[3]如下:
<!--對數(shù)據(jù)庫連接池的描述 -->
<!--數(shù)據(jù)庫連接池引用名稱 -->
<!--數(shù)據(jù)庫連接池引用類型 -->
這樣,Tomcat服務(wù)器上SQL Server 2005數(shù)據(jù)庫的連接池就被引入到Web應(yīng)用程序中了。
下面創(chuàng)建測試數(shù)據(jù)庫連接池的頁面。在項目中創(chuàng)建顯示全部用戶信息的頁面showUser.jsp,其具體代碼如下:
<%@ page language = “java” import =”java.sql.*,javax.sql.*,javax.naming.*” pageEncoding=”GB2312”%>
<% try { DataSource ds =null;
InitialContext ctx =new InitialContext();//建立上下文對象
//通過JNDI查找數(shù)據(jù)連接池 Ds =(DataSource) ctx.lookup(“java:comp/env/jdbc/dbpooling”);
Connection con=ds.getConnection();//獲得數(shù)據(jù)庫連接對象
//創(chuàng)建PreparedStatement對象
PreparedStatement pst =con.prepareStatement(“select * from [User]”);
ResultSet rs =pst.executeQuery();//獲取結(jié)果集
Out.println(“”);
Out.println (“”);
//遍歷顯示結(jié)果集中的數(shù)據(jù)
while (rs.next()) { out.println(“”);
out.println(rs.gerString(3)); out.println(“”);
}
out.println(“
“用戶名” | 密碼 |
”); out.println(rs.gerString(2)); out.println(“ |
} catch (SQLException e) {
out.println(e);
} %>
將項目部署到Tomcat服務(wù)器上,啟動服務(wù)器進(jìn)行訪問,程序通過測試。這里需要說明的是,配置完服務(wù)器中的連接池后,必須重新啟動服務(wù)器,數(shù)據(jù)連接池才會有效。
參考文獻(xiàn):
[1]馬建紅,李占波.JSP應(yīng)用與開發(fā)技術(shù).2011.01
[2]孫更新,等編著. Java Web開發(fā).2011.02
[3]飛思科技產(chǎn)品研發(fā)中心,JSP應(yīng)用開發(fā)詳解.北京:電子工業(yè)出版社,2005.12,179-198,540-562.
【摘 要】 本文探討了數(shù)據(jù)庫連接池的原理,并給出了一個在Tomcat服務(wù)器上配置了數(shù)據(jù)庫連接池的實例。
【關(guān)鍵詞】 數(shù)據(jù)庫連接池 Jsp Tomcat服務(wù)器
1 引言
在實際開發(fā)中,特別是在Web應(yīng)用中,如果JSP使用JDBC直接訪問數(shù)據(jù)庫中的數(shù)據(jù),每一次數(shù)據(jù)訪問請求都必須經(jīng)歷建立數(shù)據(jù)庫連接、打開數(shù)據(jù)庫、存取數(shù)據(jù)和關(guān)閉數(shù)據(jù)庫連接等步驟,而連接并打開數(shù)據(jù)庫是一件既消耗系統(tǒng)內(nèi)存又耗費時間的工作,而且如果頻繁執(zhí)行這些數(shù)據(jù)庫操作,勢必占用很多系統(tǒng)資源,系統(tǒng)的性能必然會急劇下降,甚至?xí)?dǎo)致系統(tǒng)崩潰。數(shù)據(jù)庫連接池技術(shù)[1]是解決這個問題最常用的方法。
2 數(shù)據(jù)庫連接池實現(xiàn)原理
為了解決消耗系統(tǒng)資源問題,可以事先先創(chuàng)建一定數(shù)量的連接放入連接池中提供給用戶使用,用戶使用完后把連接返回連接池。
2.1 創(chuàng)建連接池
首先要創(chuàng)建一個靜態(tài)的連接池。這里的“靜態(tài)”是指池中的連接是在系統(tǒng)初始化時就分配好的,并且不隨意關(guān)閉。Java提供了很多容器類可用來構(gòu)建連接池,例如Stack,Vector等。在系統(tǒng)初始化時,根據(jù)配置創(chuàng)建連接并放置在連接池中,以后所使用的連接都是從該連接池中獲取的,這樣就可以避免連接隨意建立、關(guān)閉造成的系統(tǒng)浪費。
2.2 分配、釋放策略
創(chuàng)建好連接池后,需要提供一套自定義的分配、釋放策略以保證數(shù)據(jù)庫連接的有效復(fù)用。當(dāng)客戶請求數(shù)據(jù)庫連接時,首先看連接池中是否有空閑連接,如果存在空閑連接則把連接分配給客戶,并作相應(yīng)處理;若池中沒有空閑連接,就在已經(jīng)分配出去的連接中,尋找一個合適的連接給客戶,此時該連接在多個客戶間復(fù)用。當(dāng)客戶釋放數(shù)據(jù)庫連接時,可以根據(jù)該連接是否被復(fù)用,進(jìn)行不同的處理。如果連接沒有使用者,就再重新放入池中,而不是被關(guān)閉。
2.3 配置策略
數(shù)據(jù)庫連接池中到底放多少個連接,連接耗盡后該如何處理,這就是配置策略需要解決的問題。在一般情況下,配置策略[2]在開始時就根據(jù)具體的應(yīng)用需求,給出一個初始的連接池中的數(shù)目以及一個連接池可以擴張的最大連接數(shù)目。
3 Tomcat中數(shù)據(jù)連接池的配置實例
以上講述了數(shù)據(jù)庫連接池的原理,下面給出一個具體的實例來說明如何配置Tomcat服務(wù)器的連接池。以SQL Sever 2005數(shù)據(jù)庫為例。
首先在進(jìn)行Tomcat連接池配置之前,先將SQL Server 2005數(shù)據(jù)庫連接驅(qū)動程序包sqljdbc.jar放置于Tomcat 5.5安裝目錄下的lib目錄中。然后在Tomcat 5.5安裝目錄下的conf目錄中的context.xml文件的
在項目的/WEB-INF/目錄想的web.xml配置文件中添加數(shù)據(jù)連接池的引用代碼,具體配置代碼[3]如下:
<!--對數(shù)據(jù)庫連接池的描述 -->
<!--數(shù)據(jù)庫連接池引用名稱 -->
<!--數(shù)據(jù)庫連接池引用類型 -->
這樣,Tomcat服務(wù)器上SQL Server 2005數(shù)據(jù)庫的連接池就被引入到Web應(yīng)用程序中了。
下面創(chuàng)建測試數(shù)據(jù)庫連接池的頁面。在項目中創(chuàng)建顯示全部用戶信息的頁面showUser.jsp,其具體代碼如下:
<%@ page language = “java” import =”java.sql.*,javax.sql.*,javax.naming.*” pageEncoding=”GB2312”%>
<% try { DataSource ds =null;
InitialContext ctx =new InitialContext();//建立上下文對象
//通過JNDI查找數(shù)據(jù)連接池 Ds =(DataSource) ctx.lookup(“java:comp/env/jdbc/dbpooling”);
Connection con=ds.getConnection();//獲得數(shù)據(jù)庫連接對象
//創(chuàng)建PreparedStatement對象
PreparedStatement pst =con.prepareStatement(“select * from [User]”);
ResultSet rs =pst.executeQuery();//獲取結(jié)果集
Out.println(“”);
Out.println (“”);
//遍歷顯示結(jié)果集中的數(shù)據(jù)
while (rs.next()) { out.println(“”);
out.println(rs.gerString(3)); out.println(“”);
}
out.println(“
“用戶名” | 密碼 |
”); out.println(rs.gerString(2)); out.println(“ |
} catch (SQLException e) {
out.println(e);
} %>
將項目部署到Tomcat服務(wù)器上,啟動服務(wù)器進(jìn)行訪問,程序通過測試。這里需要說明的是,配置完服務(wù)器中的連接池后,必須重新啟動服務(wù)器,數(shù)據(jù)連接池才會有效。
參考文獻(xiàn):
[1]馬建紅,李占波.JSP應(yīng)用與開發(fā)技術(shù).2011.01
[2]孫更新,等編著. Java Web開發(fā).2011.02
[3]飛思科技產(chǎn)品研發(fā)中心,JSP應(yīng)用開發(fā)詳解.北京:電子工業(yè)出版社,2005.12,179-198,540-562.
【摘 要】 本文探討了數(shù)據(jù)庫連接池的原理,并給出了一個在Tomcat服務(wù)器上配置了數(shù)據(jù)庫連接池的實例。
【關(guān)鍵詞】 數(shù)據(jù)庫連接池 Jsp Tomcat服務(wù)器
1 引言
在實際開發(fā)中,特別是在Web應(yīng)用中,如果JSP使用JDBC直接訪問數(shù)據(jù)庫中的數(shù)據(jù),每一次數(shù)據(jù)訪問請求都必須經(jīng)歷建立數(shù)據(jù)庫連接、打開數(shù)據(jù)庫、存取數(shù)據(jù)和關(guān)閉數(shù)據(jù)庫連接等步驟,而連接并打開數(shù)據(jù)庫是一件既消耗系統(tǒng)內(nèi)存又耗費時間的工作,而且如果頻繁執(zhí)行這些數(shù)據(jù)庫操作,勢必占用很多系統(tǒng)資源,系統(tǒng)的性能必然會急劇下降,甚至?xí)?dǎo)致系統(tǒng)崩潰。數(shù)據(jù)庫連接池技術(shù)[1]是解決這個問題最常用的方法。
2 數(shù)據(jù)庫連接池實現(xiàn)原理
為了解決消耗系統(tǒng)資源問題,可以事先先創(chuàng)建一定數(shù)量的連接放入連接池中提供給用戶使用,用戶使用完后把連接返回連接池。
2.1 創(chuàng)建連接池
首先要創(chuàng)建一個靜態(tài)的連接池。這里的“靜態(tài)”是指池中的連接是在系統(tǒng)初始化時就分配好的,并且不隨意關(guān)閉。Java提供了很多容器類可用來構(gòu)建連接池,例如Stack,Vector等。在系統(tǒng)初始化時,根據(jù)配置創(chuàng)建連接并放置在連接池中,以后所使用的連接都是從該連接池中獲取的,這樣就可以避免連接隨意建立、關(guān)閉造成的系統(tǒng)浪費。
2.2 分配、釋放策略
創(chuàng)建好連接池后,需要提供一套自定義的分配、釋放策略以保證數(shù)據(jù)庫連接的有效復(fù)用。當(dāng)客戶請求數(shù)據(jù)庫連接時,首先看連接池中是否有空閑連接,如果存在空閑連接則把連接分配給客戶,并作相應(yīng)處理;若池中沒有空閑連接,就在已經(jīng)分配出去的連接中,尋找一個合適的連接給客戶,此時該連接在多個客戶間復(fù)用。當(dāng)客戶釋放數(shù)據(jù)庫連接時,可以根據(jù)該連接是否被復(fù)用,進(jìn)行不同的處理。如果連接沒有使用者,就再重新放入池中,而不是被關(guān)閉。
2.3 配置策略
數(shù)據(jù)庫連接池中到底放多少個連接,連接耗盡后該如何處理,這就是配置策略需要解決的問題。在一般情況下,配置策略[2]在開始時就根據(jù)具體的應(yīng)用需求,給出一個初始的連接池中的數(shù)目以及一個連接池可以擴張的最大連接數(shù)目。
3 Tomcat中數(shù)據(jù)連接池的配置實例
以上講述了數(shù)據(jù)庫連接池的原理,下面給出一個具體的實例來說明如何配置Tomcat服務(wù)器的連接池。以SQL Sever 2005數(shù)據(jù)庫為例。
首先在進(jìn)行Tomcat連接池配置之前,先將SQL Server 2005數(shù)據(jù)庫連接驅(qū)動程序包sqljdbc.jar放置于Tomcat 5.5安裝目錄下的lib目錄中。然后在Tomcat 5.5安裝目錄下的conf目錄中的context.xml文件的
在項目的/WEB-INF/目錄想的web.xml配置文件中添加數(shù)據(jù)連接池的引用代碼,具體配置代碼[3]如下:
<!--對數(shù)據(jù)庫連接池的描述 -->
<!--數(shù)據(jù)庫連接池引用名稱 -->
<!--數(shù)據(jù)庫連接池引用類型 -->
這樣,Tomcat服務(wù)器上SQL Server 2005數(shù)據(jù)庫的連接池就被引入到Web應(yīng)用程序中了。
下面創(chuàng)建測試數(shù)據(jù)庫連接池的頁面。在項目中創(chuàng)建顯示全部用戶信息的頁面showUser.jsp,其具體代碼如下:
<%@ page language = “java” import =”java.sql.*,javax.sql.*,javax.naming.*” pageEncoding=”GB2312”%>
<% try { DataSource ds =null;
InitialContext ctx =new InitialContext();//建立上下文對象
//通過JNDI查找數(shù)據(jù)連接池 Ds =(DataSource) ctx.lookup(“java:comp/env/jdbc/dbpooling”);
Connection con=ds.getConnection();//獲得數(shù)據(jù)庫連接對象
//創(chuàng)建PreparedStatement對象
PreparedStatement pst =con.prepareStatement(“select * from [User]”);
ResultSet rs =pst.executeQuery();//獲取結(jié)果集
Out.println(“”);
Out.println (“”);
//遍歷顯示結(jié)果集中的數(shù)據(jù)
while (rs.next()) { out.println(“”);
out.println(rs.gerString(3)); out.println(“”);
}
out.println(“
“用戶名” | 密碼 |
”); out.println(rs.gerString(2)); out.println(“ |
} catch (SQLException e) {
out.println(e);
} %>
將項目部署到Tomcat服務(wù)器上,啟動服務(wù)器進(jìn)行訪問,程序通過測試。這里需要說明的是,配置完服務(wù)器中的連接池后,必須重新啟動服務(wù)器,數(shù)據(jù)連接池才會有效。
參考文獻(xiàn):
[1]馬建紅,李占波.JSP應(yīng)用與開發(fā)技術(shù).2011.01
[2]孫更新,等編著. Java Web開發(fā).2011.02
[3]飛思科技產(chǎn)品研發(fā)中心,JSP應(yīng)用開發(fā)詳解.北京:電子工業(yè)出版社,2005.12,179-198,540-562.