由一个案例引出SMON的一个功能: Recover Dead transaction

2024-04-04 01:48

本文主要是介绍由一个案例引出SMON的一个功能: Recover Dead transaction,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


  

一.故障说明

 

前段时间一朋友遇到的案例,根据他的描述,我小整理了一下。

 

数据库环境:AIX + ORACLE 10.2.0.5, 单机。

 

朋友说一个大事务不能完成回滚操作,系统异常。 查看等待事件,如下图:

 

 

这里的row cache lock 较为严重。 row cache lock 对应的cache#=11,对应的child latch是dc_object_ids。

 

如何获取这个child latch可以参考如下blog:

latch row cache objects 等待事件及 child latch对象 说明

http://www.cndba.cn/Dave/article/1550

 

Trace 文件出现大量的: waitfor stopper event to be increased。

 

 

这个wait forstopper event to be increased的等待事件是SMON进程的event,也就是说我们的SMON 进程在这个时候出现了异常。

 

    SMON 进程有一个非常重要的功能,就是Recover Dead transaction。

 

使用如下SQL 查看了一下Recover的进度:

SELECT usn,

       state,

      undoblockstotal "Total",

      undoblocksdone "Done",

      undoblockstotal -undoblocksdone "ToDo",

       DECODE(

         cputime,

          0, 'unknown',

            SYSDATE

          +(  (  (undoblockstotal-undoblocksdone)

               / (undoblocksdone/cputime))

             /86400))

          "Estimatedtime to complete"

  FROMv$fast_start_transactions;

 

返回结果如下:

 

粗略的看一下,需要5个月的时间。 开了一个国际玩笑。

 

刚拿到数据,以为是如下文档里说的现象:

Database Appearsto Hang Waits for "Wait for a undo record" and "Wait for stopperevent to be increased" Due to Parallel Transaction Recover [ID 464246.1]

 

MOS的现象有3种:

1)  Database appears to hang

2)  Undo tablespace is growing.

3)  Systemstate dump shows thesignificant waits are for "Wait for a undo record" and "Wait forstopper event to be increased".

 

和朋友确认了一下,数据库没有hang住,UNDO 表空间分配了96G,使用了86%。也正常。所以排除了这个方法。

 

在[ID 464246.1]中,MOS提供的解决方法是:

fast_start_parallel_rollback= false

 

参考如下MOS文档:

Database Hangs Because SMON Is Taking 100% CPUDoing Transaction Recovery [ID 414242.1]

 

    设置fast_start_parallel_rollback参数来提高SMON 进程进行回滚的并行度。将该参数设置为false那么并行回滚将被禁用,若设置为Low(默认值)那么会以2*CPU_COUNT数目的并行度回滚,当设置为High则4*CPU_COUNT数目的回滚进程将参与进来。

 

尝试设置fast_start_parallel_rollback=High,提高SMON的回滚速度,测试的实际结果是没有变化。

 

后来Oracle 原厂说是bug:

Bug 11693365 - Concurrent Droptable and Select on Reference constraint table hangs (deadlock) [ID 11693365.8]

 

该bug的现象:

1)  Deadlock

2)  Hang(Process Hang)

3)  Waits for "library cachelock"

4)  Waits for "row cachelock"

5)  Stack is likely to includedtbdrp

 

该bug的解决方案是:

Disable and drop all the referentialintegrity constraints before dropping the child table.

 eg:

 alter table <child_table_name> disable constraint<constraint_name>;

 alter table <child_table_name> drop constraint<constraint_name>;

 drop table <child_table_name> cascade constraints purge;

 

实际上这个方案在朋友这不可取,所以Oracle 最后建议将数据库升级到11.2.0.3。 这个方案同样也不可取。因为这个变动太大了。

 

朋友的这个环境太复杂了,出现问题的表是一张簇表,表中有5亿的数据,又使用了同义词,关联太多。 这个表是一年前系统从9i升级到10g时迁移过来的。 测试的时候导过一次,后来drop掉了,又正式迁移了一次。

出现问题的时候,这个系统灵异的访问了原来在回收站里的表,这个也是后来通过10046 跟踪出来。最终他们的解决方案是把回收站里的表恢复出来,然后重新创建了同义词,系统就回复正常了。

 

    没有参与整个过程,因此无法具体描述,也是后来听朋友说起整个处理过程,了解了一个大概过程。 

 

通过这个案例引出我们SMON的一个重要功能:Recover Dead transaction。

 

 

二.SMON 的功能:Recover Dead transaction

 

2.1 Recover Dead transaction 说明

服务进程在提交事务(commit)前意外终止的话会形成死事务(dead transaction),PMON进程负责轮询Oracle进程,找出这类意外终止的死进程(dead process),通知SMON将与该dead process相关的dead transaction回滚清理,并且PMON还负责恢复dead process原本持有的锁和latch。

 

因此当我们kill掉一个正在运行的大事务,不管是用kill session(或者shutdown abort),数据库都可能被hang住,或者SMON进程会占用所有可用的CPU资源,用来roll back 中断的大事务,因为事务很大,可能会消耗大量的资源,从而影响数据库的性能。

 

这个时候不建议关闭数据库,因为这个时候执行shutdown immediate,也可能会hang住,所以最终只能用abort的方式来关闭数据库。这样不会降低SMON进程完成rollback的进度,反而会让情况更糟。

 

 

当SMON 进程执行rollback时,我们可以能在alert log里看到如下信息:

 

