Oracle定时清理归档日志

线上归档日志满了,系统直接崩了,为解决这个问题,创建每月定时清理归档日志。

创建文件名 delete_archivelog.rman

sql 复制代码
CONFIGURE ARCHIVELOG DELETION POLICY CLEAR;
RUN {
  ALLOCATE CHANNEL c1 TYPE DISK;
  DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE - 7';
  RELEASE CHANNEL c1;
}

创建文件名 archive_cleanup.bat

sql 复制代码
@echo off
:: 设置 Oracle 实例的环境变量
set ORACLE_SID=EMR
set ORACLE_HOME=D:\app\Administrator\product\11.2.0\dbhome_1
set PATH=%ORACLE_HOME%\bin;%PATH%

:: 设置日志文件路径(可选,用于记录日志)
set LOGFILE=%~dp0%archive_cleanup.log

echo [%date% %time%] 开始删除7天前的归档日志... >> "%LOGFILE%"

:: 调用 RMAN 并执行脚本文件
"%ORACLE_HOME%\bin\rman" target / @delete_archivelog.rman >> "%LOGFILE%" 2>&1

if %errorlevel% == 0 (
  echo [%date% %time%] 归档日志清理完成,未发现错误。 >> "%LOGFILE%"
) else (
  echo [%date% %time%] 警告:归档日志清理过程中发生错误,错误代码:%errorlevel% >> "%LOGFILE%"
)

echo 清理完成,请查看日志文件:%LOGFILE%
pause

查询归档日志,是否删除。

sql 复制代码
SELECT 
  SEQUENCE#, 
  FIRST_TIME, 
  NEXT_TIME, 
  BLOCKS * BLOCK_SIZE AS BYTES, 
  DELETED
FROM 
  V$ARCHIVED_LOG 
WHERE 
  FIRST_TIME < SYSDATE  -- 这里以7天前为例子
ORDER BY 
  SEQUENCE# DESC;

SELECT TRUNC(SUM(blocks * block_size) / 1024 / 1024) AS "Archived Log Size (MB)"
  FROM v$archived_log
 WHERE deleted = 'NO';

win任务为例 每月1号触发脚本

相关推荐
数据库小学妹30 分钟前
SQL Server数据库同步工具怎么选?6款方案对比+信创迁移避坑清单
数据库·经验分享·sqlserver·dba
不剪发的Tony老师42 分钟前
国产数据库之GaussDB:固若金汤
数据库·gaussdb
雨辰AI1 小时前
生产级实测:SpringBoot3 + 达梦数据库接口从 200ms 优化至 20ms 完整调优指南
java·数据库·spring boot·后端·政务
凡人叶枫2 小时前
Effective C++ 条款39:明智而审慎地使用 private 继承
java·数据库·c++·嵌入式开发
基德爆肝c语言2 小时前
MySQL表的操作
前端·数据库·mysql
TDengine (老段)2 小时前
TDengine 连接算子 — Inner/Outer/ASOF/Window Join 的实现与使用
大数据·数据库·物联网·哈希算法·时序数据库·tdengine·涛思数据
Keano Reurink2 小时前
搜索API与GSC数据对比:发现数据盲区
数据库·python·数据挖掘
shushangyun_2 小时前
汽车服务行业B2B平台+AI解决方案哪家专业:2026年最新测评
java·运维·网络·数据库·人工智能·汽车
大黄说说3 小时前
深入理解 Go 协程 Goroutine:并发编程的核心精髓
java·数据库·python
sulikey3 小时前
数据库系统概论4 - 更新与视图 期末速成课笔记
数据库·笔记·考试·期末速成·数据库系统概论