Linux/Unix shell 脚本清除归档日志文件

               

      对于DEV以及UAT环境,有些时候,数据库需要处于归档模式,但并不需要备份数据库。因此,archive归档日志不停的增长导致磁盘空间被大量耗用。对于这种情形,可以使用一个shell脚本来定时自动清除这些归档日志。本文给出了清除归档日志的脚本。

 

1、清除归档日志shell脚本  

robin@SZDB:~/dba_scripts/custom/bin> more remove_arch_dump.sh#!/bin/bash# ------------------------------------------------------------+#   FileName: remove_arch_dump.sh                             |#   Desc:                                                     | #        Remove old archived log and data pump file           |#   Usage:                                                    |#        ./remove_arch_dump.sh                                |#                                                             |#   Authror : Robinson                                        |#   Blog    : http://blog.youkuaiyun.com/robinson_0612              |# ------------------------------------------------------------+filename=/etc/oratabcat $filename | while read LINEdo    case $LINE in        \#*)                ;;        #comment-line in oratab        *)        ORACLE_SID=`echo $LINE | awk -F: '{print $1}' -`        echo $ORACLE_SID          # ---------------------------------        # define archived log directory             # ---------------------------------        dir=/u02/database/$ORACLE_SID/archive/        echo $dir        filelist=`ls -t $dir`        echo $filelist                # ----------------------------------------------------------        # start to remove archived log and keep last 2 archived log        # ----------------------------------------------------------        count=0        for filename in $filelist        do                echo $filename                count=$(($count+1))                if [ $count -gt 2 ]; then                        echo $count                        rm -vrf $dir$filename                fi        done        ls -tr $dir                # --------------------------------        # define data pump dump directory        # --------------------------------        dir=/u02/database/$ORACLE_SID/BNR/dump/        echo $dir        filelist=`ls -t $dir`        echo $filelist                # ---------------------------------------------------------        # start to remove data pump file and keep last 5 dump file         # ---------------------------------------------------------        count=0        for filename in $filelist        do                echo $filename                count=$(($count+1))                if [ $count -gt 5 ]; then                        echo $count                        rm -vrf $dir$filename                fi        done        ls -tr $dir     ;;    esacdoneexit


2、脚本说明
    a、该脚本通过一个外部循环来读取oratab中定义的数据库的SID来寻找对应数据库的归档日志路径以及datapump dump路径。
    b、使用了一个for循环来清除归档日志,且保留最后的2个归档日志文件。
    c、接下来的另一个for循环则用来清除当前SID下对应的dump(Oracle datapump)目录下导出的dump文件。
    d、同清除归档日志一样,设定了保留dump目录最近的5个文件。保留多少个最近的文件(dump的5,或者归档日志2)可以修改。
    e、如果不需要清除dump路径,可以将dump部分注释掉。
    f、根据需要将其部署到crontab。

 

更多参考

PL/SQL --> 游标

PL/SQL --> 隐式游标(SQL%FOUND)

批量SQL之 FORALL 语句

批量SQL之 BULK COLLECT 子句

PL/SQL 集合的初始化与赋值

PL/SQL 联合数组与嵌套表
PL/SQL 变长数组
PL/SQL --> PL/SQL记录

SQL tuning 步骤

高效SQL语句必杀技

父游标、子游标及共享游标

绑定变量及其优缺点

dbms_xplan之display_cursor函数的使用

dbms_xplan之display函数的使用

执行计划中各字段各模块描述

使用 EXPLAIN PLAN 获取SQL语句执行计划

Oracle ROWID

NULL 值与索引(一)

NULL 值与索引(二)

启用 AUTOTRACE 功能

函数使得索引列失效

Oracle 绑定变量窥探

Oracle 自适应共享游标

Oracle 表空间与数据文件
Oracle 密码文件
Oracle 参数文件
Oracle 联机重做日志文件(ONLINE LOG FILE)
Oracle 控制文件(CONTROLFILE)
Oracle 归档日志
Oracle 回滚(ROLLBACK)和撤销(UNDO)
Oracle 数据库实例启动关闭过程
Oracle 10g SGA 的自动化管理
Oracle 实例和Oracle数据库(Oracle体系结构)

           

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.youkuaiyun.com/jiangjunshow

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值