部署自动清理任务解决ORA-00257: archiver error. Connect internal only, until freed

devtools/2024/11/28 20:06:24/

    使用oracle数据库的时候,我们一般都会开启归档,确保数据库的日志连续和和数据安全。但随着数据库的运行,归档文件会越来越多,最终撑满磁盘空间,数据库无法继续归档,出现“ORA-00257: archiver error. Connect internal only, until freed”错误。人为手工清理日志文件,可以暂时解决相应问题,为彻底解决该问题,我们可以设置清理任务。

一、直接清理方法

1.1,制作清理脚本

    我们在服务器上,生成一个脚本,通过rman命令去清理3天前的归档文件:

[oracle@oracle11g app]$ pwd
/oracle/app
[oracle@oracle11g app]$ ls
control180116.ora  controlbak.ora  createcontrol.sh  data  orabak  oracle  oraInventory  rm_arch.sh
[oracle@oracle11g app]$ cat rm_arch.sh
delete noprompt archivelog until time 'sysdate-3';
crosscheck archivelog all;
[oracle@oracle11g app]$ 

1.2,配置自动任务脚本

[oracle@oracle11g app]$ ls auto_rm_arch.sh 
auto_rm_arch.sh
[oracle@oracle11g app]$ cat auto_rm_arch.sh 
su - oracle -c "rman target / cmdfile=/oracle/app/rm_arch.sh msglog=/oracle/app/rm_arch.log"
[oracle@oracle11g app]$ 

    我们配置crontab自动任务,让其每天晚上2点调用auto_rm_arch.sh,进行归档文件的自动清理。

[root@oracle11g ~]# crontab -l
0 2 * * * sh /oracle/app/auto_rm_arch.sh
[root@oracle11g ~]# 

二、备份归档日志文件方法

    大部分oracle数据库,我们都需要进行rman的备份,我们可以通过备份归档的时候,对备份完成的归档日志文件进行清理,下面我们列出归档日志备份清理的脚本:

crosscheck archivelog all;
run 
{  allocate channel a1 type 'disk';allocate channel a2 type 'disk';allocate channel a3 type 'disk';	   sql 'alter system archive log CURRENT';backup filesperset=25 format '%d_arch_%s_%p_%h'  skip inaccessible                                       (archivelog all delete input); //这里delete input完成备份日志文件的清理 release channel a1;release channel a2;release channel a3;
}


http://www.ppmy.cn/devtools/137744.html

相关文章

Web day02 Js Vue Ajax

目录 1.javascript: 1.js的引入方式: 2.js变量 & 数据类型 & 输出语句: 模板字符串: 3.函数 & 自定义对象: 4. json 字符串 & DOM操作: 5. js事件监听: 6.js的模块化导入或者导出&a…

C++虚函数面试题及参考答案

目录 什么是虚函数?它的作用是什么? 如何在 C++ 中声明一个虚函数?请举个例子说明。 虚函数如何实现多态?请给出简单示例。 解释什么是动态绑定(dynamic binding)与静态绑定(static binding)。 如果基类的函数是虚函数,派生类的对应函数是否需要再次声明为虚函数…

深入理解Go语言中的`sync.Pool`与常规内存分配

在Go语言的并发编程中,内存管理是一个不可忽视的话题。sync.Pool作为Go标准库中的一个特殊工具,提供了一种对象池化机制,以优化内存分配和垃圾回收(GC)。本文将深入探讨sync.Pool与常规内存分配的主要区别,…

uni-app 自定义平台如何进行 static 目录的条件编译

一. 自定义平台如何进行 static 目录的条件编译 关于如何自定平台,参考之前文章: uni-app 玩转条件编译:自定义平台的条件编译实战详解https://blog.csdn.net/qq_24956515/article/details/143951206 由于官方不支持创建自定义平台下的 st…

设计模式简介

设计模式的八个原则: 依赖倒置原则:高层次的代码(稳定)不应该依赖低层次的代码(变化),高层次的代码应该依赖于抽象。抽象的代码不应该依赖实现细节,实现细节应该依赖抽象。开放封闭…

C/C++基础知识复习(30)

1) 什么是 C 中的 Lambda 表达式?它的作用是什么? Lambda 表达式: 在 C 中,Lambda 表达式是一种可以定义匿名函数的机制,可以在代码中快速创建一个内联的函数对象,而不需要显式地定义一个函数。Lambda 表…

Vue2中 vuex 的使用

1.安装 vuex 安装vuex与vue-router类似,vuex是一个独立存在的插件,如果脚手架初始化没有选 vuex,就需要额外安装。 yarn add vuex3 或者 npm i vuex3 233 Vue2 Vue-Router3 Vuex3 344 Vue3 Vue-Router4 Vuex4 2. 新建 store/index.j…

Android 用 platform.pk8 和 platform.x509.pem 生成 keystore 系统签名文件

一,背景介绍 最近需要开发一个拥有系统级权限的应用,就了解了下系统应用的签名方式,这里来简单介绍下。 在进行 Android 应用开发的时候,如果开发的是系统应用,那么就需要有系统签名才能正常运行,而系统应用…