电脑软硬件应用网
当前位置: 电脑软硬件应用网 > 设计学院 > 网络编程 > 数据库 > 正文
ORA-01599错误的解决方法
ORA-01599错误的解决方法
2007-4-22 8:08:29  文/辰风   出处:辰风的博客   

  故障现象:

  数据库无法启动或者cluster系统无法切换。查看数据库日志文件
 $ORACLE_BASE/admin ORCL/bdump/alert_ORCL.log有类似于ORA-01599: failed to acquire rollback
segment (49), cache space is full (currently has (48) entries) Error 1599
happened during db open, shutting down database
类似的错误信息。


  故障分析:
  Orale存在一个初始化参数max_rollback_segments它代表了同时能够online的回滚段的个数。它的缺省值是max(30,TRANSACTIONS/TRANSACTIONS_PER_ROLLBACK_SEGMENT)。当初始化参数中指定(通过rollback_segments参数)或者缺省online的回滚段个数超过max_rollback_segments这个参数后数据库就无法启动。这个错误往往是由于用户在增加了回滚段之后只是修改了rollback_segments参数但没有修改max_rollback_se
gments参数导致的。或者用户增加了public回滚段,同时在初始化参数中注释掉了max_rollback_segments参数也会导致这个问题。

  故障处理:
  可以将oracle初始化参数中的max_rollback_segments修改为大于当前所有的回滚段的总数后再重起数据库即可。如果不知道当前到底有多少回滚段,可以先将这个值设置为100再重起数据库试试。如果还报告同样的错误就再提高此值直到成功为止。当数据库启动起来以后可以通过select count(*) from dba_rollback_segs来获得确切的回滚段个数后再去修改初始化参数。

  日常维护:
  在增加回滚段的时候请注意max_rollback_segments和rollback_segments这几个参数之间的相互作用,最好同时在两个节点上都参看一下。

  • 上一篇文章:

  • 下一篇文章:
  • 最新热点 最新推荐 相关文章
    Mysql数据库名和表名在不同系统下的…
    mysql全文搜索:sql的写法
    解答SQL不许在视图定义ORDER BY子句…
    数据库海量数据查询与优化
    SQL分组实例使用GROUP BY做示例
    图解Slide Window来做SqlServer性能…
    解决附加SQL Server数据库后出现只读…
    一次SQL调优数据库性能问题后的过程
    使用sql语句分离和附加数据库的方法
    一起探讨如何改善数据库性能瓶颈问题
    关于45IT | About 45IT | 联系方式 | 版权声明 | 网站导航 |

    Copyright © 2003-2011 45IT. All Rights Reserved 浙ICP备09049068号