oracle資料庫連結知識

來源:互聯網
上載者:User

maxActive是最大啟用串連數,這裡取值為20,表示同時最多有20個資料庫連 
 接。

 

maxIdle是最大的空閑串連數,這裡取值為20,表示即使沒有資料庫連接時依然可以保持20閒置

串連,而不被清除,隨時處於待命狀態。

 

MaxWait是最大等待秒鐘數,這裡取值-1,表示無限等待,直到

逾時為止,也可取值9000,表示9秒後逾時。

maxWait=5000
maxActive=50
maxIdle=5

 

===============交易隔離等級===========

1: PROPAGATION_REQUIRED
加入當前正要執行的事務不在另外一個事務裡,那麼就起一個新的事務
比如說,ServiceB.methodB的事務層級定義為PROPAGATION_REQUIRED, 那麼由於執行ServiceA.methodA的時候,ServiceA.methodA已經起了事務,這時調用ServiceB.methodB,ServiceB.methodB看到自己已經運行在ServiceA.methodA的事務內部,就不再起新的事務。而假如ServiceA.methodA啟動並執行時候發現自己沒有在事務中,它就會為自己分配一個事務。這樣,在ServiceA.methodA或者在ServiceB.methodB內的任何地方出現異常,事務都會被復原。
2: PROPAGATION_SUPPORTS
如果當前在事務中,即以事務的形式運行,如果當前不在一個事務中,那麼就以非事務的形式運行
3: PROPAGATION_MANDATORY
必須在一個事務中運行。也就是說,只能被一個父事務調用。否則,就要拋出異常。
4: PROPAGATION_REQUIRES_NEW
比如我們設計ServiceA.methodA的事務層級為PROPAGATION_REQUIRED,ServiceB.methodB的事務層級為PROPAGATION_REQUIRES_NEW, landscaper-academy.com
那麼當執行到ServiceB.methodB的時候,ServiceA.methodA所在的事務就會掛起,ServiceB.methodB會起一個新的事務,等待ServiceB.methodB的事務完成以後,它才繼續執行。它與PROPAGATION_REQUIRED 的事務區別在於事務的復原程度了。因為ServiceB.methodB是新起一個事務,那麼就是存在
兩個不同的事務。如果ServiceB.methodB已經提交,那麼ServiceA.methodA失敗復原,ServiceB.methodB是不會復原的。如果ServiceB.methodB失敗復原,它拋出的異常被ServiceA.methodA捕獲,ServiceA.methodA事務仍然可以提交。
5: PROPAGATION_NOT_SUPPORTED
當前不支援事務。比如ServiceA.methodA的事務層級是PROPAGATION_REQUIRED ,而ServiceB.methodB的事務層級是PROPAGATION_NOT_SUPPORTED ,那麼當執行到ServiceB.methodB時,ServiceA.methodA的事務掛起,而它以非事務的狀態運行完,再繼續ServiceA.methodA的事務。
6: PROPAGATION_NEVER
不能在事務中運行。假設ServiceA.methodA的事務層級是PROPAGATION_REQUIRED, 而ServiceB.methodB的事務層級是PROPAGATION_NEVER ,那麼ServiceB.methodB就要拋出異常了。
7: PROPAGATION_NESTED
理解Nested的關鍵是savepoint。它與PROPAGATION_REQUIRES_NEW的區別是,PROPAGATION_REQUIRES_NEW另起一個事務,將會與它的父事務相互獨立,而Nested的事務和它的父事務是相依的,它的提交是要等和它的父事務一塊提交的。也就是說,如果父事務最後復原,它也要復原的。
而Nested事務的好處是它有一個savepoint。
[java]
class ServiceA {
/*
* 事務屬性配置為 PROPAGATION_REQUIRED
*/
void methodA() {
try {
// savepoint
ServiceB.methodB(); //PROPAGATION_NESTED 層級
} catch (Exception e) {
// 執行其它業務, 如 ServiceC.methodC();
}
}
}
也就是說ServiceB.methodB失敗復原,那麼ServiceA.methodA也會復原到savepoint點上,ServiceA.methodA可以選擇另外一個分支,比如
ServiceC.methodC,繼續執行,來嘗試完成自己的事務。但是這個事務並沒有在EJB標準中定義。

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.