RAC全域性死鎖檢測時間

不一樣的天空w發表於2017-10-01

對於單例項資料庫而言,死鎖的檢測在秒級完成,而RAC環境則死鎖的檢測時間預設達到了1分鐘。

 

 

對於單例項環境如果出現了死鎖,那麼馬上其中一個程式就被中止,使用者可以快速的得到錯誤返回。而對於RAC而言,死鎖的檢測並不是實時完成,而是需要60秒左右的時間。

會話1執行:

SQL> create table t_deadlock (id number primary key, name varchar2(30));

Table created.

Elapsed: 00:00:00.12
SQL> insert into t_deadlock values (1, 'a');

1 row created.

Elapsed: 00:00:00.00
SQL> insert into t_deadlock values (2, 'b');

1 row created.

Elapsed: 00:00:00.00
SQL> commit;

Commit complete.

Elapsed: 00:00:00.00
SQL> update t_deadlock set name = 'a1' where id = 1;

1 row updated.

Elapsed: 00:00:00.00

會話2執行:

SQL> set timing on
SQL> update t_deadlock set name = 'b2' where id = 2;

1 row updated.

Elapsed: 00:00:00.00
SQL> update t_deadlock set name = 'a2' where id = 1;

此時,會話2等待會話1的最終操作,下面會話1更新被會話2鎖定的行,引發死鎖:

SQL> update t_deadlock set name = 'b1' where id = 2;
update t_deadlock set name = 'b1' where id = 2
*
ERROR at line 1:
ORA-00060: deadlock detected while waiting for resource


Elapsed: 00:01:00.12

可以看到,死鎖的超時檢測為1分鐘。

而這個死鎖的檢測時間是可以調整的,Oracle透過隱含引數_lm_dd_interval控制:

SQL> conn / as sysdba
Connected.
SQL> alter system set "_lm_dd_interval" = 30 scope = spfile;

System altered.

SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.

Total System Global Area 281018368 bytes
Fixed Size 2095672 bytes
Variable Size 104859080 bytes
Database Buffers 167772160 bytes
Redo Buffers 6291456 bytes
Database mounted.
Database opened.

再次測試死鎖的檢測時間,會話1

SQL> update t_deadlock set name = 'a1' where id = 1;

1 row updated.

SQL> set timing on

會話2執行更新:

SQL> set timing on
SQL> update t_deadlock set name = 'b2' where id = 2;

1 row updated.

Elapsed: 00:00:00.02
SQL> update t_deadlock set name = 'a2' where id = 1;

會話1執行更新引發死鎖:

SQL> update t_deadlock set name = 'b1' where id = 2;

大約30秒後,會話2報錯ORA-60

update t_deadlock set name = 'a2' where id = 1
*
ERROR at line 1:
ORA-00060: deadlock detected while waiting for resource


Elapsed: 00:00:30.27

10.2.0.2版本上,Oracle存在一個bug,允許這個引數設定為0,在10.2.0.3以後,這個bug被修正,如果設定為0後,則資料庫無法正常啟動:

[oracle@node1 ~]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.5.0 - Production on Mon Jun 4 07:54:09 2012

Copyright (c) 1982, 2010, Oracle. All Rights Reserved.

Connected to an idle instance.

SQL> startup
ORA-00067: invalid value 0 for parameter _lm_dd_interval; must be at least 1

最後修改隱含引數是Oracle不推薦的,而且修改這個引數勢必會影響RAC的正常工作方式導致LDM程式的繁忙度增加,而且可能影響RAC環境的穩定性和可用性。

如果確實對於前臺的死鎖檢查時間要求較高,建議在測試環境中詳細測試後再部署到產品環境中。

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31397003/viewspace-2145658/,如需轉載,請註明出處,否則將追究法律責任。

相關文章