背景

当Oracle 归档日志满了后,将无法正常登入oracle,需要删除一部分归档日志才能正常登入ORACLE。最近遇到一个问题,一套Oracle 11g数据库使用RMAN删除了归档日志,但是仍然无法释放,导致无法登陆oracle数据库。

1.查看归档日志文件

oracle@ps251n2s:[/opt/oracle/archive/db] ls -ltr |more

total 3059881082

-rw-r----- 1 oracle oinstall 725320704 May 20 2016 1_1_91233774.dbf

-rw-rw---- 1 oracle oinstall 1756937216 Jun 7 2016 1_2_91233774.dbf

-rw-rw---- 1 oracle oinstall 1756731392 Jun 21 2016 1_3_91233774.dbf

-rw-rw---- 1 oracle oinstall 1758001152 Jul 3 2016 1_4_91233774.dbf

-rw-rw---- 1 oracle oinstall 1756729344 Jul 15 2016 1_5_91233774.dbf

-rw-rw---- 1 oracle oinstall 1765750784 Jul 26 22:00 1_6_91233774.dbf

-rw-rw---- 1 oracle oinstall 1760346112 Aug 6 14:04 1_7_91233774.dbf

......

2.使用 RMAN list archivelog all; 查看日志也没有显示旧归档日志的记录

RMAN> list archivelog all;

using target database control file instead of recovery catalog

List of Archived Log Copies for database with db_unique_name DBS

=====================================================================

Key Thrd Seq S Low Time

------- ---- ------- - ---------

1206 1 1206 A 14-JAN-17

Name: /opt/oracle/archive/db/1_1206_91233774.dbf

1207 1 1207 A 14-JAN-17

Name: /opt/oracle/archive/db/1_1207_91233774.dbf

1208 1 1208 A 14-JAN-17

Name: /opt/oracle/archive/db/1_1208_91233774.dbf

......

3.使用crosscheck检查也没有查到旧归档日志记录

RMAN> crosscheck archivelog all;

using target database control file instead of recovery catalog

allocated channel: ORA_DISK_1

channel ORA_DISK_1: SID=16 device type=DISK

validation succeeded for archived log

archived log file name=/opt/oracle/archive/db/1_1206_91233774.dbf RECID=1206 STAMP=933244655

validation succeeded for archived log

archived log file name=/opt/oracle/archive/db/1_1207_91233774.dbf RECID=1207 STAMP=933249510

validation succeeded for archived log

archived log file name=/opt/oracle/archive/db/1_1208_91233774.dbf RECID=1208 STAMP=933254500

validation succeeded for archived log

archived log file name=/opt/oracle/archive/db/1_1209_91233774.dbf RECID=1209 STAMP=933259445

validation succeeded for archived log

4.查看v$archived_log视图也没有旧归档日志记录

.解决过程

1.在MOS上找到一篇文章《Why Are Controlfile Entries For Archived Logs Not Overwritten After CONTROL_FILE_RECORD_KEEP_TIME? (文档 ID 1056085.1)》

文章介绍控制文件中的归档日志信息是由V$CONTROLFILE_RECORD_SECTION视图中的ARCHIVED LOG条目去控制的,当RECORDS_TOTAL=RECORDS_USED时控制文件中的旧的归档日志就会被覆盖掉。

2.查数据库中的V$CONTROLFILE_RECORD_SECTION视图,看到ARCHIVED LOG行的records_total=224意味着控制文件中只能保留224条归档日志文件信息。

SYS@dbs> select * from v$controlfile_record_section where type='ARCHIVED LOG';

TYPE      RECORD_SIZE RECORDS_TOTAL RECORDS_USED FIRST_INDEX LAST_INDEX LAST_RECID

---------------------------- ----------- ------------- ------------ ----------- ---------- ----------

ARCHIVED LOG      584   224   224   88  87  1235

3.查询v$archived_log视图,总数为224条

SYS@dbs> select count(*) from v$archived_log;

COUNT(*)

----------

224

这时应该可以推断出由于控制文件中只能保留224条归档日志数据,所以以前的归档信息已经被控制文件刷出,RMAN无法识别到这些归档文件,所以就无法删除这些归档日志。

4.将旧的归档日志重新注册到控制文件中

RMAN> catalog start with '/opt/oracle/archive/db';

......

File Name: /opt/oracle/archive/db/1_1005_91233774.dbf

File Name: /opt/oracle/archive/db/1_1006_91233774.dbf

File Name: /opt/oracle/archive/db/1_1007_91233774.dbf

Do you really want to catalog the above files (enter YES or NO)? yes

cataloging files...

cataloging done

......

RMAN> list archivelog all;

.....

1236 1 301 A 22-OCT-16

Name: /opt/oracle/archive/db/1_301_91233774.dbf

1237 1 302 A 22-OCT-16

Name: /opt/oracle/archive/db/1_302_91233774.dbf

......

5.旧的归档日志文件已经注册到控制文件中了,再使用RMAN进行删除就可以了

delete archivelog until logseq 1007;

6.再次查询v$controlfile_record_section视图,records_total也被“撑”大了

SYS@db> select * from v$controlfile_record_section where type='ARCHIVED LOG';

TYPE      RECORD_SIZE RECORDS_TOTAL RECORDS_USED FIRST_INDEX LAST_INDEX LAST_RECID

---------------------------- ----------- ------------- ------------ ----------- ---------- ----------

ARCHIVED LOG      584   896   742  807  652  1800

至此问题解决。

最新文章

  1. UWP开发之Mvvmlight实践二:Mvvmlight的核心框架MVVM与MVC、MVP的区别(图文详解)
  2. JSP前三章测试改错
  3. VS2013单元测试 的安装、创建与执行
  4. cPage分页详细介绍
  5. linq查询一个字段的总和
  6. Saving changes is not permitted in SQL Server
  7. 关于js touch事件 的引用设置
  8. hdu2923 最短路floyd
  9. image
  10. apache 配置虚拟主机
  11. poj 1392 Ouroboros Snake
  12. 转载-smarty教程(基本语法)
  13. 如何清除xcode里面的mobileprovision文件
  14. Spring 对缓存的抽象
  15. 深入理解Linux内核 学习笔记(4)
  16. 实现ssr服务端渲染
  17. rpgmakermv \c 常用颜色一览
  18. 8 -- 深入使用Spring -- 5...1 启用Spring缓存
  19. laravel控制器方法中,用函数作为变量进行传递时的处理方法
  20. Java的学习01

热门文章

  1. CSS z-index应用靠近用户的框
  2. css子选择器 :frist-child :nth-child(n) :nth-of-type(n) ::select选择器
  3. [原题复现]SUCTF 2019 WEB EasySQL(堆叠注入)
  4. mysql官网下载yum
  5. java中对于浮点型数据操作
  6. 直面秋招!非科班生背水一战,最终拿下阿里等大厂offer!
  7. 【flask-migrate】:ERROR [root] Error: Target database is not up to date.
  8. Java基础教程——线程池
  9. go特性-数组与切片
  10. C++基础知识篇:C++ 变量类型