首页 > 数据库 >Oracle 正确删除归档日志的方法

Oracle 正确删除归档日志的方法

时间:2024-09-25 08:52:17浏览次数:8  
标签:04 archive oracle 归档 Oracle 日志 DEC Backup RMAN

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

标签:04,archive,oracle,归档,Oracle,日志,DEC,Backup,RMAN
From: https://www.cnblogs.com/ataoxz/p/18430500

相关文章

  • 删除归档日志和过期备份
    删除归档日志删除某个Sequence之前(包含该Sequence)的归档日志RMAN>deletearchiveloguntilsequencexxx;RMAN>deletearchivelogfromsequencexxxuntilsequencexxx; 删除系统时间1天以前的归档日志,不会删除闪回区有效的归档日志(可以指定删除多久日志)RMAN>delet......
  • 基于父模型归档的 Pydantic 联合判别器
    我有这样的模型:classFoo(BaseModel):protocol:strprotocol_params:Union[ProtocolOneParam,ProtocolTwoParam]ProtocolOneParam和ProtocolTwoParam没有具有可区分值的相同字段,因此我可以将它们用作Discriminator,而我可以理解哪个模......
  • 【Linux】多线程:线程池的创建、日志类、RAII互斥锁、单例模式:饿汉方式与懒汉方式
    目录一、线程池概念二、线程的封装及线程池类成员变量的介绍 三、单例模式饿汉方式(EagerInitialization)懒汉方式(LazyInitialization)四、RAII类型的互斥锁 五、日志类的实现六、简单的任务类创建七、线程池的创建 一、线程池概念线程池(ThreadPool)是一种基于......
  • Serilog文档翻译系列(五) - 编写日志事件
    日志事件通过Log静态类或ILogger接口上的方法写入接收器。下面的示例将使用Log以便语法简洁,但下面显示的方法同样可用于接口。Log.Warning("Diskquota{Quota}MBexceededby{User}",quota,user);通过此日志方法创建的警告事件将具有两个相关属性,Quota和User。假......
  • 2024/9/24日 日志
    今天上午进行了工程实训课--》钳工实训,第一次切身实地的参与到器件打造,本次课程打造的是心形,从铁柱到薄片再到心形,手锯到发麻发酸,却仍需力气去进行最后的精度刻画切割,更让我对高精密的器件的制造感到敬佩。其实是相通的,任何事的完成都离不开尽心和耐力,这对我的日常学习也是一次宝......
  • 9.24 开发MES系统日志二
    今天通过大模型设计了MES系统的数据库表,我感觉它其中需要改的地方应该会很多,本次使用大模型来回答这个问题只是为了有个示例,让心里有底,比如在我看来最基本的存储各种二维码的字段不存在,这一点需要仔细补充。同时三天之内需要提出一个队本系统的问题,其实我早就想好了想要提交的问......
  • 考前须知:Oracle OCP考试流程和准备
    考前须知:OracleOCP考试流程和准备OCP(OracleCertifiedProfessional),是甲骨文数据库认证中很常见的一个,但却有着很重要的作用,对于从事大型数据库相关行业的人来说,几乎是必考的一种,OCP证书含金量较高,考试也有一定的难度,所以考前要对OCP考试有一些了解。​一.OCP认证考试流程:......
  • 大数据-136 - ClickHouse 集群 表引擎详解1 - 日志、Log、Memory、Merge
    点一下关注吧!!!非常感谢!!持续更新!!!目前已经更新到了:Hadoop(已更完)HDFS(已更完)MapReduce(已更完)Hive(已更完)Flume(已更完)Sqoop(已更完)Zookeeper(已更完)HBase(已更完)Redis(已更完)Kafka(已更完)Spark(已更完)Flink(已更完)ClickHouse(正在更新···)章节内容上节我们完成了如下的内容:测试连接集群数据类型......
  • VR开发日志-如何用VR头盔看到自己开发的VR内容?如何用Pico头盔直连UE开发的内容预览?
    大家好,我是JK,今天和大家分享关于如何用VR头盔看到自己开发的VR内容?本次使用的方法是用Pico头盔直连UE开发的内容预览。大家可以跟着步骤来做,具体操作步骤如下:第一步:到pico官网下载PicoDeveloperCerter,链接:PICO开发者平台(picoxr.com)第二步:安装好PicoDeveloper......
  • 统信UOS安装Oracle 11g的客户端
    统信UOS安装Oracle11g的客户端一个积分的下载地址https://download.csdn.net/download/u011189649/89791511解压客户端压缩文件到/db/#首先执行xhost+xhost+#上传linux.x64_11gR2_client.zip文件至/db/目录;#如果上传不了就在局域网搭个http服务,然后用wget下载#wget......