第七章數據庫連接池及JNDI技術_第1頁
第七章數據庫連接池及JNDI技術_第2頁
第七章數據庫連接池及JNDI技術_第3頁
第七章數據庫連接池及JNDI技術_第4頁
第七章數據庫連接池及JNDI技術_第5頁
已閱讀5頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、第五章 數據庫連接池及JNDI技術本節(jié)內容 JNDI概述 連接池及JNDI的應用本講目標 連接池及JNDI的應用JNDI介紹 什么是JNDI JNDI(Java Naming and Directory Interface,Java命名和目錄接口) 是一組在Java應用中訪問命名和目錄服務的API 通過名稱將資源與服務進行關聯(lián)JNDI的簡單應用 應用步驟 修改Tomcatconfcontext.xml文件 使用lookup()進行查找 /javax.naming.Context提供了查找提供了查找JNDI 的接口的接口Context ctx = new InitialContext();/ja

2、va:comp/env/為前綴為前綴String testjndi = (String)ctx.lookup(java:comp/env/tjndi);out.println(JNDI: +testjndi);初始化初始化Context對象對象調用調用lookup()方法方法JNDI查找的名稱查找的名稱生活中的連接池 普通電話 -建立連接,等待回應 熱線電話 -已建立連接連接連接已連接已連接開始通話開始通話開始通話開始通話已連接,直接通話已連接,直接通話連接中連接中 傳統(tǒng)數據庫連接方式的不足 每一次請求時均需要與數據庫進行連接,資源占用較多 當并發(fā)訪問數量較大時,網站速度收到極大影響 在訪問結

3、束后必須要關閉連接釋放資源 系統(tǒng)的安全性和穩(wěn)定性相對較差為什么使用連接池為什么使用連接池 企業(yè)級開發(fā)需要穩(wěn)健和高效的數據訪問層 完成對數據庫的CRUD操作 能夠處理數據庫發(fā)生的各種錯誤 可以靈活的修改配置 提供方便使用的工具 高性能請求請求響應響應操作操作結果結果要求高效、穩(wěn)健的數據訪問層要求高效、穩(wěn)健的數據訪問層打開連接,操作數打開連接,操作數據庫,關閉連接據庫,關閉連接多次重復操作多次重復操作傳統(tǒng)的傳統(tǒng)的JDBC已經已經無法滿足需求,那無法滿足需求,那怎么辦呢?怎么辦呢?什么是連接池技術 連接池 連接池是在內存中預設好一定數量的連接對象,以備用戶在進行數據庫操作時直接使用 性能 數據庫連接

4、的建立、斷開均由管理池統(tǒng)一管理 連接池技術與傳統(tǒng)數據庫連接的比較 數據庫操作性能得到提升 通過連接池管理數據庫的連接與釋放、提高了系統(tǒng)資源的使用效率連接池技術工作原理 連接池中的連接想要獲得連接想要獲得連接返回一個連接返回一個連接返回一個已連接返回一個已連接好的空閑連接好的空閑連接應用程序從連接池中獲得連接應用程序從連接池中獲得連接連接池是由容器提供的,連接池是由容器提供的,用來管理池中連接對象用來管理池中連接對象應用程序應用程序連接池連接池Connection1Connection2Connection3數據源簡介 數據源(DataSource) javax.sql.DataSource接口

5、負責建立與數據庫的連接 從Tomcat的數據源獲得連接 把連接保存在連接池中應用程序應用程序Connection1Connection2Connection3想要獲得連接想要獲得連接返回一個連接返回一個連接連接池連接池連接池中的連接對象連接池中的連接對象是由誰創(chuàng)建的呢?是由誰創(chuàng)建的呢?訪問數據源 如何獲得DataSource對象 數據源由Tomcat提供,不能在程序中創(chuàng)建實例 使用JNDI獲得DataSource引用應用程序應用程序jdbc/s1jdbc/s2數據源數據源數據源名稱數據源名稱Connectioncontext.lookup( jdbc/s1 ) import javax.nam

6、ing.Context;import javax.naming.InitialContext;import javax.naming.NamingException;import javax.sql.DataSource;public class TitlesBean public List getTitles() try Context ic = new InitialContext(); DataSource source = (DataSource)ic.lookup(java:comp/env/jdbc/news); Connection connection = source.get

7、Connection(); titlesQuery = connection.prepareStatement(SELECT * FROM titles ); ResultSet results = titlesQuery.executeQuery(); /為為BookBean對象的屬性賦值對象的屬性賦值, ,并添加到并添加到titlesList中中 catch (SQLException exception) exception.printStackTrace(); catch (NamingException namingException) namingException.printSt

8、ackTrace(); finally closeConn(); 使用使用JNDI和數和數據源要導入的包據源要導入的包通過通過Context、DataSource獲取獲取Connection對象對象分為兩部分分為兩部分java:comp/env為為JavaEE默認路徑默認路徑jdbc/news為為DataSource名名定義定義JNDI異常異常訪問數據源訪問數據源 Tomcat的conf/context.xml中的配置 訪問數據源 加入數據庫驅動文件 把數據庫驅動的.jar文件,加入到Tomcat的commonlib中 應用程序的web.xml文件的配置(6.0以上版本不用配) 在web.xml中配置 jdbc/news javax.sql.DataSource Container 指定指定JNDI的名字,與的名字,與元素中的元素中的name一致一致指定引用資源的類名,與指定引用資源的類名,與元素中的元素中的type一致一致指定管理所引用資源的指定管理所引用資源的Manager與與元素中的元素中的auth一致一致總結你學到了嗎?連接池的工作原理?如何配置連接池?使用連接池實現數據庫連接 訓練要點: 連接池的配置 通過JNDI查找數據源需求說明: 通過連接池方式訪問數據庫實現思路及關鍵代碼: 配置context.xml文件 配置web.xml文件 編碼實現查找數據源獲取連接實現

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論