oracle 11g rac ORA-01555 快照过旧报错处理

简介:

ORA-01555 快照过旧,是数据库中很常见的一个错误,比如当我们的事务需要使用undo来构建CR块的时候,

而此时对应的undo 已经不存在了, 这个时候就会报ORA-01555的错误。

环境是Oracle 11g RAC 由于客户执行一个比较复杂的SQL,使用PLSQL运行了88分钟后出现报错,这是一个要查看报表的SQL。


临时的处理方法如下:

以下为虚拟机模拟操作,建议数据库安装的时候这个参数一定要提前调整优化一下,不要使用默认值。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
[root@ysdb1 ~] # su - oracle
[oracle@ysdb1 ~]$ sqlplus / as sysdba
SQL*Plus: Release 11.2.0.4.0 Production on Fri Dec 23 10:39:44 2016
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
SYS@ysdb1>show parameter undo;
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900     --默认15分钟
undo_tablespace                      string      UNDOTBS1
SYS@ysdb1>
SYS@ysdb1>alter system  set  undo_retention=10800 scope=both;
System altered.


--查看表空间容量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
SYS@ysdb1>col tablespace_name  for  a15
SYS@ysdb1>col free_rate  for  a15
SYS@ysdb1>SELECT a.tablespace_name,
              ROUND (a.total_size)  "total_size(MB)" ,
              ROUND (a.total_size) - ROUND (b.free_size, 3)  "used_size(MB)" ,
              ROUND (b.free_size, 3)  "free_size(MB)" ,
              ROUND (b.free_size / total_size * 100, 2) ||  '%'  free_rate
       FROM ( SELECT tablespace_name, SUM (bytes) / 1024 / 1024 total_size
                   FROM dba_data_files
               GROUP BY tablespace_name) a,
              ( SELECT tablespace_name, SUM (bytes) / 1024 / 1024 free_size
                  FROM dba_free_space
              GROUP BY tablespace_name) b
     WHERE a.tablespace_name = b.tablespace_name(+);
TABLESPACE_NAME total_size(MB) used_size(MB) free_size(MB) FREE_RATE
--------------- -------------- ------------- ------------- ---------------
SYSAUX                     600       178.625       421.375 70.23%
UNDOTBS1                   200        56.062       143.938 71.97%
USERS                        5             1             4 80%
SYSTEM                     700         287.5         412.5 58.93%
UNDOTBS2                   200         6.687       193.313 96.66%
1
2
3
4
5
6
7
8
9
10
SYS@ysdb1> SELECT   tablespace_name, status, SUM (bytes) / 1024 / 1024  "Bytes(M)"
         FROM   dba_undo_extents
     GROUP BY   tablespace_name, status;
TABLESPACE_NAME      STATUS      Bytes(M)
TABLESPACE_NAME STATUS      Bytes(M)
--------------- --------- ----------
UNDOTBS1        UNEXPIRED         11
UNDOTBS2        UNEXPIRED      2.125
UNDOTBS1        EXPIRED      44.0625
UNDOTBS2        EXPIRED       3.5625


1.出现ORA-01555错误,通常有2种情况:

    1)SQL语句执行时间太长,或者UNDO表空间过小,或者事务量过大,或者过于频繁的提交,导致执行SQL过程中进行一致性读时,SQL执行后修改的前镜像(即UNDO数据)在UNDO表空间中已经被覆盖,不能构造一致性读块(CR blocks)。  这种情况最多。

    2)SQL语句执行过程中,访问到的块,在进行延迟块清除时,不能确定该块的事务提交时间与SQL执行开始时间的先后次序。 这种情况很少。

 

 

2.第1种情况解决的办法:

  1)增加UNDO表空间大小

  2)增加undo_retention 时间,默认只有15分钟

  3)优化出错的SQL,减少查询的时间,首选方法

  4)避免频繁的提交











本文转自 roidba 51CTO博客,原文链接:http://blog.51cto.com/roidba/1885405,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
运维 Oracle 前端开发
Oracle 11g RAC集群日常运维命令总结
Oracle 11g RAC集群日常运维命令总结
112 2
|
4月前
|
Oracle 关系型数据库
分布式锁设计问题之Oracle RAC保证多个节点写入内存Page的一致性如何解决
分布式锁设计问题之Oracle RAC保证多个节点写入内存Page的一致性如何解决
|
5月前
|
存储 负载均衡 Oracle
|
5月前
|
存储 Oracle 关系型数据库
|
2月前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
200 64
|
17天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
64 11
|
1月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
1月前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
23天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。

推荐镜像

更多