zoukankan      html  css  js  c++  java
  • Oracle 正确删除归档日志的方法

           我们都知道在controlfile中记录着每一个archivelog文件的相关信息,当然们在OS下把这些物理文件delete掉后,在我们的controlfile中仍然记录着这些archivelog文件的相关信息,在oracle的OEM管理器中有可视化的日志展现出,当我们手工清除 archive目录下的文件后,这些记录并没有被我们从controlfile中清除掉,也就是oracle并不知道这些文件已经不存在了,这时候我们要做手工的清除的话,下面我经过实验,可以尝试这种方法:

    1、进入rman

    [root@db1 ~]# su - oracle
    [oracle@db1 ~]$ /u01/app/oracle/product/10.2.0/db/bin/rman

    一般都设置了环境变量,所以可以直接执行 rman 命令,如下:

    [oracle@db1 ~]$ rman
    Recovery Manager: Release 11.2.0.1.0 - Production on Fri Sep 25 16:18:03 2020
    Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved.
    
    RMAN> 

    2、connect target /

    RMAN> connect target /
    connected to target database: ORA11G (DBID=4206582437)
    RMAN
    >

    3、crosscheck archivelog all;

           crosscheck archivelog all:验证的是DB的归档日志即log_archive_dest参数指定位置的文件,当手工删除了归档日志以后,Rman备份会检测到日志缺失,从而无法进一步继续执行Rman备份,所以此时需要手工执行crosscheck过程,查看所有的归档日志文件是否都是正常的然后再来执行Rman备份。

     4、delete expired archivelog all;

           这时候我们再去OEM中就看不到这些日志文件了,如果你的从来没有做过这个动作的话,我们可以比较这个动作前的controlfile和动作后的controlfile的文件大小。

    Oracle 正确删除归档并回收空间的方法

            一个 Oracle 归档日志经常满,表现为 /archivelog 这个文件空间占用 100%。大家总是抱怨 Oracle 为何没有归档维护工具,很多人直接删除了事,其实错了,Oracle有归档维护工具,而且很智能,可以正确的删除归档和 FlashBack。

            不过切记:Oracle归档日志对于Oracle的数据恢复和备份非常重要,不到万不得已不要删除归档日志。

            删除归档日志的过程,如下:

     1、以 oracle 用户身份登录

           以 oracle 用户身份登录到数据库服务器主机或者通过网络连接。

    2、进入Oracle数据备份工具

    [oracle@db ~]# rman
    RMAN> rman target /

    或者

    /u01/app/oracle/product/10.2.0/db/bin/rman target/

    或者

    /u01/app/oracle/product/10.2.0/db/bin/rman target/@DTHXRAC1

    3、在RMAN命令窗口里操作

    RMAN> DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';

           说明:SYSDATE-7 ,表明当前的系统时间 7天前。before 关键字表示在7天前的归档日志,如果使用了闪回功能,也会删除闪回的数据。

           同理,有可以删除从7天前到现在的全部日志,不过这个命令要考虑清楚,做完这个删除,最好马上进行数据库全备份。       

    RMAN> DELETE ARCHIVELOG FROM TIME 'SYSDATE-7';

           Unix/Linux 下也可以通过 find 命令找到7天前的归档数据,使用 exec 子操作删除,如下:

    find /archivelog -xdev -mtime +7 -name "*.dbf" -exec rm -f {}  ;

           这样做仍然会在 RMAN 里留下未管理的归档文件,它的作用还是相当于直接用操作系统命令将归档日志文件直接删除,而 Oracle 控制文件并不知道,因此仍需要在 RMAN 里执行下面两条命令:

    RMAN> crosscheck archivelog all;
    
    RMAN> delete expired archivelog all;

           所以,还不如上面的方法好用,不过用 find 命令的好处就是,可以在条件上和 exec 子项做很多操作,实现更复杂的功能。

    简单介绍一下 report obsolete 命令

           使用 report obsolete 命令报告过期备份:

    RMAN> report obsolete;
    RMAN retention policy will be applied to the command
    RMAN retention policy is set to redundancy 1
    Report of obsolete backups and copies
    Type                 Key    Completion Time    Filename/Handle
    --------------------   ------   ------------------    --------------------
    Backup Set           125    01-NOV-04
    Backup Piece         125    01-NOV-04          /data1/oracle/orabak/full_1_541045804
    Backup Set           131    04-NOV-04
    Backup Piece         131    04-NOV-04          /data1/oracle/orabak/full_AVATAR2_20041104_131
    ....
    Backup Set           173    06-DEC-04
    Backup Piece         173    06-DEC-04          /data1/oracle/orabak/full_AVATAR2_20041206_173
    Backup Set           179    11-DEC-04
    Backup Piece         179    11-DEC-04          /data1/oracle/orabak/arch544588206.arc
    .....
     
    Backup Piece         189    17-DEC-04          /data1/oracle/orabak/arch545106606.arc
    Backup Set           190    17-DEC-04
    Backup Piece         190    17-DEC-04          /data1/oracle/orabak/arch545106665.arc
    Backup Set           191    20-DEC-04
    Backup Piece         191    20-DEC-04          /data1/oracle/orabak/arch_AVATAR2_20041220_194
    Archive Log          2973   20-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2985.dbf
    Archive Log          2971   20-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2984.dbf
    .....
    Archive Log          2705   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2717.dbf
    Archive Log          2704   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2716.dbf
    Archive Log          2703   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2715.dbf
    Archive Log          2702   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2714.dbf

    使用 delete obsolete 命令删除过期备份

    RMAN> delete obsolete;
    RMAN retention policy will be applied to the command
    RMAN retention policy is set to redundancy 1
    using channel ORA_DISK_1
     
    Deleting the following obsolete backups and copies:
    Type                 Key    Completion Time    Filename/Handle
     
    --------------------  ------     ------------------    --------------------
    Backup Set           125    01-NOV-04
    Backup Piece         125    01-NOV-04          /data1/oracle/orabak/full_1_541045804
    ....
    Archive Log          2704   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2716.dbf
    Archive Log          2703   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2715.dbf
    Archive Log          2702   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2714.dbf
    Do you really want to delete the above objects (enter YES or NO)? yes
    deleted backup piece
    backup piece handle=/data1/oracle/orabak/full_AVATAR2_20041206_173 recid=173 stamp=544156241
    .....
    deleted archive log
    archive log filename=/opt/oracle/oradata/avatar2/archive/1_2715.dbf recid=2703 stamp=545108268
    deleted archive log
    archive log filename=/opt/oracle/oradata/avatar2/archive/1_2714.dbf recid=2702 stamp=545107659
    Deleted 286 objects
     
    
    RMAN> crosscheck archivelog all;
    allocated channel: ORA_DISK_1
     
    channel ORA_DISK_1: sid=9 devtype=DISK
    validation succeeded for archived log
    archive log filename=/archivelog1/1_615_737652750.dbf recid=928 stamp=750848535
    validation succeeded for archived log
    archive log filename=/archivelog1/1_616_737652750.dbf recid=930 stamp=750851615
    Crosschecked 2 objects
  • 相关阅读:
    API协议
    执行聚合
    执行过滤
    执行查询
    介绍查询语言
    探索你的数据
    探索你的集群(翻译)
    es6.4基本概念(中文翻译)
    Python3.7.4安装
    elasticsearch常用请求
  • 原文地址:https://www.cnblogs.com/morgan363/p/13730941.html
Copyright © 2011-2022 走看看