这篇文章根据笔者在工作中遇到的临时表游标未释放导致回滚段空间不足的错误现象及解决方法进行详尽的介绍,更多内容请参考下文:
一大早,突然收到生产系统报出多个ORA-01650错误,报回滚段空间不足。
先分析一下相关背景。产生报错的程序是一个数据处理模块,每天会将其他系统传过来的平面文件中的内容处理后放入数据库中,事务量很大。我们的系统是9i,划分了16个回滚段,其中两个大的batch回滚段,每个batch回滚段有6G的足够空间。而数据处理模块会在事务中指定使用BATCH1。
再分析报错的模块。检查相关的数据事务处理部分,由于业务需要保持数据的一致性,需要处理完1个文件后才能提交,中间如果出错就要全部回滚。经过确认,这部分代码有很长时间没有做改动了。然后再确认数据量,可以确认,今天(周五)是一周之内文件内容最少的一天。也就是说,如果由于数据量引起错误,其他时间的概率应该更大。
但是,有一点需要注意。指定回滚段是针对事务的,不是针对回滚段。也就是说,我们可以指定某个事务只使用某个回滚段,但是不能保证这个回滚段只被这个事务事务。当一个事务申请使用回滚段时,如果没有自己指定,oracle就会根据当时的各个回滚段的使用情况,分配一个最合适的回滚段给这个事务使用。因此,报回滚段空间不足的事务可能不一定就是导致回滚段空间不足的事务。还有一种可能就是,事务所指定的回滚段被其他事务所占用了。
于是我们就检查是否还有其他事务占用了该回滚段。
SELECT s.sid, s.username, s.osuser, s.machine, s.program, t.xidusn,t.ubafil,t.ubablk,t.used_ublk, t.log_io, t.phy_io, t.cr_get, t.cr_change, r.name, q.sql_text FROM v$session s,v$transaction t, v$RollName r, v$sqlarea q WHERE s.saddr=t.ses_addr and t.xidusn = r.usn and s.sql_address = q.address(+) and s.sql_hash_value = q.hash_value(+) And r,name = ‘RBS_BATCH1’; |
果然发现有5个事务在占用BATCH1。但是发现会话状态为INACTIVE。这说明它们当时并没有运行INSERT/UPDATE/DELETE语句(曾经运行过,事务没有结束),而是将回滚段资源hung住了。
再查下那些对象被hung在BATCH1中,
select l.session_id, l.os_user_name, l.oracle_username, o.owner, o.object_name, t.xidusn,t.ubafil,t.ubablk,t.used_ublk, t.used_urec, t.log_io, t.phy_io, t.cr_get, t.cr_change, r.name from v$locked_object l, dba_objects o, v$transaction t, v$RollName r where l.object_id = o.object_id and l.xidusn = t.xidusn and l.xidslot = t.xidslot and l.xidsqn = t.xidsqn and t.xidusn = r.usn; |
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
作者
相关推荐
-
OpenWorld18大会:Ellison宣布数据库的搜寻和破坏任务
在旧金山举行的甲骨文OpenWorld 2018大会中,甲骨文首席技术官(CTO)兼创始人Larry Elli […]
-
甲骨文自治数据库亮相 带来云计算新希望
早前甲骨文还不在云计算公司之列,而现在该公司正在迅速弥补其失去的时间。甲骨文的云计算核心是甲骨文自治数据库(O […]
-
ObjectRocket着力发展Azure MongoDB服务
MongoDB吸引了微软公司的注意力,微软公司计划针对运行于该公司2017年发布的Azure Cosmos D […]
-
2017年12月数据库流行度排行榜 定格岁末排名瞬间
数据库知识网站DB-engines最近更新的2017年12月份数据库流行度排名情况是否能提供更多的看点呢?TechTarget数据库网站将与您分享12月份的榜单排名情况,让我们拭目以待。