天天看点

Oracle下定时删除归档日志脚本

一、报错信息

前几天网站突然访问不了,并且报了如下错误:

ora-27101: shared memory realm does not exist

ora-01034: oracle not available 11g

ORA-24324: service handle not initialized

原因:由于数据库归档日志满了,不能继续往数据库里写数据。

二、查看归档日志大小

su - oracle

sqlplus / as sysdba

<code>show parameter recover</code>

可查看到归档日志目录为:/u01/app/oracle/fast_recovery_area/******/archivelog

可以查看该目录的大小,对比数据库设置的日志空间,该目录大小不能大于数据库设置的空间。

三、扩大归档日志大小

<code>alter system </code><code>set</code> <code>db_recovery_file_dest_size</code><code>=</code><code>100G</code><code>;</code>

四、清理归档日志

扩大后还需设置定时计划清理归档日志,需要切换到oracle账号执行命令

rman target /

RMAN&gt; crosscheck archivelog all;

RMAN&gt; delete expired archivelog all;

RMAN&gt; delete archivelog until time 'sysdate-3'

上面三条命令的解释:

1、第一条命令可以把无效的expired的archivelog标出来。

2、第二条命令直接全部删除过期的归档日志。

3、第三条命令直接删除三天前所有的归档日志。

五、设置自动脚本

1、编写脚本

su - oracle        //切换到oracle用户下执行操作

cd /u01/app

vim arcclear.sh

<code>#!/usr/bin</code>

<code>rman target </code><code>/</code> <code>&lt;&lt;EOF</code>

<code>delete force noprompt archivelog </code><code>all</code> <code>completed before </code><code>'sysdate-3'</code><code>;</code>

<code>exit;</code>

<code>EOF</code>

chmod +x arcclear.sh

2、添加到计划任务

crontab -e

<code>30</code> <code>1</code> <code>*</code> <code>*</code> <code>*</code> <code>sh </code><code>/</code><code>u01</code><code>/</code><code>app</code><code>/</code><code>arcclear.sh &gt;&gt; </code><code>/</code><code>u01</code><code>/</code><code>app</code><code>/</code><code>arcclear.log</code>

service crond restart

      本文转自M四月天 51CTO博客,原文链接:http://blog.51cto.com/msiyuetian/2047792,如需转载请自行联系原作者