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