![第七章-數(shù)據庫連接池及JNDI技術_第1頁](http://file4.renrendoc.com/view/327ea6657ce0c7e3068939ee39dd1b61/327ea6657ce0c7e3068939ee39dd1b611.gif)
![第七章-數(shù)據庫連接池及JNDI技術_第2頁](http://file4.renrendoc.com/view/327ea6657ce0c7e3068939ee39dd1b61/327ea6657ce0c7e3068939ee39dd1b612.gif)
![第七章-數(shù)據庫連接池及JNDI技術_第3頁](http://file4.renrendoc.com/view/327ea6657ce0c7e3068939ee39dd1b61/327ea6657ce0c7e3068939ee39dd1b613.gif)
![第七章-數(shù)據庫連接池及JNDI技術_第4頁](http://file4.renrendoc.com/view/327ea6657ce0c7e3068939ee39dd1b61/327ea6657ce0c7e3068939ee39dd1b614.gif)
![第七章-數(shù)據庫連接池及JNDI技術_第5頁](http://file4.renrendoc.com/view/327ea6657ce0c7e3068939ee39dd1b61/327ea6657ce0c7e3068939ee39dd1b615.gif)
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第五章數(shù)據庫連接池及JNDI技術本節(jié)內容JNDI概述連接池及JNDI的應用本講目標連接池及JNDI的應用JNDI介紹什么是JNDIJNDI(JavaNamingandDirectoryInterface,Java命名和目錄接口)是一組在Java應用中訪問命名和目錄服務的API通過名稱將資源與服務進行關聯(lián)JNDI的簡單應用應用步驟修改Tomcat\conf\context.xml文件使用lookup()進行查找<Context><Environmentname="tjndi"value="helloJNDI"type="java.lang.String"/></Context>//javax.naming.Context提供了查找JNDI的接口Contextctx=newInitialContext();
//java:comp/env/為前綴Stringtestjndi=(String)ctx.lookup("java:comp/env/tjndi");out.println("JNDI:"+testjndi);初始化Context對象調用lookup()方法JNDI查找的名稱生活中的連接池普通電話----建立連接,等待回應熱線電話----已建立連接連接已連接開始通話開始通話已連接,直接通話連接中傳統(tǒng)數(shù)據庫連接方式的不足每一次請求時均需要與數(shù)據庫進行連接,資源占用較多當并發(fā)訪問數(shù)量較大時,網站速度收到極大影響在訪問結束后必須要關閉連接釋放資源系統(tǒng)的安全性和穩(wěn)定性相對較差為什么使用連接池為什么使用連接池企業(yè)級開發(fā)需要穩(wěn)健和高效的數(shù)據訪問層完成對數(shù)據庫的CRUD操作能夠處理數(shù)據庫發(fā)生的各種錯誤可以靈活的修改配置提供方便使用的工具高性能數(shù)據庫請求響應操作結果要求高效、穩(wěn)健的數(shù)據訪問層打開連接,操作數(shù)據庫,關閉連接多次重復操作傳統(tǒng)的JDBC已經無法滿足需求,那怎么辦呢?什么是連接池技術連接池連接池是在內存中預設好一定數(shù)量的連接對象,以備用戶在進行數(shù)據庫操作時直接使用性能數(shù)據庫連接的建立、斷開均由管理池統(tǒng)一管理連接池技術與傳統(tǒng)數(shù)據庫連接的比較數(shù)據庫操作性能得到提升通過連接池管理數(shù)據庫的連接與釋放、提高了系統(tǒng)資源的使用效率連接池技術工作原理連接池中的連接數(shù)據庫想要獲得連接返回一個連接返回一個已連接好的空閑連接應用程序從連接池中獲得連接連接池是由容器提供的,用來管理池中連接對象應用程序連接池Connection1Connection2Connection3數(shù)據源簡介數(shù)據源(DataSource)javax.sql.DataSource接口負責建立與數(shù)據庫的連接從Tomcat的數(shù)據源獲得連接把連接保存在連接池中應用程序Connection1Connection2Connection3數(shù)據庫想要獲得連接返回一個連接連接池連接池中的連接對象是由誰創(chuàng)建的呢?訪問數(shù)據源如何獲得DataSource對象數(shù)據源由Tomcat提供,不能在程序中創(chuàng)建實例使用JNDI獲得DataSource引用應用程序jdbc/s1jdbc/s2數(shù)據源數(shù)據源名稱Connectioncontext.lookup("jdbc/s1")
importjavax.naming.Context;importjavax.naming.InitialContext;importjavax.naming.NamingException;importjavax.sql.DataSource;public
classTitlesBean{
publicListgetTitles(){try{Contextic=newInitialContext(); DataSourcesource= (DataSource)ic.lookup("java:comp/env/jdbc/news");Connectionconnection=source.getConnection();titlesQuery=connection.prepareStatement("SELECT*FROMtitles");ResultSetresults=titlesQuery.executeQuery(); //為BookBean對象的屬性賦值,并添加到titlesList中
}catch(SQLExceptionexception){exception.printStackTrace();}catch(NamingExceptionnamingException)namingException.printStackTrace();}finally{closeConn();}}}使用JNDI和數(shù)據源要導入的包通過Context、DataSource獲取Connection對象分為兩部分java:comp/env為JavaEE默認路徑jdbc/news為DataSource名定義JNDI異常訪問數(shù)據源訪問數(shù)據源
Tomcat的conf/context.xml中的配置屬性名稱說明name指定Resource的JNDI名稱auth指定管理Resource的Manager(Container:由容器創(chuàng)建和管理|Application:由Web應用創(chuàng)建和管理)type指定Resource所屬的Java類maxActive指定連接池中處于活動狀態(tài)的數(shù)據庫連接的最大數(shù)目maxIdle指定連接池中處于空閑狀態(tài)的數(shù)據庫連接的最大數(shù)目maxWait指定連接池中的連接處于空閑的最長時間,超過這個時間會拋出異常,取值為-1,表示可以無限期等待<Context><Resourcename="jdbc/books"auth="Container"type="javax.sql.DataSource"maxActive="100"maxIdle="30"maxWait="10000"username="scott"password="tiger"driverClassName="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@localhost:1521:orcl"/></Context>訪問數(shù)據源加入數(shù)據庫驅動文件把數(shù)據庫驅動的.jar文件,加入到Tomcat的common\lib中應用程序的web.xml文件的配置(6.0以上版本不用配)在web.xml中配置<resource-ref>
<resource-ref><res-ref-name>jdbc/news</res-ref-name><res-type>javax.sql.DataSource</res-type><res-auth>Container</res-auth></resource-ref>指定JNDI的名字,與<Resource>元素中的name一致指定引用資源的類名,與<Resource>元素中的type一致指定管理所引用資源的Manager與<Resource>元素中的auth一致總結你學到了嗎?連接池的工作原理?如何配置連接池?使用連接池實現(xiàn)數(shù)據庫連接訓練要點:連接池的配置通過JNDI查找數(shù)據源需求說明:通過連接池方式訪問數(shù)據庫實現(xiàn)思路及關鍵代碼:配置cont
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 物理科技在智能交通系統(tǒng)中的應用
- 現(xiàn)代藝術與設計趨勢創(chuàng)新與變革
- 現(xiàn)代營銷中的用戶體驗設計
- 環(huán)境科學與未來綠色發(fā)展的結合策略
- 國慶節(jié)紅色電影活動方案
- Unit7《Lesson 26 I Love My Family》(說課稿)-2024-2025學年北京版(2024)英語三年級上冊
- 2024-2025學年高中地理 第4章 旅游與區(qū)域的發(fā)展 章末分層突破說課稿 中圖版選修3
- Unit 7 Happy Birthday!(說課稿)-2024-2025學年譯林版(三起)(2024)英語三年級上冊
- 2024年屆九年級歷史上冊 第11課 開辟新時代的“宣言”說課稿2 北師大版001
- 《18 初始機器人》說課稿-2023-2024學年清華版(2012)信息技術一年級下冊
- 醫(yī)院消防安全培訓課件
- 質保管理制度
- 《00541語言學概論》自考復習題庫(含答案)
- 2025年機關工會個人工作計劃
- 人事測評理論與方法-課件
- 最新卷宗的整理、裝訂(全)課件
- 城市旅行珠海景色介紹珠海旅游攻略PPT圖文課件
- 小學 三年級 科學《觀測風》教學設計
- JJF1664-2017溫度顯示儀校準規(guī)范-(高清現(xiàn)行)
- 第二講共振理論、有機酸堿理論
- 高考英語聽力必備場景詞匯精選(必看)
評論
0/150
提交評論