设为首页 收藏本站
查看: 536|回复: 0

[经验分享] Oracle 11G rollback段出错修复

[复制链接]

尚未签到

发表于 2016-7-29 07:10:20 | 显示全部楼层 |阅读模式
测试服务器的磁盘满了,经分析由于测试服务器经常进行大量数据清理,UNDO表空间占了太多空间,于是打算新建UNDO表空间(UNDOTBS2),把旧(UNDOTBS1)的清理掉。
删除旧空间的时候发现怎么都删不了,报错说有回滚段被占用。
于是用查看回滚段情况:
select owner,segment_name,SEGMENT_ID,FILE_ID,BLOCK_ID,STATUS,tablespace_name from dba_rollback_segs;
 
结果显示 _SYSSMU14_1571488672$,_SYSSMU16_3431913684$ 等多个在UNDOTBS1上的回滚段的STATUS显示“NEEDS RECOVERY”,即这些回滚段有错误需要修复,阻止了删除UNDOTBS1。
 
上网搜索相关修复方法,按实际情况拟定修复方案,最后成功修复。方案如下:

  • 用实例的system账号以DBA身份登录sqlplus:

    • sqlplus system/**** as sysdba

  • 关闭数据库:

    • shutdown immediate

  • 创建pfile文件:

    • create pfile 'c:/pfile.ora' from spfile

  • 修改pfile文件,添加以下参数:

    • *.undo_management='Manual'
    • _corrupted_rollback_segments=('_SYSSMU14_1571488672$','_SYSSMU16_3431913684$')

  • 启动数据库:

    • startup pfile='c:/pfile.ora'

  • 删除状态为needs Recovery的segment:

    • drop rollback segment "_SYSSMU14_1571488672$"; 
    • 注意是用双引号,删除会有报错信息,只要删除了就忽略出错信息吧。

  • 重启数据库并删除undo表空间:

    • drop tablespace UNDOTBS1 including contents and datafiles;

  • 修改pfile.ora,去除之前添加的隐藏参数启动数据库:

    • startup pfile='c:/pfile.ora'

  • 检查数据库是否能正常工作。
  • 检查正常,确认完成修复,重启服务器。

 
 
以下为修复中使用过的一些命令记录:
查询正在运行的事务的回滚段使用情况
select s.username, u.name from v$transaction t,v$rollstat r, v$rollname u,v$session s where s.taddr=t.addr and t.xidusn=r.usn and r.usn=u.usn order by s.username;

查询数据文件情况
select * from dba_data_files where tablespace_name like 'UNDOTBS1';

查询回滚空间的使用情况
select usn,xacts,status,rssize/1024/1024/1024, hwmsize/1024/1024/1024,shrinks from v$rollstat order by rssize;

创建新的UNDO表空间
create undo tablespace undotbs2 datafile 'D:\app\Administrator\oradata\QAS\UNDOTBS02.DBF' size 10m reuse autoextend on next 100m maxsize 20g;

指定系统使用新的UNDO表空间
alter system set undo_tablespace=undotbs2 scope=both;

显示UNDO相关参数
show parameter undo; 
几个参考链接:
http://blog.csdn.net/life_dba/article/details/9139353
http://blog.csdn.net/cockcrow/article/details/598703
http://www.dba-oracle.com/t_fix_undo_log_corruption.htm

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-250799-1-1.html 上篇帖子: [转]讲解oracle自定义聚合函数 下篇帖子: Oracle表的常用查询实验(二)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表