Waiting for smon to disable tx recovery

 

SMON: about to recover undo segment 12
SMON: mark undo segment 12 as available
SMON: about to recover undo segment 12
*** 2009-11-12 10:08:11.389
SMON: mark undo segment 12 as available

 

 

可以使用如下SQL 查看SMON进程处理事务recovery的进度:

 

SET LINESIZE 100

ALTER SESSIONSETNLS_DATE_FORMAT='DD-MON-YYYYHH24:MI:SS';

 

SELECT usn,

       state,

      undoblockstotal "Total",

      undoblocksdone "Done",

      undoblockstotal - undoblocksdone"ToDo",

       DECODE(

         cputime,

          0, 'unknown',

            SYSDATE

          +(  (  (undoblockstotal-undoblocksdone)

               / (undoblocksdone/cputime))

             /86400))

          "Estimatedtime to complete"

  FROMv$fast_start_transactions;

 

 

在有些版本里,cputime 参数值不正常,一直为0,因此不能估算进度。

 

 

在某些案例中,v$fast_start_transactions视图也不能正常显示,不过还可以查询oracle 内部的数据字典:x$ktuxe。 该字典代表rollback 需要剩余的undo blocks的数量。

 

SELECT ktuxeusn,

       TO_CHAR(SYSDATE,'DD-MON-YYYYHH24:MI:SS') "Time",

      ktuxesiz,

      ktuxesta

  FROMx$ktuxe

 WHEREktuxecfl = 'DEAD';

 

2.2 FAST_START_PARALLEL_ROLLBACK 参数说明

 

fast_start_parallel_rollback参数可以提高SMON 进程进行回滚的并行度。将该参数设置为false那么并行回滚将被禁用,若设置为Low(默认值)那么会以2*CPU_COUNT数目的并行度回滚,当设置为High则4*CPU_COUNT数目的回滚进程将参与进来。

 

 

官网的说明如下:

FAST_START_PARALLEL_ROLLBACK specifies thedegree of parallelism used when recovering terminated transactions.

Terminated transactions are transactionsthat are active before a system failure. If a system fails when there areuncommitted parallel DML or DDL transactions,thenyou can speed up transaction recovery during startup byusing this parameter.

 

Values:

FALSE: Parallelrollback is disabled

LOW: Limitsthe maximum degree of parallelism to 2 * CPU_COUNT

HIGH: Limitsthe maximum degree of parallelism to 4 * CPU_COUNT

 

Note:

If you change the value of this parameter, thentransaction recovery will be stopped andrestarted with the new implied degree of parallelism.

 

关于该参数具体的使用案例可以参考惜分飞的blog

FAST_START_PARALLEL_ROLLBACK与回滚恢复

http://www.xifenfei.com/2534.html

 

 

当fast_start_parallel_rollback= Low/High,即启用并行回滚时,可能会出现并行进程因为各种资源互相阻塞导致回滚工作停滞,如果遇到这种情况,可以将该参数设置为FALSE。一般可以保证恢复工作以串行形式在较长时间内完成。

 

 

 

 

 

---------------------------------------------------------------------------------------

版权所有,文章允许转载,但必须以链接方式注明源地址,否则追究法律责任!

QQ:492913789

Email:ahdba@qq.com

Blog:  http://www.cndba.cn/dave

Weibo:    http://weibo.com/tianlesoftware

Twitter:  http://twitter.com/tianlesoftware

Facebook: http://www.facebook.com/tianlesoftware

Linkedin: http://cn.linkedin.com/in/tianlesoftware

这篇关于由一个案例引出SMON的一个功能: Recover Dead transaction的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/874509

相关文章

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

C#实现高性能拍照与水印添加功能完整方案

《C#实现高性能拍照与水印添加功能完整方案》在工业检测、质量追溯等应用场景中,经常需要对产品进行拍照并添加相关信息水印,本文将详细介绍如何使用C#实现一个高性能的拍照和水印添加功能,包含完整的代码实现... 目录1. 概述2. 功能架构设计3. 核心代码实现python3.1 主拍照方法3.2 安全HBIT

Java 中的 equals 和 hashCode 方法关系与正确重写实践案例

《Java中的equals和hashCode方法关系与正确重写实践案例》在Java中,equals和hashCode方法是Object类的核心方法,广泛用于对象比较和哈希集合(如HashMa... 目录一、背景与需求分析1.1 equals 和 hashCode 的背景1.2 需求分析1.3 技术挑战1.4

Java中实现对象的拷贝案例讲解

《Java中实现对象的拷贝案例讲解》Java对象拷贝分为浅拷贝(复制值及引用地址)和深拷贝(递归复制所有引用对象),常用方法包括Object.clone()、序列化及JSON转换,需处理循环引用问题,... 目录对象的拷贝简介浅拷贝和深拷贝浅拷贝深拷贝深拷贝和循环引用总结对象的拷贝简介对象的拷贝,把一个

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文

录音功能在哪里? 电脑手机等设备打开录音功能的技巧

《录音功能在哪里?电脑手机等设备打开录音功能的技巧》很多时候我们需要使用录音功能,电脑和手机这些常用设备怎么使用录音功能呢?下面我们就来看看详细的教程... 我们在会议讨论、采访记录、课堂学习、灵感创作、法律取证、重要对话时,都可能有录音需求,便于留存关键信息。下面分享一下如何在电脑端和手机端上找到录音功能

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv