<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > EDA/PCB > 設(shè)計應(yīng)用 > 基于JDBC的數(shù)據(jù)庫連接池技術(shù)研究與應(yīng)用

          基于JDBC的數(shù)據(jù)庫連接池技術(shù)研究與應(yīng)用

          作者: 時間:2012-09-18 來源:網(wǎng)絡(luò) 收藏

          近年來,隨著Internet/Intranet建網(wǎng)技術(shù)的飛速發(fā)展和在世界范圍內(nèi)的迅速普及,計算機 應(yīng)用程序已從傳統(tǒng)的桌面應(yīng)用轉(zhuǎn)到Web應(yīng)用。

          本文引用地址:http://www.ex-cimer.com/article/189898.htm

          基于B/S(Browser/Server)架構(gòu)的3層開發(fā)模式逐漸取代C/S(Client/Server)架構(gòu)的開發(fā)模式,成為開發(fā)企業(yè)級應(yīng)用和電子商務(wù)普遍采用的技術(shù)。在Web應(yīng)用開發(fā)的早期,主要使用的技術(shù)是CGI?ASP?PHP等。之后,Sun公司推出了基于Java語言的Servlet+Jsp+JavaBean技術(shù)。相比傳統(tǒng)的開發(fā)技術(shù),它具有跨平臺?安全?有效?可移植等特性,這使其更便于使用和開發(fā)。

          Java應(yīng)用程序訪問的基本原理

          在Java語言中,(Java DataBase CONnection)是應(yīng)用程序與溝通的橋梁,

          即Java語言通過技術(shù)訪問是一種“開放”的方案,它為數(shù)據(jù)庫應(yīng)用開發(fā)人員?數(shù)據(jù)庫前臺工具開發(fā)人員提供了一種標(biāo)準(zhǔn)的應(yīng)用程序設(shè)計接口,使開發(fā)人員可以用純Java語言編寫完整的數(shù)據(jù)庫應(yīng)用程序。JDBC提供兩種API,分別是面向開發(fā)人員的API和面向底層的JDBC驅(qū)動程序API,底層主要通過直接的JDBC驅(qū)動和JDBC-ODBC橋驅(qū)動實現(xiàn)與數(shù)據(jù)庫的連接。

          一般來說,Java應(yīng)用程序訪問數(shù)據(jù)庫的過程是:

          ①裝載數(shù)據(jù)庫驅(qū)動程序;

          ②通過JDBC建立數(shù)據(jù)庫連接;

          ③訪問數(shù)據(jù)庫,執(zhí)行SQL語句;

          ④斷開數(shù)據(jù)庫連接。

          JDBC作為一種數(shù)據(jù)庫訪問技術(shù),具有簡單易用的優(yōu)點。但使用這種模式進(jìn)行Web應(yīng)用

          程序開發(fā),存在很多問題:首先,每一次Web請求都要建立一次數(shù)據(jù)庫連接。建立連接是一個費時的活動,每次都得花費0.05s~1s的時間,而且系統(tǒng)還要分配內(nèi)存資源。這個時間對于一次或幾次數(shù)據(jù)庫操作,或許感覺不出系統(tǒng)有多大的開銷??墒菍τ诂F(xiàn)在的Web應(yīng)用,尤其是大型電子商務(wù)網(wǎng)站,同時有幾百人甚至幾千人在線是很正常的事。在這種情況下,頻繁的進(jìn)行數(shù)據(jù)庫連接操作勢必占用很多的系統(tǒng)資源,網(wǎng)站的響應(yīng)速度必定下降,嚴(yán)重的甚至?xí)斐煞?wù)器的崩潰。不是危言聳聽,這就是制約某些電子商務(wù)網(wǎng)站發(fā)展的技術(shù)瓶頸問題。其次,對于每一次數(shù)據(jù)庫連接,使用完后都得斷開。否則,如果程序出現(xiàn)異常而未能關(guān)閉,將會導(dǎo)致數(shù)據(jù)庫系統(tǒng)中的內(nèi)存泄漏,最終將不得不重啟數(shù)據(jù)庫。還有,這種開發(fā)不能控制被創(chuàng)建的連接對象數(shù),系統(tǒng)資源會被毫無顧及的分配出去,如連接過多,也可能導(dǎo)致內(nèi)存泄漏,服務(wù)器崩潰。

          數(shù)據(jù)庫連接池(connection pool)的工作原理

          1、基本概念及原理

          由上面的分析可以看出,問題的根源就在于對數(shù)據(jù)庫連接資源的低效管理。

          我們知道,對于共享資源,有一個很著名的設(shè)計模式:資源池(Resource Pool)。該模式正是為了解決資源的頻繁分配?釋放所造成的問題。為解決上述問題,可以采用數(shù)據(jù)庫連接池技術(shù)。數(shù)據(jù)庫連接池的基本思想就是為數(shù)據(jù)庫連接建立一個“緩沖池”。預(yù)先在緩沖池中放入一定數(shù)量的連接,當(dāng)需要建立數(shù)據(jù)庫連接時,只需從“緩沖池”中取出一個,使用完畢之后再放回去。我們可以通過設(shè)定連接池最大連接數(shù)來防止系統(tǒng)無盡的與數(shù)據(jù)庫連接。更為重要的是我們可以通過連接池的管理機制監(jiān)視數(shù)據(jù)庫的連接的數(shù)量?使用情況,為系統(tǒng)開發(fā)?測試及性能調(diào)整提供依據(jù)。


          上一頁 1 2 3 4 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();