詳解Oracle 11g DRCP連接方式的基本原理
學(xué)習(xí)Oracle是一個(gè)復(fù)雜、繁瑣的過程。在浩如煙海的Oracle官方資料、新特性、MOS資料和各種Internal知識(shí)面前,我們總是覺得力不從心、不知所措。但是,這往往也就是我們不斷堅(jiān)持、積累和追尋的樂趣。
在Oracle 11g中,提出了突破傳統(tǒng)專用/共享連接的第三種連接方式——Database Resident Connection Pooling(DRCP)。本篇我們一起來探討這項(xiàng)技術(shù)。
1、 從Dedicated Server到Shared Server
Client Process連接到Server Process的方式,傳統(tǒng)上有兩種方式:Dedicated Server和Shared Server。在Client連入到Oracle Server的過程中,默認(rèn)是通過監(jiān)聽器listener監(jiān)聽器進(jìn)行Oracle實(shí)例服務(wù)定位。只有再由監(jiān)聽器fork出的子進(jìn)程向Instance請(qǐng)求出一個(gè)Server Process與Client Process遠(yuǎn)程通信。不同的連接方式,就體現(xiàn)在數(shù)據(jù)庫(kù)實(shí)例在接受到Server Process請(qǐng)求后,是怎么樣提供出Server Process進(jìn)程,以及該進(jìn)程如何管理的。
Dedicated Server模式也稱為專用連接方式,就是Oracle Instance會(huì)專門創(chuàng)建出一個(gè)新的Server Process與Client Process進(jìn)行遠(yuǎn)程通信。在整個(gè)Client Process請(qǐng)求過程中,Server Process只為該Client提供服務(wù)。UGA信息也保存在Server Process的PGA空間中。當(dāng)會(huì)話結(jié)束,Client連接中斷,Server Process就失去“存在意義”被清除掉,分配內(nèi)存回收。Dedicated方式是我們最常使用的數(shù)據(jù)庫(kù)連接方式。在長(zhǎng)會(huì)話或前端應(yīng)用使用連接池組件的情況下,Dedicated方式的優(yōu)勢(shì)是很明顯的。
與Dedicated Server模式對(duì)應(yīng)的是Shared Server。在該模式下,Oracle實(shí)例會(huì)維持兩種Server Process:分發(fā)進(jìn)程(Dispatcher DXXX)和共享進(jìn)程(SXXX)。
SQL> select addr, pid, spid, username, program from v$process where program like '%000%'; ADDR PID SPID USERNAME PROGRAM -------- ---------- ------------ --------------- -------------------- 6D24BA1C 13 648 SYSTEM ORACLE.EXE (D000) 6D24C00C 14 1736 SYSTEM ORACLE.EXE (S000)
當(dāng)監(jiān)聽器向數(shù)據(jù)庫(kù)實(shí)例提出Server Process分配請(qǐng)求的時(shí)候,在Shared Server模式下,監(jiān)聽器會(huì)向分發(fā)進(jìn)程DXXX請(qǐng)求分配Server Process。DXXX會(huì)根據(jù)當(dāng)前的空閑Server情況,分配出一個(gè)Server Process供使用。當(dāng)Client使用結(jié)束之后,Server Process(SXXX)并不是被釋放,而是重新回到D000管制下。系統(tǒng)也會(huì)依據(jù)參數(shù)設(shè)置,維持一個(gè)穩(wěn)定的SXXX數(shù)量。
SQL> show parameter shared_servers NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ max_shared_servers integer shared_servers integer 1
Shared Server連接模式的出現(xiàn),是和短會(huì)話、高并發(fā)的互聯(lián)網(wǎng)應(yīng)用發(fā)展相關(guān)。每次創(chuàng)建和回收Server Process的成本是很高的。如果應(yīng)用沒有中間層連接池,而是高并發(fā)的創(chuàng)建Server Process并且快速回收,這對(duì)于數(shù)據(jù)庫(kù)來說是很高的壓力。
從現(xiàn)在的應(yīng)用設(shè)計(jì)開發(fā)看,連接池管理已經(jīng)滲透入主流應(yīng)用系統(tǒng)框架,shared server方式實(shí)際中應(yīng)用不是很廣泛。
2、Database Resident Connection Pooling(DRCP)
如果我們站在軟件模式的角度看,Shared Server本質(zhì)上也是想實(shí)現(xiàn)一種在數(shù)據(jù)庫(kù)層面上的連接池。這點(diǎn)在Oracle 11g上得到了實(shí)現(xiàn),Oracle駐留連接池(DRCP)就是一個(gè)允許在多進(jìn)程(Multi-Process)和多線程(Multi-Threads)之間共享連接的新特性。
Shared server在一定程度上緩解了Server process IDEL和頻繁創(chuàng)建銷毀Server process的問題。但是,Shared Server沒有解決Session數(shù)據(jù)共享的問題。當(dāng)存在client需要長(zhǎng)時(shí)間持有session,同時(shí)其他client沒有大量會(huì)話要求的時(shí)候,這種模型是有效的。但是,在每次請(qǐng)求會(huì)話的時(shí)間很短(短會(huì)話)和數(shù)據(jù)庫(kù)活動(dòng)需要多次會(huì)話交互的時(shí)候,DRCP就是更加理想的連接池模型了。
DRCP新特性主要針對(duì)的就是應(yīng)用程序在訪問數(shù)據(jù)庫(kù)時(shí),出現(xiàn)高并發(fā)連接數(shù)問題。DRCP連接池將Server和Session信息進(jìn)行緩存,為多個(gè)訪問的應(yīng)用程序提供連接共享。
同Shared Server一樣,DRCP前端存在一個(gè)代理(Connection Broker),負(fù)責(zé)應(yīng)用中間件連接的共享要求,同時(shí)負(fù)責(zé)管理數(shù)據(jù)庫(kù)實(shí)例上的連接池連接。當(dāng)應(yīng)用中間件想Broker提出連接請(qǐng)求的時(shí)候,Broker會(huì)從連接池中找出空閑連接。當(dāng)交互結(jié)束后,Server Process被釋放回連接池供重用。
同shared server不同的方面在于。當(dāng)共享池中連接池被分配出之后,等價(jià)于dedicated server方式。
3、三種連接方式的內(nèi)存使用情況
三種連接方式下,Oracle實(shí)例、Server Process和內(nèi)存使用方式截然不同。
Dedicated Server方式
當(dāng)Client Server請(qǐng)求連接的時(shí)候,全新的Server Process和session信息被創(chuàng)建。當(dāng)連接中斷,Server Process和Session全部被釋放。內(nèi)存分配是一個(gè)連接要分配Server Process和Session的空間。UGA信息是保存在PGA里的。
Shared Server方式
當(dāng)接收到Client Server的請(qǐng)求之后,Dispatcher會(huì)將請(qǐng)求放置在一個(gè)common隊(duì)列中??捎玫腟erver Process就從隊(duì)列中獲取請(qǐng)求信息。當(dāng)終止會(huì)話之后,對(duì)應(yīng)的會(huì)話信息就被釋放掉。Session信息是從SGA中分配出。
DRCP方式
當(dāng)Client Server請(qǐng)求之后,Connection Broker從連接池中尋找一個(gè)空閑Pooled Server提供給Client Server。如果沒有空閑的,Connection Broker就會(huì)創(chuàng)建出一個(gè)新的連接。如果當(dāng)前連接池已經(jīng)達(dá)到最大數(shù)量限制,就將請(qǐng)求放置在等待隊(duì)列中,等待空閑Server。
當(dāng)釋放Pooled Server回到Connection Pool的時(shí)候,相應(yīng)的數(shù)據(jù)庫(kù)資源被釋放掉。DRCP的內(nèi)存要求與存儲(chǔ)池大小和會(huì)話有關(guān)。每個(gè)Pooled Server有一個(gè)Session信息,且存儲(chǔ)在PGA中。
下面一個(gè)分配實(shí)例,來說明情況:
場(chǎng)景:一個(gè)應(yīng)用程序,其每個(gè)session需要400k的空間。每個(gè)Server process對(duì)應(yīng)4M空間。連接池大小為100,共享shared Server大小數(shù)據(jù)量也是100。如果有5000個(gè)連接數(shù)。
在Dedicated Server模式下:
Memory Usage=5000*(0.4M+4M)=22GB;
在Shared Server模式下:
Memory Usage=5000×0.4M+4M×100=2.5GB;注意,其中Session信息的2G是從SGA中分配的。
在DRCP模式下:
Memory Usage=100×(4M+0.4M)+5000×35K=615MB。注意:35K為維護(hù)會(huì)話信息使用的內(nèi)存大小。
4、結(jié)論
DRCP模式在傳統(tǒng)的shared server基礎(chǔ)上,為前端應(yīng)用提供更加成熟的數(shù)據(jù)連接池解決方案。從目前的資料看,DRCP對(duì)OCI、PHP等多種驅(qū)動(dòng)提供了支持。注意:對(duì)JDBC Thin和JDBC OCI的支持還不存在。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何使用Oracle PL/SQL 實(shí)現(xiàn)發(fā)送電子郵件功能(UTL_MAIL)
這篇文章主要介紹了Oracle PL/SQL 實(shí)現(xiàn)發(fā)送電子郵件功能,今天主要給大家介紹使用UTL_MAIL實(shí)現(xiàn)發(fā)送電子郵件功能,具體實(shí)例代碼跟隨小編一起看看吧2021-08-08
oracle設(shè)置密碼復(fù)雜度及設(shè)置超時(shí)退出的功能
我們都知道密碼策略加固的參數(shù)一般包括密碼長(zhǎng)度、復(fù)雜度檢測(cè)、最大最小使用時(shí)間、過期警報(bào)時(shí)間、最大登錄失敗次數(shù)以及鎖定時(shí)間等設(shè)置,下面這篇文章主要給大家介紹了關(guān)于oracle設(shè)置密碼復(fù)雜度及設(shè)置超時(shí)退出功能的相關(guān)資料,需要的朋友可以參考下2022-06-06
Oracle數(shù)據(jù)庫(kù)查看與修改內(nèi)存配置的方法
在使用Oracle時(shí)我們需要關(guān)注數(shù)據(jù)庫(kù)的內(nèi)存使用情況,以確保其正確高效地運(yùn)行,下面這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫(kù)查看與修改內(nèi)存配置的相關(guān)資料,需要的朋友可以參考下2023-11-11
使用PLSQL遠(yuǎn)程連接Oracle數(shù)據(jù)庫(kù)的方法(內(nèi)網(wǎng)穿透)
Oracle數(shù)據(jù)庫(kù)來源于知名大廠甲骨文公司,是一款通用數(shù)據(jù)庫(kù)系統(tǒng),能提供完整的數(shù)據(jù)管理功能,而Oracle數(shù)據(jù)庫(kù)時(shí)關(guān)系數(shù)據(jù)庫(kù)的典型代表,其數(shù)據(jù)關(guān)系設(shè)計(jì)完備,這篇文章主要介紹了使用PLSQL遠(yuǎn)程連接Oracle數(shù)據(jù)庫(kù)的方法(內(nèi)網(wǎng)穿透),需要的朋友可以參考下2023-03-03
oracle—SQL技巧之(一)連續(xù)記錄查詢sql案例測(cè)試
有這樣一個(gè)需求:需要查詢出某個(gè)客戶某一年那些天是有連續(xù)辦理過業(yè)務(wù),本文給予sql實(shí)現(xiàn)語句并測(cè)試,感興趣的朋友可以了解下2013-01-01
expdp與impdp導(dǎo)出導(dǎo)入特定表方式
文章介紹了在Oracle數(shù)據(jù)庫(kù)中導(dǎo)入導(dǎo)出特定表的方法,包括在10g和11g/12c中的操作區(qū)別,以及如何使用DBBAK文件夾作為導(dǎo)出文件的存儲(chǔ),同時(shí),文章指出了在Windows Server 2012及以上版本中使用PowerShell時(shí)可能會(huì)遇到的問題,建議在DOS命令行窗口中執(zhí)行相關(guān)操作2025-01-01
Oracle 數(shù)據(jù)庫(kù)針對(duì)表主鍵列并發(fā)導(dǎo)致行級(jí)鎖簡(jiǎn)單演示
本文簡(jiǎn)單演示針對(duì)表主鍵并發(fā)導(dǎo)致的行級(jí)鎖,鎖的產(chǎn)生是因?yàn)椴l(fā)。沒有并發(fā),就沒有鎖。并發(fā)的產(chǎn)生是因?yàn)橄到y(tǒng)需要,系統(tǒng)需要是因?yàn)橛脩粜枰?,感興趣的你可以參考下哈,希望可以幫助到你2013-03-03

