`
e-ant
  • 浏览: 73344 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

如何删除归档日志文件

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


1. 进入rman 
2. connect target /
3. crosscheck archivelog all;
4. delete expired archivelog all;
这时候我们再去OEM中看就一定看不到,如果你的从来没有做过这个动作的话,我们可以比较从这个动作前的controlfile后动作后的controlfile的大小!

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


ORACLE正确删除归档并回收空间的方法
一个ORACLE归档日志经常满,表现为/oraarchive 这个文件空间占用100%大家一定抱怨ORACLE为何没有归档维护工具,很多人直接删除了事,错了,ORACLE有,而且很智能,可以正确的删除归档和FLASHBACK,不过切记,ORACLE归档日志对于ORACLE的数据恢复和备份非常重要,不到万不得已不要删除归档日志。
删除归档日志的过程
以ORACLE用户身份登录到数据库服务器主机或通过网络连接
进入ORACLE数据备份工具
rman target/
或rman target/@orcl
在命令窗口里面执行
DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';
说明
SYSDATA-7,表明当前的系统时间7天前,before关键字表示在7天前的归档日志,如果使用了闪回功能,也会删除闪回的数据。
同样道理,也可以删除从7天前到现在的全部日志,不过这个命令要考虑清楚,做完这个删除,最好马上进行全备份数据库
DELETE ARCHIVELOG FROM TIME 'SYSDATE-7';

UNIX/LINUX下也可以通过FIND找到7天前的归档数据,使用EXEC子操作删除

find /oraarchive -xdev -mtime +7 -name "*.dbf" -exec rm -f {} ;
这样做仍然会在RMAN里留下未管理的归档文件
仍需要在RMAN里执行下面2条命令
crosscheck archivelog all;
delete expired archivelog all;
所以还不如上面的方法好用,不过用FIND的好处就是,可以在条件上,和EXEC子项上做很多操作,实现更复杂的功能

3.简要介绍一下report obsolete命令

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

RMAN> report obsolete;RMAN retention policy will be applied to the commandRMAN retention policy is set to redundancy 1Report of obsolete backups and copiesType                 Key    Completion Time    Filename/Handle-------------------- ------ ------------------ --------------------Backup Set           125    01-NOV-04Backup Piece       125    01-NOV-04          /data1/oracle/orabak/full_1_541045804Backup Set           131    04-NOV-04Backup Piece       131    04-NOV-04          /data1/oracle/orabak/full_AVATAR2_20041104_131....Backup Set           173    06-DEC-04Backup Piece       173    06-DEC-04          /data1/oracle/orabak/full_AVATAR2_20041206_173Backup Set           179    11-DEC-04Backup Piece       179    11-DEC-04          /data1/oracle/orabak/arch544588206.arc.....Backup Piece       189    17-DEC-04          /data1/oracle/orabak/arch545106606.arcBackup Set           190    17-DEC-04Backup Piece       190    17-DEC-04          /data1/oracle/orabak/arch545106665.arcBackup Set           191    20-DEC-04Backup Piece       191    20-DEC-04          /data1/oracle/orabak/arch_AVATAR2_20041220_194Archive Log          2973   20-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2985.dbfArchive 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.dbfArchive Log          2704   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2716.dbfArchive Log          2703   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2715.dbfArchive Log          2702   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2714.dbf


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

RMAN> delete obsolete;RMAN retention policy will be applied to the commandRMAN retention policy is set to redundancy 1using channel ORA_DISK_1Deleting the following obsolete backups and copies:Type                 Key    Completion Time    Filename/Handle-------------------- ------ ------------------ --------------------Backup Set           125    01-NOV-04Backup Piece       125    01-NOV-04          /data1/oracle/orabak/full_1_541045804....Archive Log          2704   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2716.dbfArchive Log          2703   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2715.dbfArchive Log          2702   17-DEC-04          /opt/oracle/oradata/avatar2/archive/1_2714.dbfDo you really want to delete the above objects (enter YES or NO)? yesdeleted backup piecebackup piece handle=/data1/oracle/orabak/full_AVATAR2_20041206_173 recid=173 stamp=544156241.....deleted archive logarchive log filename=/opt/oracle/oradata/avatar2/archive/1_2715.dbf recid=2703 stamp=545108268deleted archive logarchive log filename=/opt/oracle/oradata/avatar2/archive/1_2714.dbf recid=2702 stamp=545107659Deleted 286 objectsRMAN> crosscheck archivelog all;released channel: ORA_DISK_1allocated channel: ORA_DISK_1channel ORA_DISK_1: sid=19 devtype=DISKspecification does not match any archive log in the recovery catalog


5 在rman中用crosscheck检查归档日志,2个归档日志都是失败的:
RMAN> crosscheck archivelog all;

释放的通道: ORA_DISK_1
分配的通道: ORA_DISK_1
通道 ORA_DISK_1: sid=14 devtype=DISK
对归档日志的验证失败
存档日志文件名 =D:ORACLEORADATATESTARCHIVE1_47.DBF 记录 ID=1 时间戳 =572866
683
对归档日志的验证失败
存档日志文件名 =D:ORACLEORADATATESTARCHIVE11_48.DBF 记录 ID=2 时间戳 =57286
6931
已交叉检验的 2 对象

6 试着同步一下,看行不行,结果不行,crosscheck还是失败:
RMAN> resync catalog;

正在启动全部恢复目录的 resync
完成全部 resync

RMAN> crosscheck archivelog all;

释放的通道: ORA_DISK_1
分配的通道: ORA_DISK_1
通道 ORA_DISK_1: sid=14 devtype=DISK
对归档日志的验证失败
存档日志文件名 =D:ORACLEORADATATESTARCHIVE1_47.DBF 记录 ID=1 时间戳 =572866
683
对归档日志的验证失败
存档日志文件名 =D:ORACLEORADATATESTARCHIVE11_48.DBF 记录 ID=2 时间戳 =57286
6931
已交叉检验的 2 对象

7 用list expired看看是否有失效的archive log,证明没有失效的archive log:
RMAN> list expired archivelog all;

说明与恢复目录中的任何存档日志均不匹配

8 更改语言环境试试,结果再次crosscheck,2个archive log 都成功了:
RMAN> exit


恢复管理器完成。

C:>set nls_lang=american_america.zhs16gbk

C:>rman catalogrman/rman@safetarget /

Recovery Manager: Release 9.2.0.1.0 - Production

Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.

connected to target database: TEST (DBID=1870953724)
connected to recovery catalog database

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=D:ORACLEORADATATESTARCHIVE1_47.DBF recid=1 stamp=57286
6683
validation succeeded for archived log
archive log filename=D:ORACLEORADATATESTARCHIVE11_48.DBF recid=2 stamp=5728
66931
Crosschecked 2 objects

分享到:
评论

相关推荐

    oracle Rman删除归档脚本for windows

    为了释放空间,需要定时删除归档日志文件。以下是使用 Windows 计划任务执行删除归档脚本的步骤。 是什么是 RMAN? RMAN 是 Oracle 数据库中的备份和恢复工具,用于管理数据库的备份和恢复。RMAN 提供了多种类型的...

    Oracle 删除归档日志实例

    - **删除旧日志**:只删除超过一定时间(如7天)的归档日志文件,保留最近一段时间的日志以备不时之需。例如,在UNIX/Linux环境下,可以使用`find`命令结合`exec`操作来查找并删除特定时间之前的归档日志文件: ```...

    DB2 归档日志清理

    这个命令可以帮助我们了解归档日志的时间戳信息以及当前存在的有效归档日志文件的数量。 4. **强制断开所有会话连接**:执行`db2 force application all`命令可以强制断开所有与数据库的连接会话。这一步骤对于确保...

    RMAN 删除指定几天前的归档

    Oracle数据库中的RMAN(Recovery Manager)是一个常用的数据库备份和恢复管理工具,可以用来删除指定天数前的归档日志文件。 首先,我们需要了解归档日志的作用。在Oracle数据库中,当数据库处于归档模式时,所有对...

    自动删除ORACLE归档日志文件

    #功能:自动删除ORACLE归档日志文件 #删除方式:rman ,deletearchivelog #调用方式:可单独调用,或在job_clean_archivlog.sh脚本中根据需要调用见另外的附件) ##############################################

    如何正确删除Oracle归档日志

    在UNIX/Linux环境下,还可以使用`find`命令结合`exec`子命令来查找并删除特定条件下的归档日志文件: ``` find /oraarchive -xdev -mtime +7 -name "*.dbf" -exec rm -f {} \; ``` 这条命令将会删除`/oraarchive`...

    Linux的定时清理oracle归档日志文件及脚本.pdf

    在脚本中,我们使用了 allocate channel 命令来分配设备,连接 Oracle 数据库,然后使用 delete 命令来删除归档日志文件。最后,我们使用 crosscheck backup 和 delete 命令来检查和删除过期的备份文件。 本文提供...

    当空间占用率高于60%时自动删除ORACLE归档日志文件

    #功能:当空间占用率高于60%时自动删除ORACLE归档日志文件 # #删除方式:高于60%时使用rman+deletearchivelog,高于79%时使用武力删除 #调用方式:可单独调用,或配置定时任务自动执行脚本(会调用clean_archivelog....

    Linux下自动删除归档日志文件的方法

    本文将详细介绍如何在Linux环境下设置自动删除归档日志文件的策略,以确保系统资源的有效利用。 首先,我们需要明确日志删除策略。在这个例子中,我们的目标是删除7天前的归档日志文件以及`.tgz`备份文件。这样的...

    Oracle归档日志删除

    通常不建议直接在操作系统层面删除归档日志,因为这样会导致控制文件中的信息与实际存在的文件不一致。正确的做法是通过RMAN(Recovery Manager)来管理和删除归档日志。 删除Oracle归档日志的正确步骤如下: 1. *...

    清理备库已经应用的归档日志

    在Oracle数据库中,当redo log文件填满时,当前的redo log组会切换到下一个未使用的组,而旧的日志文件则被归档,生成归档日志文件。这些文件包含自上次归档以来的所有更改,对于备库来说,它们用于将变更应用到备用...

    oracle归档日志的开启及删除.docx

    注意:在删除归档日志之前,需要确保已经关闭了归档日志模式,以免删除了重要的日志文件。 Oracle数据库中的归档日志是一个重要的日志机制,但是需要定期清理,以免占用过多的磁盘空间。同时,需要谨慎地使用归档...

    oracle 删除归档日志

    接下来,可以使用`asmcmd list`或`asmcmd ls`命令查看归档日志所在的目录和文件名,最后使用`asmcmd rm`命令删除指定的归档日志文件。 5. **监控和清理策略**:为了防止存储空间耗尽,建议设置定期清理归档日志的...

    删除ORACLE归档日志

    这个脚本会遍历指定目录下的所有归档日志文件,如果文件创建日期超过7天,它将被删除。 5. **执行脚本**:在确保脚本无误后,给予执行权限(`chmod +x delete_oracle_archives.sh`),然后执行它(`./delete_...

    删除归档日志、更改归档模式

    3. **执行删除操作**: 使用`ARCHIVELOG DELETE`命令,指定需要删除的归档日志文件或根据保留策略自动删除。 4. **清理磁盘空间**: 删除物理文件,确保磁盘空间得到释放。 **二、更改归档模式** 更改数据库的归档...

    ORACLE11g数据库归档日志清理规程[归纳].pdf

    如果该参数的VALUE为空,意味着数据库没有配置恢复区,此时可以直接在服务器上删除归档日志文件。如果VALUE非空,表明数据库启用了闪回恢复区,此时需要使用RMAN(恢复管理器)来安全地删除归档日志。 要使用RMAN...

    Oracle清除归档日志

    `命令可以删除已经过期的归档日志文件。 4. **退出RMAN工具:** - 输入`exit;`命令退出RMAN工具。 #### 四、注意事项 - 在执行任何清理操作之前,请确保数据库的备份是完整的,并且能够正确恢复。 - 使用RMAN...

    Oracle 12c实战归档日志文件

    ### Oracle 12c实战归档日志文件详解 #### 一、归档日志文件概念及作用 **归档日志文件**是联机重做日志文件组的副本,它包含了重做记录(redo records)以及一个唯一的日志序列号(log sequence number)。这些文件...

    aix系统下oracle数据库归档日志清除步骤

    7. **删除归档日志**:使用`rm`命令配合通配符来删除指定的归档日志文件,例如`rm 1_11*`,如图6所示。务必谨慎操作,确保不会误删重要文件。 8. **验证空间变化**:删除归档日志后,使用`df -g`命令再次检查文件...

Global site tag (gtag.js) - Google Analytics