首页 » ORACLE 9i-23ai » Troubleshooting ORA-600 [4187] Undo segment sequence number is exhausted

Troubleshooting ORA-600 [4187] Undo segment sequence number is exhausted

每个事务都有一个唯一的 ID,称为 XID,基于Undo segment number 、Undo segment slot number and Undo segment sequence number (wrap#),为每个事务在第一个 DML语句期间分配一个事务 ID(XID), 例如:0002.028.000004DA. 要查明transaction是否真的被提交,需要查看transaction table的描述符。transaction table在每个undo 段头可以转储如alter system dump undo header ‘xxx’, 每次transaction table的slot重用时, slot wrap(sequence number) number就会增加.当slot重用(或wrap#)达到maximum value 4,294,967,295 (2^32 – 1)(0xffffffff)次数时,当再次增加 wrap number 1或多值时,通常会提示ORA-1558 或ORA-600[4187]出现,由于撤销段分配的 AUM 算法,这也应该是非常罕见的。但是执行量非常大事务的库,在undo段非常少时还是有发生的概率,最近这个客户就遇到了(ORACLE RAC 11.2.0.4)。

现象

Fri Nov 19 15:10:12 2021
Thread 1 advanced to log sequence 54671 (LGWR switch)
  Current log# 5 seq# 54671 mem# 0: +DATA/anbob/onlinelog/group_5.287.904064243
Fri Nov 19 15:10:16 2021
Archived Log entry 52856 added for thread 1 sequence 54670 ID 0xfe89eeec dest 1:
Fri Nov 19 15:12:09 2021
Errors in file /u01/oracle/app/oracle/diag/rdbms/anbob/anbob1/trace/anbob1_ora_23451.trc  (incident=189693):
ORA-00600: internal error code, arguments: [4187], [], [], [], [], [], [], [], [], [], [], []
Incident details in: /u01/oracle/app/oracle/diag/rdbms/anbob/anbob1/incident/incdir_189693/anbob1_ora_23451_i189693.trc
Use ADRCI or Support Workbench to package the incident.
See Note 411.1 at My Oracle Support for error and packaging details.

Alert中出现的ora-600 [4187],部分事务无法继续,随后系统会生成较大的trace日志,有可能会导致ORACLE_HOME磁盘空间耗尽, 通常这种情况重启实例也无法彻底解决,客户在反复重启后,可能会出现下面其它的ORA-600 错误。

	行 5958: ORA-00600: internal error code, arguments: [4187], [], [], [], [], [], [], [], [], [], [], []
	行 5963: ORA-00600: internal error code, arguments: [kfncSlaveMsgFree1], [0], [0], [0], [], [], [], [], [], [], [], []
	行 5965: ORA-00600: internal error code, arguments: [4187], [], [], [], [], [], [], [], [], [], [], []
	行 5972: ORA-00600: internal error code, arguments: [kfgRecoverCreation_0], [], [], [], [], [], [], [], [], [], [], []
	行 5973: ORA-00600: internal error code, arguments: [kfncSlaveMsgFree1], [0], [0], [0], [], [], [], [], [], [], [], []
	行 5975: ORA-00600: internal error code, arguments: [4187], [], [], [], [], [], [], [], [], [], [], []
	行 5984: ORA-00600: internal error code, arguments: [kfioTranslateIO03], [], [], [], [], [], [], [], [], [], [], []
	行 5985: ORA-00600: internal error code, arguments: [kfgRecoverCreation_0], [], [], [], [], [], [], [], [], [], [], []
	行 5986: ORA-00600: internal error code, arguments: [kfncSlaveMsgFree1], [0], [0], [0], [], [], [], [], [], [], [], []

因为事务无法继续,可能在数据库层分析性能SQL就容易被误解,毕竟事务挂起无法继续。事务中断回滚清理、UNDO header Block recovery等,甚至可能存在SMON实例回滚时的内部错误,如果smon遇到100次内部错误则会重启实例(参数_smon_internal_errlimit控制)。在实例重启后出现ORA-15221 raised in ASM I/O path等ora-600 KF 相关的ASM事务报错,PMON会终止实例。

PMON TRACE

*** 2021-11-19 16:27:44.257
*** SESSION ID:(567.1) 2021-11-19 16:27:44.257
*** CLIENT ID:() 2021-11-19 16:27:44.257
*** SERVICE NAME:(SYS$BACKGROUND) 2021-11-19 16:27:44.257
*** MODULE NAME:() 2021-11-19 16:27:44.257
*** ACTION NAME:() 2021-11-19 16:27:44.257
 
Doing block recovery for file 3 block 272
Block header before block recovery:
buffer tsn: 2 rdba: 0x00c00110 (3/272)
scn: 0x0f9b.ed0bc9e7 seq: 0x01 flg: 0x04 tail: 0xc9e72601
frmt: 0x02 chkval: 0x5ec8 type: 0x26=KTU SMU HEADER BLOCK
Resuming block recovery (PMON) for file 3 block 272
Block recovery from logseq 54683, block 996 to scn 17162371681671

*** 2021-11-19 16:27:44.270
Recovery of Online Redo Log: Thread 1 Group 5 Seq 54683 Reading mem 0
Block recovery completed at rba 54683.998.16, scn 3995.3977334373
==== Redo read statistics for thread 1 ====
Total physical reads (from disk and memory): 1541Kb
-- Redo read_disk statistics --
Read rate (ASYNC): 0Kb in 0.01s => 0.00 Mb/sec
-- Redo read_memory statistics --
Read disk 0Kb and read memory 1541Kb, hit-ratio=1.00
Precise schema: 1541Kb valid, 0Kb invalid, valid-ratio 1.00
Longest record: 0Kb, moves: 0/4 (0%)
Longest LWN: 1Kb, moves: 0/3 (0%), moved: 0Mb
Last redo scn: 0x0f9b.ed114d64 (17162371681636)
----------------------------------------------
Block image after block recovery:
buffer tsn: 2 rdba: 0x00c00110 (3/272)
scn: 0x0f9b.ed0bc9e7 seq: 0x01 flg: 0x04 tail: 0xc9e72601
frmt: 0x02 chkval: 0x5ec8 type: 0x26=KTU SMU HEADER BLOCK

 Retention Table 
  -----------------------------------------------------------
 Extent Number:0  Commit Time: 1637305903
 Extent Number:1  Commit Time: 1637305905
 Extent Number:2  Commit Time: 1637305905
 Extent Number:3  Commit Time: 1637303989
 Extent Number:4  Commit Time: 1637304038
...
...
 Extent Number:28  Commit Time: 1637305842
 Extent Number:29  Commit Time: 1637305901
 Extent Number:30  Commit Time: 1637305901
  
  TRN CTL:: seq: 0xd14f chd: 0x0009 ctl: 0x0004 inc: 0x00000000 nfb: 0x0000
            mgc: 0xb000 xts: 0x0068 flg: 0x0001 opt: 2147483646 (0x7ffffffe)
            uba: 0x00c06434.d14f.2c scn: 0x0f9b.ed0bc826
Version: 0x01
  FREE BLOCK POOL::
    uba: 0x00000000.d14f.2b ext: 0x2  spc: 0x1dc   
    uba: 0x00000000.d14f.2a ext: 0x2  spc: 0x70e   
    uba: 0x00000000.d14b.02 ext: 0x1e spc: 0x1f02  
    uba: 0x00000000.ce3f.02 ext: 0x12 spc: 0x14da  
    uba: 0x00000000.3226.02 ext: 0x32 spc: 0x14ae  
  TRN TBL::
 
  index  state cflags  wrap#    uel         scn            dba            parent-xid    nub     stmt_num    cmt
  ------------------------------------------------------------------------------------------------
   0x00    9    0x00  0xfffffa0c  0x000c  0x0f9b.ed0bc8f1  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x01    9    0x00  0xfffff4ab  0x0016  0x0f9b.ed0bc84e  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
   0x02    9    0x00  0xfffff3aa  0x0008  0x0f9b.ed0bc934  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x03    9    0x00  0xfffff8d9  0x000e  0x0f9b.ed0bc985  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x04    9    0x00  0xfffffce8  0xffff  0x0f9b.ed0bc9e7  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x05    9    0x00  0xfffff627  0x001a  0x0f9b.ed0bc833  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
   0x06    9    0x00  0xfffff4e6  0x0004  0x0f9b.ed0bc9cb  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x07    9    0x00  0xffffece5  0x000b  0x0f9b.ed0bc85c  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
   0x08    9    0x00  0xfffff724  0x0021  0x0f9b.ed0bc93a  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x09    9    0x00  0xfffffff3  0x0015  0x0f9b.ed0bc828  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
   0x0a    9    0x00  0xfffffaf2  0x0018  0x0f9b.ed0bc90c  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x0b    9    0x00  0xfffff671  0x0010  0x0f9b.ed0bc867  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
   0x0c    9    0x00  0xfffffec0  0x001e  0x0f9b.ed0bc900  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x0d    9    0x00  0xfffff8bf  0x0020  0x0f9b.ed0bc889  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x0e    9    0x00  0xfffff4ce  0x0013  0x0f9b.ed0bc9ab  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x0f    9    0x00  0xfffff64d  0x000d  0x0f9b.ed0bc875  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
   0x10    9    0x00  0xfffff5ec  0x000f  0x0f9b.ed0bc86b  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305927
...
   0x1d    9    0x00  0xfffff23f  0x0019  0x0f9b.ed0bc91e  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x1e    9    0x00  0xfffff67e  0x000a  0x0f9b.ed0bc908  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x1f    9    0x00  0xfffff1ad  0x0003  0x0f9b.ed0bc982  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x20    9    0x00  0xfffffb0c  0x001b  0x0f9b.ed0bc8ba  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
   0x21    9    0x00  0xfffff1eb  0x0011  0x0f9b.ed0bc943  0x00c06434  0x0000.000.00000000  0x00000001   0x00000000  1637305928
  EXT TRN CTL::

Incident 328031 created, dump file: /u01/oracle/app/oracle/diag/rdbms/lcfa/LCFA1/incident/incdir_328031/LCFA1_pmon_11307_i328031.trc
ORA-00600: internal error code, arguments: [kfgRecoverCreation_0], [], [], [], [], [], [], [], [], [], [], []

PMON: fatal error while deleting s.o. 0x6ae9d8a18 in this tree:
----------------------------------------
SO: 0x6d91e2ea0, type: 2, owner: (nil), flag: INIT/-/-/0x00 if: 0x3 c: 0x3
 proc=0x6d91e2ea0, name=process, file=ksu.h LINE:12721, pg=0
(process) Oracle pid:50, ser:3, calls cur/top: 0x65863abc0/0x65863abc0
          flags : (0x1) DEAD
          flags2: (0x8000),  flags3: (0x10) 
          intr error: 0, call error: 0, sess error: 0, txn error 0
          intr queue: empty
  ksudlp FALSE at location: 0
  Cleanup details:
    Found dead = 1 sec ago
    Total Cleanup attempts = 1, Cleanup time = 0 sec, Cleanup timer = 0.000 sec
    Last attempt (full) started 1 sec ago, Length = in progress
  (post info) last post received: 0 0 51
              last post received-location: ksv2.h LINE:1679 ID:ksvpst: workdone
              last process to post me: 0x6d51f8310 1 2
              last post sent: 0 0 26
              last post sent-location: ksa2.h LINE:285 ID:ksasnd
              last process posted by me: 0x6ed26d1a0 1 6
  (latch info) wait_event=0 bits=0x0
  Process Group: DEFAULT, pseudo proc: 0x6ed5819c8
  O/S info: user: grid, term: UNKNOWN, ospid: 12107 (DEAD)
  OSD pid info: Unix process pid: 12107, image: oracle@
...

Kernel Transaction Undo tranXaction Control (KTUXC): Maintains control information to rollback changes to the transaction table itself.

从上面transaction table header(ktuxc)显示chd 9# slot, 而slot 9的wrap#为 0xfffffff3已经非常接近上限0xffffffff,并且其它slot同样也非常高。
wrap#增长当前采用的是在执行ktubnd函数为事务绑定undo段时,会调用kjqghd去计算出一个重用slot递增值delta,这个delta限制必须小于16(由KTU_MAX_KSQN_DELTA定义),所以就可能会出现 0xfffffff3 +delta的值超过KSQNMAXVAL,显示为负值。

 

从MOS中可以确认存在该问题bug Doc ID 19700135.8

ORA-600 [4187] can occur for undo segments where wrap# is close to the max value of 0xffffffff (KSQNMAXVAL).
This normally affects databases with high transaction rate that have existed for a relatively long time.

To identify undo segments causing the above error and others that may potentially cause it
in the future, run the next query:

select b.segment_name, b.tablespace_name
,a.ktuxeusn “Undo Segment Number”
,a.ktuxeslt “Slot”
,a.ktuxesqn “Wrap#”
from x$ktuxe a, dba_rollback_segs b
where a.ktuxesqn > -429496730 and a.ktuxesqn < 0
and a.ktuxeusn = b.segment_id;

Then drop the undo segments or the undo tablespace from the output above.

数据库中查询以上SQL

SQL> set lines 999
SQL> select b.segment_name, b.tablespace_name 
  2           ,a.ktuxeusn "Undo Segment Number"
  3           ,a.ktuxeslt "Slot"
  4           ,a.ktuxesqn "Wrap#"
  5     from  x$ktuxe a, dba_rollback_segs b
  6     where a.ktuxesqn > -429496730 and a.ktuxesqn < 0
  7         and a.ktuxeusn = b.segment_id;

SEGMENT_NAME                     TABLESPACE_NAME          Undo Segment Number       Slot      Wrap#
-------------------------------- ------------------------ ------------------- ---------- ----------
_SYSSMU10_562384330$             UNDOTBS1                                  10          0      -1524
_SYSSMU10_562384330$             UNDOTBS1                                  10          1      -2901
_SYSSMU10_562384330$             UNDOTBS1                                  10          2      -3158
_SYSSMU10_562384330$             UNDOTBS1                                  10          3      -1831
_SYSSMU10_562384330$             UNDOTBS1                                  10          4       -792
_SYSSMU10_562384330$             UNDOTBS1                                  10          5      -2521
_SYSSMU10_562384330$             UNDOTBS1                                  10          6      -2842
_SYSSMU10_562384330$             UNDOTBS1                                  10          7      -4891
_SYSSMU10_562384330$             UNDOTBS1                                  10          8      -2268
_SYSSMU10_562384330$             UNDOTBS1                                  10          9        -13
_SYSSMU10_562384330$             UNDOTBS1                                  10         10      -1294
...
...
_SYSSMU10_562384330$             UNDOTBS1                                  10         22       -666
_SYSSMU10_562384330$             UNDOTBS1                                  10         23       -555
_SYSSMU10_562384330$             UNDOTBS1                                  10         24      -3596
_SYSSMU10_562384330$             UNDOTBS1                                  10         25      -3325
_SYSSMU10_562384330$             UNDOTBS1                                  10         26      -2670
_SYSSMU10_562384330$             UNDOTBS1                                  10         27      -1551
_SYSSMU10_562384330$             UNDOTBS1                                  10         28      -4384
_SYSSMU10_562384330$             UNDOTBS1                                  10         29      -3521
_SYSSMU10_562384330$             UNDOTBS1                                  10         30      -2434
_SYSSMU10_562384330$             UNDOTBS1                                  10         31      -3667
_SYSSMU10_562384330$             UNDOTBS1                                  10         32      -1268
'''

Note:
大量slot的wrap# 已经出现的溢出为负值。

transaction table的说明

To find out whether the transaction has really been committed, it is necessary to look at its descriptor in the transaction table.
The transaction ID (or XID) enables you to find the transaction descriptor:
• usn: Number of the undo segment which was assigned to the transaction
• slot: Number of the entry in the transaction table (contained in the header of the undo segment) corresponding to the transaction descriptor. 
This is the index column in the transaction table.
• seq: Sequence number indicating reuse of the slot. This number is incremented as each slot is reused. It corresponds to the wrap# column in the transaction table.
All this information is collected in a memory area called the cleanout information area. This information is then used to actually apply the changes.

The transaction table holds a pointer to the head and tail of the committed transaction table slots. Each inactive entry in the transaction table points to the next committed (inactive) slot. 
They are ordered by commit SCN, starting at the oldest transaction to have committed. If the committed list is empty after several attempts at traversing it, the transaction table remains full 
and an error is reported. This indicates that there are not enough undo segments for the amount of concurrent transactions in the database. However, since AUM tries to allocate each concurrent transaction to their 
own undo segment, this should be extremely rare to see. If this error does occur, the solution is to increase the size of the undo tablespace to allow more undo segments to be created.

At instance startup each undo tablespace will contain 10 undo segments. The number of additional segments brought online during instance startup is based on the SESSIONS parameter.
 Oracle allocates approximately one undo segment for every five sessions. These are sized according to the auto-allocate algorithm for locally managed tablespaces. The basic algorithm 
is that the first 16 extents are 64 KB in size. During subsequent allocation the next 63 extents are 1 MB, the next 120 extents are 8 MB and all additional extents are 64 MB.

事务绑定UNDO段的原则是尽可能的将活动事务平均的各个undo段上,具体算法为:
1,在当前undo tablespace中的online undo segment中寻找事务表中没有活动事务的undo segment
2,如果没有找到则尝试在当前undo tablespace online 那些处于offline状态的undo segment
3,如果没有找到则尝试在当前undo tablespace创建undo segment并online
4,如果无法创建则会寻找最近最少使用的undo segment

到这一步既然确认了是业务特性高频事务导致undo 段的slot wrap#耗尽,检查一下UNDO段个数,发现当前的undo 表空间为大小1.5G (数据文件自动扩展),判断应该是大量的小事务,如loop 中insert value ommit等, 对于这么高频率的事务的数据库节点,同时因为UNDO段个数少,即使是undo段使用平衡,也会存在耗尽的风险, 如果个别segment的slot wrap#高,可以drop undo segment,但是如果普遍undo段wrap#使用都高,可以先创建新的UNDO表空间,修改数据库默认表空间解决,后期删聊原UNDO表空间。

预防
1, 初始化更多的UNDO段,使用_rollback_segment_count参数

2, 增加巡检项

select b.segment_name, b.tablespace_name 
         ,a.ktuxeusn "Undo Segment Number"
         ,a.ktuxeslt "Slot"
         ,a.ktuxesqn "Wrap#"
   from  x$ktuxe a, dba_rollback_segs b
   where  a.ktuxeusn = b.segment_id 
   and ktuxesqn>power(2,20); -- change

下面带这个问题做个测试:
一个SESSION 大量小事务会不会只使用1个rollback seg? 重启实例rollback seg wrap#会不会重置?

-- env 11.2.0.4 RAC --
SQL> select * from v$rollname
  2  ;

       USN NAME
---------- ------------------------------------------------------------
         0 SYSTEM
      3001 _SYSSMU3001_2524665243$
      3002 _SYSSMU3002_3274207932$
      3003 _SYSSMU3003_551481765$
      3004 _SYSSMU3004_3828969324$
      3005 _SYSSMU3005_2166630833$
      3006 _SYSSMU3006_2644181912$
      3007 _SYSSMU3007_2679219495$
      3008 _SYSSMU3008_2173666674$
      3009 _SYSSMU3009_3685259267$
      3010 _SYSSMU3010_1327269793$

11 rows selected.

SQL> alter system dump undo header '_SYSSMU3010_1327269793$';
System altered.

SQL> @t
TRACEFILE
--------------------------------------------------------------------------------------------------------------------------------- 
/u01/app/oracle/diag/rdbms/rac11g/rac11g2/trace/rac11g2_ora_7583.trc

SQL> host
oracle@11g-node2:/home/oracle/tpt-oracle-master $vi /u01/app/oracle/diag/rdbms/rac11g/rac11g2/trace/rac11g2_ora_7583.trc
   0x01    9    0x00  0x04f8  0x0008  0x0000.03fcd3b4  0x014089d6  0x0000.000.00000000  0x00000001   0x00000000  1714102509
   0x02    9    0x00  0x04fa  0xffff  0x0000.03fd3944  0x014089e1  0x0000.000.00000000  0x00000004   0x00000000  1714102536
   0x03    9    0x00  0x04e3  0x0020  0x0000.03fc9460  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x04    9    0x00  0x04f7  0x000b  0x0000.03fc93c6  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x05    9    0x00  0x04f3  0x0011  0x0000.03fc809c  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100707
   0x06    9    0x00  0x04f5  0x001d  0x0000.03fcbca7  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101791
   0x07    9    0x00  0x04f0  0x0019  0x0000.03fc6a27  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100408
   0x08    9    0x00  0x04f5  0x001c  0x0000.03fcd3b8  0x014089d6  0x0000.000.00000000  0x00000001   0x00000000  1714102510
   0x09    9    0x00  0x04f1  0x000a  0x0000.03fc813a  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100709
   0x0a    9    0x00  0x04ee  0x0004  0x0000.03fc815a  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100710
   0x0b    9    0x00  0x04ed  0x000d  0x0000.03fc93ca  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x0c    9    0x00  0x04fb  0x0012  0x0000.03fc9415  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x0d    9    0x00  0x04fa  0x000f  0x0000.03fc93d8  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x0e    9    0x00  0x04fa  0x001b  0x0000.03fd307f  0x014089d6  0x0000.000.00000000  0x00000001   0x00000000  1714102535
   0x0f    9    0x00  0x04f9  0x001f  0x0000.03fc93e4  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x10    9    0x00  0x04f8  0x0001  0x0000.03fcd05e  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714102208
   0x11    9    0x00  0x04fa  0x0009  0x0000.03fc809f  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100707
   0x12    9    0x00  0x04f8  0x0014  0x0000.03fc9436  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x13    9    0x00  0x04f3  0x0018  0x0000.03fc6a7d  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100408
   0x14    9    0x00  0x04ee  0x001e  0x0000.03fc9455  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x15    9    0x00  0x04eb  0x000e  0x0000.03fd307b  0x014089d6  0x0000.000.00000000  0x00000001   0x00000000  1714102535
   0x16    9    0x00  0x04ee  0x0000  0x0000.03fd3922  0x014089dc  0x0000.000.00000000  0x00000003   0x00000000  1714102536
   0x17    9    0x00  0x04ed  0x0003  0x0000.03fc945c  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x18    9    0x00  0x04ef  0x0005  0x0000.03fc6a82  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100408
   0x19    9    0x00  0x04ee  0x0013  0x0000.03fc6a64  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714100408
   0x1a    9    0x00  0x04f1  0x0006  0x0000.03fcbca2  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101791
   0x1b    9    0x00  0x04f1  0x0016  0x0000.03fd3914  0x014089da  0x0000.000.00000000  0x00000003   0x00000000  1714102536
   0x1c    9    0x00  0x04f0  0x0021  0x0000.03fd2d4d  0x014089d6  0x0000.000.00000000  0x00000001   0x00000000  1714102532
   0x1d    9    0x00  0x04ea  0x0010  0x0000.03fcbcab  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101791
   0x1e    9    0x00  0x04ef  0x0017  0x0000.03fc9457  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x1f    9    0x00  0x04ee  0x000c  0x0000.03fc93f3  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101009
   0x20    9    0x00  0x04ea  0x001a  0x0000.03fc9729  0x014089d3  0x0000.000.00000000  0x00000001   0x00000000  1714101310
   0x21    9    0x00  0x04ec  0x0015  0x0000.03fd306f  0x00000000  0x0000.000.00000000  0x00000000   0x00000000  1714102534
  EXT TRN CTL::
  usn: 3010


SQL> create table anbob.test_undo(id int);
Table created.

SQL> insert into anbob.test_undo values(1);
1 row created.

SQL> commit;
Commit complete.

# lots of transactions
declare
i int:=0 ;
begin
 while i<=1e6 loop
 update anbob.test_undo set id=id+1;
 i:=i+1;
 commit;
 end loop;
end;
/

# check rollback segment
SQL> @trans

       SID    SERIAL# USERNAME    TADDR            SES_ADDR          USED_UBLK  USED_UREC             0xFLAG STATUS          START_DATE              XIDUSN    XIDSLOT     XIDSQN XID              PRV_XID          PTX_XID
---------- ---------- ----------- ---------------- ---------------- ---------- ---------- ------------------ --------------- ------------------- ---------- ---------- ---------- ---------------- ---------------- ----------------
      1347          1 SYS         000000014ECC2108 000000015A6E5F40          1          1      1E03          INACTIVE        2024-04-26 11:53:12       3001          1       1765 B90B0100E5060000 0000000000000000 0000000000000000

SQL> /

       SID    SERIAL# USERNAME    TADDR            SES_ADDR          USED_UBLK  USED_UREC             0xFLAG STATUS          START_DATE              XIDUSN    XIDSLOT     XIDSQN XID              PRV_XID          PTX_XID
---------- ---------- ----------- ---------------- ---------------- ---------- ---------- ------------------ --------------- ------------------- ---------- ---------- ---------- ---------------- ---------------- ----------------
      1347          1 SYS         000000014ECC2108 000000015A6E5F40          1          1      1E03          INACTIVE        2024-04-26 11:53:12       3010          2       3609 C20B0200190E0000 0000000000000000 0000000000000000

SQL> /

       SID    SERIAL# USERNAME    TADDR            SES_ADDR          USED_UBLK  USED_UREC             0xFLAG STATUS          START_DATE              XIDUSN    XIDSLOT     XIDSQN XID              PRV_XID          PTX_XID
---------- ---------- ----------- ---------------- ---------------- ---------- ---------- ------------------ --------------- ------------------- ---------- ---------- ---------- ---------------- ---------------- ----------------
      1347          1 SYS         000000014ECC2108 000000015A6E5F40          1          1       C0B          INACTIVE        2024-04-26 11:53:13       3008         22       1842 C00B160032070000 0000000000000000 0000000000000000

SQL> /

       SID    SERIAL# USERNAME    TADDR            SES_ADDR          USED_UBLK  USED_UREC             0xFLAG STATUS          START_DATE              XIDUSN    XIDSLOT     XIDSQN XID              PRV_XID          PTX_XID
---------- ---------- ----------- ---------------- ---------------- ---------- ---------- ------------------ --------------- ------------------- ---------- ---------- ---------- ---------------- ---------------- ----------------
      1347          1 SYS         000000014ECC2108 000000015A6E5F40          0          0      1203          INACTIVE        2024-04-26 11:53:17       3004         14       1978 BC0B0E00BA070000 0000000000000000 0000000000000000

SQL> /

       SID    SERIAL# USERNAME    TADDR            SES_ADDR          USED_UBLK  USED_UREC             0xFLAG STATUS          START_DATE              XIDUSN    XIDSLOT     XIDSQN XID              PRV_XID          PTX_XID
---------- ---------- ----------- ---------------- ---------------- ---------- ---------- ------------------ --------------- ------------------- ---------- ---------- ---------- ---------------- ---------------- ----------------
      1347          1 SYS         000000014ECC2108 000000015A6E5F40          1          1      1E03          INACTIVE        2024-04-26 11:53:17       3008         31       2021 C00B1F00E5070000 0000000000000000 0000000000000000



SQL> select * from v$rollname;

       USN NAME
---------- ------------------------------------------------------------
         0 SYSTEM
      3001 _SYSSMU3001_2524665243$
      3002 _SYSSMU3002_3274207932$
      3003 _SYSSMU3003_551481765$
      3004 _SYSSMU3004_3828969324$
      3005 _SYSSMU3005_2166630833$
      3006 _SYSSMU3006_2644181912$
      3007 _SYSSMU3007_2679219495$
      3008 _SYSSMU3008_2173666674$
      3009 _SYSSMU3009_3685259267$
      3010 _SYSSMU3010_1327269793$

11 rows selected.

SQL> alter system dump undo header '_SYSSMU3008_2173666674$';
System altered.


  index  state cflags  wrap#    uel         scn            dba            parent-xid    nub     stmt_num    cmt
  ------------------------------------------------------------------------------------------------
   0x00    9    0x00  0x19d9  0x0002  0x0000.041d937f  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x01    9    0x00  0x19d8  0x0008  0x0000.041d9349  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x02    9    0x00  0x19da  0x0007  0x0000.041d9387  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x03    9    0x00  0x19c4  0x0020  0x0000.041d9475  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x04    9    0x00  0x19d8  0x000b  0x0000.041d93ff  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x05    9    0x00  0x19d4  0x0011  0x0000.041d93e1  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x06    9    0x00  0x19d5  0x001d  0x0000.041d931e  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x07    9    0x00  0x19d1  0x0019  0x0000.041d9392  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x08    9    0x00  0x19d5  0x001c  0x0000.041d934d  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x09    9    0x00  0x19d2  0x000a  0x0000.041d93f6  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0a    9    0x00  0x19cf  0x0004  0x0000.041d93f7  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0b    9    0x00  0x19ce  0x000d  0x0000.041d9403  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0c    9    0x00  0x19dc  0x0012  0x0000.041d9421  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0d    9    0x00  0x19db  0x000f  0x0000.041d940f  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0e    9    0x00  0x19da  0x001b  0x0000.041d9366  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0f    9    0x00  0x19da  0x001f  0x0000.041d9411  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x10    9    0x00  0x19d8  0x0001  0x0000.041d933a  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x11    9    0x00  0x19db  0x0009  0x0000.041d93eb  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x12    9    0x00  0x19d9  0x0014  0x0000.041d9429  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x13    9    0x00  0x19d4  0x0018  0x0000.041d93b0  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x14    9    0x00  0x19cf  0x001e  0x0000.041d943d  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x15    9    0x00  0x19cb  0x000e  0x0000.041d9364  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x16    9    0x00  0x19ce  0x0000  0x0000.041d9379  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x17    9    0x00  0x19ce  0x0003  0x0000.041d9461  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x18    9    0x00  0x19d0  0x0005  0x0000.041d93b6  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x19    9    0x00  0x19cf  0x0013  0x0000.041d939f  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1a    9    0x00  0x19d1  0x0006  0x0000.041d931c  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1b    9    0x00  0x19d1  0x0016  0x0000.041d936f  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1c    9    0x00  0x19d0  0x0021  0x0000.041d9351  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1d    9    0x00  0x19ca  0x0010  0x0000.041d932c  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1e    9    0x00  0x19d0  0x0017  0x0000.041d9449  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1f    9    0x00  0x19cf  0x000c  0x0000.041d941b  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x20    9    0x00  0x19cb  0xffff  0x0000.041d947a  0x0140e83a  0x0000.000.00000000  0x00000002   0x00000000  1714103733




SQL> STARTUP FORCE
ORACLE instance started.

Total System Global Area 4275781632 bytes
Fixed Size                  2260088 bytes
Variable Size            1291846536 bytes
Database Buffers         2969567232 bytes
Redo Buffers               12107776 bytes
Database mounted.
Database opened.


oracle@11g-node2:/home/oracle $ora

SQL*Plus: Release 11.2.0.4.0 Production on Fri Apr 26 12:05:13 2024

Copyright (c) 1982, 2013, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,
Data Mining and Real Application Testing options

SQL> alter system dump undo header '_SYSSMU3010_1327269793$';
System altered.

SQL> oradebug setmypid
Statement processed.
SQL> oradebug tracefile_name
/u01/app/oracle/diag/rdbms/rac11g/rac11g2/trace/rac11g2_ora_15681.trc
SQL> host vi /u01/app/oracle/diag/rdbms/rac11g/rac11g2/trace/rac11g2_ora_15681.trc
    uba: 0x00000000.00bc.1a ext: 0x3  spc: 0xf3a
    uba: 0x00000000.0000.00 ext: 0x0  spc: 0x0
  TRN TBL::

  index  state cflags  wrap#    uel         scn            dba            parent-xid    nub     stmt_num    cmt
  ------------------------------------------------------------------------------------------------
   0x00    9    0x00  0x19da  0x0002  0x0000.041e0dbf  0x0140e83e  0x0000.000.00000000  0x00000001   0x00000000  1714104309
   0x01    9    0x00  0x19d9  0x0008  0x0000.041deb1c  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714103997
   0x02    9    0x00  0x19db  0x0007  0x0000.041e1333  0x0140e83e  0x0000.000.00000000  0x00000001   0x00000000  1714104311
   0x03    9    0x00  0x19c4  0x0020  0x0000.041d9475  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x04    9    0x00  0x19d8  0x000b  0x0000.041d93ff  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x05    9    0x00  0x19d4  0x0011  0x0000.041d93e1  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x06    9    0x00  0x19d6  0x001d  0x0000.041de843  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714103995
   0x07    9    0x00  0x19d2  0xffff  0x0000.041e13e4  0x0140e83e  0x0000.000.00000000  0x00000001   0x00000000  1714104311
   0x08    9    0x00  0x19d6  0x001c  0x0000.041df3ba  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714104001
   0x09    9    0x00  0x19d2  0x000a  0x0000.041d93f6  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0a    9    0x00  0x19cf  0x0004  0x0000.041d93f7  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0b    9    0x00  0x19ce  0x000d  0x0000.041d9403  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0c    9    0x00  0x19dc  0x0012  0x0000.041d9421  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0d    9    0x00  0x19db  0x000f  0x0000.041d940f  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x0e    9    0x00  0x19db  0x0015  0x0000.041df58c  0x0140e83f  0x0000.000.00000000  0x00000003   0x00000000  1714104009
   0x0f    9    0x00  0x19da  0x001f  0x0000.041d9411  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x10    9    0x00  0x19d9  0x0001  0x0000.041de95d  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714103996
   0x11    9    0x00  0x19db  0x0009  0x0000.041d93eb  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x12    9    0x00  0x19d9  0x0014  0x0000.041d9429  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x13    9    0x00  0x19d4  0x0018  0x0000.041d93b0  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x14    9    0x00  0x19cf  0x001e  0x0000.041d943d  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x15    9    0x00  0x19cc  0x0016  0x0000.041df593  0x0140e83b  0x0000.000.00000000  0x00000002   0x00000000  1714104009
   0x16    9    0x00  0x19cf  0x0000  0x0000.041df5a9  0x0140e83e  0x0000.000.00000000  0x00000001   0x00000000  1714104009
   0x17    9    0x00  0x19ce  0x0003  0x0000.041d9461  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x18    9    0x00  0x19d0  0x0005  0x0000.041d93b6  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x19    9    0x00  0x19cf  0x0013  0x0000.041d939f  0x0140e838  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1a    9    0x00  0x19d2  0x0006  0x0000.041de834  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714103995
   0x1b    9    0x00  0x19d2  0x000e  0x0000.041df58a  0x0140e83e  0x0000.000.00000000  0x00000001   0x00000000  1714104009
   0x1c    9    0x00  0x19d1  0x0021  0x0000.041df3d8  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714104002
   0x1d    9    0x00  0x19cb  0x0010  0x0000.041de845  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714103995
   0x1e    9    0x00  0x19d0  0x0017  0x0000.041d9449  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x1f    9    0x00  0x19cf  0x000c  0x0000.041d941b  0x0140e839  0x0000.000.00000000  0x00000001   0x00000000  1714103733
   0x20    9    0x00  0x19cb  0x001a  0x0000.041d947a  0x0140e83a  0x0000.000.00000000  0x00000002   0x00000000  1714103733
   0x21    9    0x00  0x19cd  0x001b  0x0000.041df52a  0x0140e83a  0x0000.000.00000000  0x00000001   0x00000000  1714104009
  EXT TRN CTL::

Note:
可见即使在1个session做大量事务,也会均匀的使用多个undo segment, 对于rollback segment的使用可以查看DIS 402 Space and Transaction Management. 重启也不会导致undo segment wrap重置。

Solution:
可修复的方法,如创建新UNDO,切换新UNDO;如果仅个别UNDO segment wrap耗尽,可考虑删除该UNDO 段或使用隐藏参数标记undo段不可用。 上面这个BUG 19700135已经在12.2 及其以后版本的数据库中修复,只要不是12.2以下的数据库, 或者为了禁用DRM时,将 _gc_undo_affinity 设置成了 false,都很难发生这个问题。 所以19c 中未出问题,不建议再禁用DRM。

打赏

, ,

对不起,这篇文章暂时关闭评论。