版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第五章數(shù)據(jù)庫(kù)連接池及JNDI技術(shù)本節(jié)內(nèi)容JNDI概述連接池及JNDI的應(yīng)用本講目標(biāo)連接池及JNDI的應(yīng)用JNDI介紹什么是JNDIJNDI(JavaNamingandDirectoryInterface,Java命名和目錄接口)是一組在Java應(yīng)用中訪問命名和目錄服務(wù)的API通過名稱將資源與服務(wù)進(jìn)行關(guān)聯(lián)JNDI的簡(jiǎn)單應(yīng)用應(yīng)用步驟修改Tomcat\conf\context.xml文件使用lookup()進(jìn)行查找<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對(duì)象調(diào)用lookup()方法JNDI查找的名稱生活中的連接池普通電話----建立連接,等待回應(yīng)熱線電話----已建立連接連接已連接開始通話開始通話已連接,直接通話連接中傳統(tǒng)數(shù)據(jù)庫(kù)連接方式的不足每一次請(qǐng)求時(shí)均需要與數(shù)據(jù)庫(kù)進(jìn)行連接,資源占用較多當(dāng)并發(fā)訪問數(shù)量較大時(shí),網(wǎng)站速度收到極大影響在訪問結(jié)束后必須要關(guān)閉連接釋放資源系統(tǒng)的安全性和穩(wěn)定性相對(duì)較差為什么使用連接池為什么使用連接池企業(yè)級(jí)開發(fā)需要穩(wěn)健和高效的數(shù)據(jù)訪問層完成對(duì)數(shù)據(jù)庫(kù)的CRUD操作能夠處理數(shù)據(jù)庫(kù)發(fā)生的各種錯(cuò)誤可以靈活的修改配置提供方便使用的工具高性能數(shù)據(jù)庫(kù)請(qǐng)求響應(yīng)操作結(jié)果要求高效、穩(wěn)健的數(shù)據(jù)訪問層打開連接,操作數(shù)據(jù)庫(kù),關(guān)閉連接多次重復(fù)操作傳統(tǒng)的JDBC已經(jīng)無法滿足需求,那怎么辦呢?什么是連接池技術(shù)連接池連接池是在內(nèi)存中預(yù)設(shè)好一定數(shù)量的連接對(duì)象,以備用戶在進(jìn)行數(shù)據(jù)庫(kù)操作時(shí)直接使用性能數(shù)據(jù)庫(kù)連接的建立、斷開均由管理池統(tǒng)一管理連接池技術(shù)與傳統(tǒng)數(shù)據(jù)庫(kù)連接的比較數(shù)據(jù)庫(kù)操作性能得到提升通過連接池管理數(shù)據(jù)庫(kù)的連接與釋放、提高了系統(tǒng)資源的使用效率連接池技術(shù)工作原理連接池中的連接數(shù)據(jù)庫(kù)想要獲得連接返回一個(gè)連接返回一個(gè)已連接好的空閑連接應(yīng)用程序從連接池中獲得連接連接池是由容器提供的,用來管理池中連接對(duì)象應(yīng)用程序連接池Connection1Connection2Connection3數(shù)據(jù)源簡(jiǎn)介數(shù)據(jù)源(DataSource)javax.sql.DataSource接口負(fù)責(zé)建立與數(shù)據(jù)庫(kù)的連接從Tomcat的數(shù)據(jù)源獲得連接把連接保存在連接池中應(yīng)用程序Connection1Connection2Connection3數(shù)據(jù)庫(kù)想要獲得連接返回一個(gè)連接連接池連接池中的連接對(duì)象是由誰創(chuàng)建的呢?訪問數(shù)據(jù)源如何獲得DataSource對(duì)象數(shù)據(jù)源由Tomcat提供,不能在程序中創(chuàng)建實(shí)例使用JNDI獲得DataSource引用應(yīng)用程序jdbc/s1jdbc/s2數(shù)據(jù)源數(shù)據(jù)源名稱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對(duì)象的屬性賦值,并添加到titlesList中
}catch(SQLExceptionexception){exception.printStackTrace();}catch(NamingExceptionnamingException)namingException.printStackTrace();}finally{closeConn();}}}使用JNDI和數(shù)據(jù)源要導(dǎo)入的包通過Context、DataSource獲取Connection對(duì)象分為兩部分java:comp/env為JavaEE默認(rèn)路徑j(luò)dbc/news為DataSource名定義JNDI異常訪問數(shù)據(jù)源訪問數(shù)據(jù)源
Tomcat的conf/context.xml中的配置屬性名稱說明name指定Resource的JNDI名稱auth指定管理Resource的Manager(Container:由容器創(chuàng)建和管理|Application:由Web應(yīng)用創(chuàng)建和管理)type指定Resource所屬的Java類maxActive指定連接池中處于活動(dòng)狀態(tài)的數(shù)據(jù)庫(kù)連接的最大數(shù)目maxIdle指定連接池中處于空閑狀態(tài)的數(shù)據(jù)庫(kù)連接的最大數(shù)目maxWait指定連接池中的連接處于空閑的最長(zhǎng)時(shí)間,超過這個(gè)時(shí)間會(huì)拋出異常,取值為-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ù)據(jù)源加入數(shù)據(jù)庫(kù)驅(qū)動(dòng)文件把數(shù)據(jù)庫(kù)驅(qū)動(dòng)的.jar文件,加入到Tomcat的common\lib中應(yīng)用程序的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一致總結(jié)你學(xué)到了嗎?連接池的工作原理?如何配置連接池?使用連接池實(shí)現(xiàn)數(shù)據(jù)庫(kù)連接訓(xùn)練要點(diǎn):連接池的配置通過JNDI查找數(shù)據(jù)源需求說明:通過連接池方式訪問數(shù)據(jù)庫(kù)實(shí)現(xiàn)思路及關(guān)鍵代碼:配置cont
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 核心素養(yǎng)視域下高中歷史史料教學(xué)實(shí)施路徑研究-基于后進(jìn)生認(rèn)知發(fā)展的實(shí)證分析
- 部隊(duì)光纜維護(hù)合同范本
- 特斯拉汽車面試通關(guān)課
- 馬邊彝族自治縣公安局2025年第3批次輔警招聘?jìng)淇碱}庫(kù)及參考答案詳解
- 2025年中國(guó)電子備考題庫(kù)產(chǎn)業(yè)發(fā)展研究院備考題庫(kù)化與軟件產(chǎn)業(yè)研究所招聘9-14人備考題庫(kù)及參考答案詳解一套
- 2025年玉環(huán)農(nóng)商銀行專業(yè)崗位招聘?jìng)淇碱}庫(kù)及1套完整答案詳解
- 區(qū)塊鏈技術(shù)在金融行業(yè)中的應(yīng)用潛力分析
- 可持續(xù)農(nóng)業(yè)示范責(zé)任承諾書(6篇)
- 上海市松江區(qū)松江二中2026屆語文高三上期末綜合測(cè)試模擬試題含解析
- 女生偵查學(xué)就業(yè)前景分析
- 運(yùn)動(dòng)技能學(xué)習(xí)與控制課件第十二章運(yùn)動(dòng)技能學(xué)習(xí)的反饋
- 高考作文標(biāo)準(zhǔn)方格紙-A4-可直接打印
- 應(yīng)急救援器材培訓(xùn)課件
- 小學(xué)美術(shù)四年級(jí)上冊(cè) 3. 周末日記 公開課比賽一等獎(jiǎng)
- 塑料制品行業(yè)財(cái)務(wù)工作年度績(jī)效報(bào)告
- 皮膚科護(hù)理中的振動(dòng)按摩在皮膚病管理中的應(yīng)用
- 20以內(nèi)進(jìn)位加法100題(精心整理6套-可打印A4)
- 腸內(nèi)營(yíng)養(yǎng)考評(píng)標(biāo)準(zhǔn)終
- 項(xiàng)目全周期現(xiàn)金流管理培訓(xùn)
- 生物化學(xué)實(shí)驗(yàn)智慧樹知到答案章節(jié)測(cè)試2023年浙江大學(xué)
- 等腰三角形復(fù)習(xí)課教案
評(píng)論
0/150
提交評(píng)論