Chinaunix首页 | 论坛 | 博客
  • 博客访问: 479616
  • 博文数量: 178
  • 博客积分: 2547
  • 博客等级: 少校
  • 技术积分: 1764
  • 用 户 组: 普通用户
  • 注册时间: 2006-02-22 08:27
文章分类

全部博文(178)

文章存档

2014年(2)

2013年(2)

2012年(2)

2010年(19)

2009年(26)

2008年(69)

2007年(20)

2006年(38)

我的朋友

分类: Oracle

2012-09-14 11:41:42

最近老是碰见ora-16014错误,这是由于在线日志归档不了造成的, db_recovery_file_dest_size参数设置小,还有就是归档空间不够,解决办法,可以将归档路径下的无用文件删除,或者增大 db_recovery_file_dest_size参数的值:
这里转载网上的一篇文章:

为解决此问题,一种是修改db_recovery_file_dest_size的值,将其扩大。另一种方法是清理db_recovery_file_dest 参数所指定区域的多余数据,为该区域腾出必要的空间。具体方案根据具体情况解决。

      如下为问题解决步骤,系为转载。

 

1.问题以及解决过程

SQL> select status from v$instance;

STATUS
------------
MOUNTED

SQL> alter database open;
alter database open
*
第 1 行出现错误:
ORA-16014: 日志 2 的序列号 27 未归档, 没有可用的目的地
ORA-00312: 联机日志 2 线程 1:
'D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO02.LOG'


SQL> show parameter db_recovery_file

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest                string      D:/oracle/product/10.2.0/flash
                                                 _recovery_area
db_recovery_file_dest_size           big integer 2G

SQL> alter system archive log current;
alter system archive log current
*
第 1 行出现错误:
ORA-01109: 数据库未打开


SQL> alter system switch logfile;
alter system switch logfile
*
第 1 行出现错误:
ORA-01109: 数据库未打开


SQL> shutdown immediate;
ORA-01109: 数据库未打开


已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup
ORACLE 例程已经启动。

Total System Global Area  201326592 bytes
Fixed Size                  1248092 bytes
Variable Size              88081572 bytes
Database Buffers          109051904 bytes
Redo Buffers                2945024 bytes
数据库装载完毕。
ORA-16038: 日志 2 序列号 27 无法归档
ORA-19809: 超出了恢复文件数的限制
ORA-00312: 联机日志 2 线程 1:
'D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO02.LOG'


SQL> alter database open;
alter database open
*
第 1 行出现错误:
ORA-16014: 日志 2 的序列号 27 未归档, 没有可用的目的地
ORA-00312: 联机日志 2 线程 1:
'D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO02.LOG'


SQL> show parameter db_recovery

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest                string      D:/oracle/product/10.2.0/flash
                                                 _recovery_area
db_recovery_file_dest_size           big integer 2G

SQL> alter system set db_recovery_file_dest_size=3G scope=both;

系统已更改。

SQL> alter database open;

数据库已更改。

2.反思:

(1).检查flash recovery area的使用情况:

SQL> select * from v$flash_recovery_area_usage;

FILE_TYPE    PERCENT_SPACE_USED PERCENT_SPACE_RECLAIMABLE NUMBER_OF_FILES
------------ ------------------ ------------------------- ---------------
CONTROLFILE                   0                         0               0
ONLINELOG                     0                         0               0
ARCHIVELOG                 6.36                         0               4
BACKUPPIECE                 .22                         0               1
IMAGECOPY                 63.68                         0               5
FLASHBACKLOG                .51                       .25               2

已选择6行。

SQL>

(2).计算flash recovery area已经占用的空间:

SQL> select sum(percent_space_used)*3/100 from v$flash_recovery_area_usage;

SUM(PERCENT_SPACE_USED)*3/100
-----------------------------
                       2.1231

可以看到,这里已经有2.1231G使用了,这说明我们刚开始设置的db_recovery_file_dest_size=2G不足,导致online redo log无法归档,在这里,我们通过设置db_recovery_file_dest_size参数,增大了flash recovery area来解决这个问题。

(3).也可以通过删除flash recovery area中不必要的备份来释放flash recovery area空间来解决这个问题:

(1). delete obsolete;

(2). crosscheck backupset;

      delete expired backupset;

具体操作:


为了测试向一个表中插入1000万条数据,因为有大量的日志产生,所以事先手工(非RMAN)删除了归档日志,以免因空间不足
而失败。在插入数据过程中,数据库还是down掉了。shutdown后发现数据库无法打开。


SQL> alter database open;
ERROR at line 1:
ORA-16014: log 1 sequence# 92 not archived, no available destinations
ORA-00312: online log 1 thread 1: 'C:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO01.LOG'

 

SQL> select * from v$log
;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIME
---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ----------
         1          1         93   52428800          1 NO  INACTIVE               4345718 04-FEB-09
         3          1         94   52428800          1 NO  INACTIVE               4347356 04-FEB-09
         2          1         95   52428800          1 NO  CURRENT                4368182 04-FEB-09

从以上信息猜测,由于GROUP1无法归档引起,检查归档空间
 

SQL> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest_size           big integer 3G

通过检查实际的归档文件夹后发现,实际使用的归档空间的远远小于3G,猜测可能由于手工删除归档日志所致。
采用以下方法解决:


当手工删除了归档日志以后,Rman备份会检测到日志缺失,从而无法进一步继续执行。
所以此时需要手工执行crosscheck过程,之后Rman备份可以恢复正常。
1.Crosscheck日志

$ rman target /

rman target sys/oracle@test


Recovery Manager: Release 9.2.0.4.0 - 64bit Production

Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
connected to target database: AVATAR2 (DBID=2480694409)

RMAN> crosscheck archivelog all;

using target database controlfile instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=25 devtype=DISK
validation failed for archived log
.........................................

RMAN>


2.使用delete expired archivelog all 命令删除所有过期归档日志:


RMAN> delete expired archivelog all;


RCL/ARCHIVELOG/2009_02_04/O1_MF_1_86_4RL2RJWB_.ARC
81      1    87      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_87_4RL2RYGN_.ARC
82      1    88      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_88_4RL2SGFO_.ARC
83      1    89      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_89_4RL2SY0H_.ARC
84      1    90      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_90_4RL2TOB8_.ARC
85      1    91      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_91_4RL2VHC7_.ARC

 

SQL> alter database open;
 

Database altered.


阅读(1959) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~