網(wǎng)站數(shù)據(jù)庫連接池作用及配置;
連接池用于創(chuàng)建和管理數(shù)據(jù)庫連接的緩沖池技術,緩沖池中的連接可以被任何需要他們的線程使用。當一個線程需要用JDBC對一個數(shù)據(jù)庫操作時,將從池中請求一個連接。當這個連接使用完畢后,將返回到連接池中,等待為其他的線程服務。
連接池的主要優(yōu)點有以下三個方面。
1、減少連接創(chuàng)建時間。連接池中的連接是已準備好的、可重復使用的,獲取后可以直接訪問數(shù)據(jù)庫,因此減少了連接創(chuàng)建的次數(shù)和時間。
2、簡化的編程模式。當使用連接池時,每一個單獨的線程能夠像創(chuàng)建一個自己的JDBC連接一樣操作,允許用戶直接使用JDBC編程技術。
3、控制資源的使用。如果不使用連接池,每次訪問數(shù)據(jù)庫都需要創(chuàng)建一個連接,這樣系統(tǒng)的穩(wěn)定性受系統(tǒng)連接需求影響很大,很容易產(chǎn)生資源浪費和高負載異常。連接池能夠使性能大化,將資源利用控制在一定的水平之下。連接池能控制池中的連接數(shù)量,增強了系統(tǒng)在大量用戶應用時的穩(wěn)定性。
下面,簡單的闡述下連接池的工作原理。
連接池技術的核心思想是連接復用,通過建立一個數(shù)據(jù)庫連接池以及一套連接使用、分配和管理策略,使得該連接池中的連接可以得到高效、安全的復用,避免了數(shù)據(jù)庫連接頻繁建立、關閉的開銷。
連接池的工作原理主要由三部分組成,分別為連接池的建立、連接池中連接的使用管理、連接池的關閉。
1、連接池的建立。一般在系統(tǒng)初始化時,連接池會根據(jù)系統(tǒng)配置建立,并在池中創(chuàng)建了幾個連接對象,以便使用時能從連接池中獲取。連接池中的連接不能隨意創(chuàng)建和關閉,這樣避免了連接隨意建立和關閉造成的系統(tǒng)開銷。Java中提供了很多容器類可以方便的構建連接池,例如Vector、Stack等。
2、連接池的管理。連接池管理策略是連接池機制的核心,連接池內連接的分配和釋放對系統(tǒng)的性能有很大的影響。
其管理策略是:當客戶請求數(shù)據(jù)庫連接時,首先查看連接池中是否有空閑連接,如果存在空閑連接,則將連接分配給客戶使用;如果沒有空閑連接,則查看當前所開的連接數(shù)是否已經(jīng)達到大連接數(shù),如果沒達到就重新創(chuàng)建一個連接給請求的客戶;如果達到就按設定的大等待時間進行等待,如果超出大等待時間,則拋出異常給客戶。
當客戶釋放數(shù)據(jù)庫連接時,先判斷該連接的引用次數(shù)是否超過了規(guī)定值,如果超過就從連接池中刪除該連接,否則保留為其他客戶服務。
該策略保證了數(shù)據(jù)庫連接的有效復用,避免頻繁的建立、釋放連接所帶來的系統(tǒng)資源開銷。
3、連接池的關閉。當應用程序退出時,關閉連接池中所有的連接,釋放連接池相關的資源,該過程正好與創(chuàng)建相反。
數(shù)據(jù)庫連接池的作用以及配置;
連接池是創(chuàng)建和管理多個連接的一種技術,這些連接可被需要使用它們的任何線程使用。連接池技術基于下述事實:對于大多數(shù)應用程序,當它們正在處理通常需要數(shù)毫秒完成的事務時,僅需要能夠訪問JDBC連接的1個線程。未處理事務時,連接處于閑置狀態(tài)。使用連接池,允許其他線程使用閑置連接來執(zhí)行有用的任務。
事實上,當某一線程需要用JDBC在MySQL或其他數(shù)據(jù)庫上執(zhí)行操作時,需要用到由連接池提供的連接。使用連接完成線程后,線程會將連接返回給連接池,以便該連接能夠被其他需要使用連接的線程使用。從連接池“借出”連接時,該連接僅供請求它的線程使用。從編程觀點看,其效果等同于每次需要JDBC連接時調用DriverManager.getConnection(),但是,采用連接池技術,可通過使用新的或已有的連接結束線程。連接池技術能顯著增加Java應用程序的性能,同時還能降低資源使用率。
連接池技術的主要優(yōu)點包括:
(1) 縮短了連接創(chuàng)建時間
創(chuàng)建新的JDBC連接會導致聯(lián)網(wǎng)操作和一定的JDBC驅動開銷,如果這類連接是“循環(huán)”使用的,使用該方式,可避免這類不利因素。
(2)簡化的編程模型
使用連接池技術時,每個單獨線程能夠像創(chuàng)建了自己的JDBC連接那樣進行操作,從而允許使用直接的JDBC編程技術。
(3)受控的資源使用
如果不使用連接池技術,而是在每次需要時為線程創(chuàng)建新的連接,那么應用程序的資源使用將十分浪費,而且在負載較重的情況下會導致無法預期的結果。
注意,與數(shù)據(jù)庫的每個連接均會在客戶端和服務器端造成一定的開銷(CPU、關聯(lián)轉換等)。
每個連接均會對應用程序和數(shù)據(jù)庫服務器的可用資源帶來一定的限制。無論連接是否執(zhí)行任何有用的任務,仍將使用這些資源中的相當一部分。
連接池能夠使性能大化,同時還能將資源利用控制在一定的水平之下,如果超過該水平,應用程序將崩潰而不僅僅是變慢。幸運的是,Sun公司通過JDBC-2.0“可選”接口,完成了JDBC中連接池概念的標準化實施,所有主要應用服務器均實施了能夠與MySQL Connector/J一起良好工作的
這類API。
通常,你可以在應用服務器的配置文件中配置連接池,并通過Java命名和目錄接口(JNDI)訪問它。
使用連接池時需要牢記的最重要事項是,無論在代碼中出現(xiàn)了什么(異常、控制流等),連接以及由連接創(chuàng)建的任何部分(語句、結果集等)均應被關閉,以便能再次使用它們。如不然,它們將糾纏在一起,在最好的情況下,意味著它們所代表的數(shù)據(jù)庫服務器資源(緩沖區(qū)、鎖定、套接字等)可能會捆綁一段時間,在最壞的情況下,可能會導致永久捆綁。
連接池的好大小是什么?
取決于具體情況。盡管好大小取決與預期的負載和平均的數(shù)據(jù)庫事務時間,好的連接池大小小于你的預期。
例如,如果使用的是Sun公司的Java Petstore Blueprint應用程序,對于包含15~20個連接的連接池,使用MySQL和Tomcat,在可接受的相應時間下,可服務于中等程度的負載(600個并發(fā)用戶)。
要想確定用于應用程序的連接池大小,應使用諸如Apache Jmeter或The Grinder等工具創(chuàng)建負載測試腳本,并對應用程序進行負載測試。確定出
發(fā)點的一種簡單方法是,將連接池的大連接數(shù)配置為“無限”,運行負載測試,并測量大的并發(fā)連接數(shù)。隨后,應進行反向操作,確定出使應
用程序具有好性能的連接池的最小和大值。
連接池與數(shù)據(jù)源區(qū)別?
數(shù)據(jù)庫連接池是在應用程序啟動時建立足夠的數(shù)據(jù)庫連接,并將這些連接組
成一個連接池,由應用程序動態(tài)地對池中的連接進行申請、使用和釋放。
對于多于連接池中連接數(shù)的并發(fā)請求,應在請求隊列中排隊等待。并且應用程序可根據(jù)池中連接的使用率,動態(tài)增加或減少池中的連接數(shù)。當關閉連接操作時,連接并不真正的關閉,而是返回到連接池中作為空閑連接在后面繼續(xù)使用,連接池技術解決了數(shù)據(jù)庫連接頻繁打開關閉所帶來的性能問題。
有了連接池,我們沒必要直接找數(shù)據(jù)源打交道了,連接池在你的程序所在的機器內存,數(shù)據(jù)源不一定,并且數(shù)據(jù)源和連接池會保持一定數(shù)量
的連接,這樣我們訪問數(shù)據(jù)庫的時候就不需要找數(shù)據(jù)源要連接,直接在本地內存中取得連接,可以提高程序的性能。連結池的存在是為了效率,因為實例化一個連接很耗費資源,而連接又有可重用的特征,所以可以把一定數(shù)量的連接放在連接池里面以提高效率。
分享標題:網(wǎng)站數(shù)據(jù)庫連接池作用及配置
分享網(wǎng)址:http://vcdvsql.cn/news/144139.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、微信公眾號、App設計、面包屑導航、手機網(wǎng)站建設、品牌網(wǎng)站設計
廣告
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源:
創(chuàng)新互聯(lián)