【快问快答】事务异常或者instance abort时,如何估算事务rollback时间

2022-08-22 13:19:38 浏览数 (2)

编者按:

本文作者系流浪的金鱼(花名),甲骨文数据库工程师。个人主页:https://blog.csdn.net/rishairu1,经其本人授权发布。

【免责声明】本号文章仅代表个人观点,与任何公司无关。

来源|SQL和数据库技术(ID:SQLplusDB)

快问快答,不高深,但是知道了就知道了!

如果事务被异常或者手动中断,或者shutdown abort的时候,正在执行的事务会被rollback。那么这个时候如何确认是否被rollback以及其进度呢。

我们可以通过 V$FAST_START_TRANSACTIONS 这个View,根据undo使用量来观察和计算进度。

代码语言:javascript复制
select USN, SLT, SEQ, UNDOBLOCKSDONE, UNDOBLOCKSTOTAL
from V$FAST_START_TRANSACTIONS;

USN,SLT和SEQ是异常发生前事物的识别号。UNDOBLOCKSDONE是已经完成rollback的UNDO block数,

UNDOBLOCKSTOTAL是合计需要rollback的undo block数。

当异常发生或者shutdown abort,rollback在进行的过程中,UNDOBLOCKSDONE会逐渐增加。

通过UNDOBLOCKSDONE 和 UNDOBLOCKSTOTAL 比例就可以估算出大概的rollback时间。

例如

代码语言:javascript复制
sql> set time on 
20:15:50
sql> select USN, SLT, SEQ, UNDOBLOCKSDONE, UNDOBLOCKSTOTAL
from V$FAST_START_TRANSACTIONS;
 
USN     SLT     SEQ     UNDOBLOCKSDONE                    UNDOBLOCKSTOTAL
------- ------- ------- --------------------------------- ---------------------------------
22      0       3688    988                               18566
 
20:16:23
sql> select USN, SLT, SEQ, UNDOBLOCKSDONE, UNDOBLOCKSTOTAL
from V$FAST_START_TRANSACTIONS;
USN     SLT     SEQ     UNDOBLOCKSDONE                    UNDOBLOCKSTOTAL
------- ------- ------- --------------------------------- ---------------------------------
22      0       3688    12033                              18566
18566/(12033-988)/(20:16:23 - 20:15:50) = 55.5秒

注意,这个值是估算值,实际有可能增加也可能减少,供参考。

0 人点赞