小技巧: 事务异常或者instance abort时,估算事务rollback时间的方法

2022-08-19 21:46:36 浏览数 (2)

编者按:

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

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

如果事务被异常或者手动中断,或者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 人点赞