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

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

1、清除归档日志shell脚本 

  1. robin@SZDB:~/dba_scripts/custom/bin> more remove_arch_dump.sh 
  2. #!/bin/bash 
  3. # ------------------------------------------------------------+ 
  4. #   FileName: remove_arch_dump.sh                             | 
  5. #   Desc:                                                     |  
  6. #        Remove old archived log and data pump file           | 
  7. #   Usage:                                                    | 
  8. #        ./remove_arch_dump.sh                                | 
  9. #                                                             | 
  10. #   Authror : Robinson                                        | 
  11. #   Blog    : http://blog.csdn.net/robinson_0612              | 
  12. # ------------------------------------------------------------+ 
  13.  
  14. filename=/etc/oratab 
  15.  
  16. cat $filename | while read LINE 
  17. do 
  18.     case $LINE in 
  19.         \#*)                ;;        #comment-line in oratab 
  20.         *) 
  21.         ORACLE_SID=`echo $LINE | awk -F: '{print $1}' -` 
  22.         echo $ORACLE_SID 
  23.    
  24.         # --------------------------------- 
  25.         # define archived log directory      
  26.         # --------------------------------- 
  27.         dir=/u02/database/$ORACLE_SID/archive/ 
  28.         echo $dir 
  29.  
  30.         filelist=`ls -t $dir` 
  31.         echo $filelist 
  32.          
  33.         # ---------------------------------------------------------- 
  34.         # start to remove archived log and keep last 2 archived log 
  35.         # ---------------------------------------------------------- 
  36.         count=0 
  37.         for filename in $filelist 
  38.         do 
  39.                 echo $filename 
  40.                 count=$(($count+1)) 
  41.                 if [ $count -gt 2 ]; then 
  42.                         echo $count 
  43.                         rm -vrf $dir$filename 
  44.                 fi 
  45.         done 
  46.         ls -tr $dir 
  47.          
  48.         # -------------------------------- 
  49.         # define data pump dump directory 
  50.         # -------------------------------- 
  51.         dir=/u02/database/$ORACLE_SID/BNR/dump/ 
  52.         echo $dir 
  53.  
  54.         filelist=`ls -t $dir` 
  55.         echo $filelist 
  56.          
  57.         # --------------------------------------------------------- 
  58.         # start to remove data pump file and keep last 5 dump file  
  59.         # --------------------------------------------------------- 
  60.         count=0 
  61.         for filename in $filelist 
  62.         do 
  63.                 echo $filename 
  64.                 count=$(($count+1)) 
  65.                 if [ $count -gt 5 ]; then 
  66.                         echo $count 
  67.                         rm -vrf $dir$filename 
  68.                 fi 
  69.         done 
  70.         ls -tr $dir 
  71.  
  72.      ;; 
  73.     esac 
  74. done 
  75. exit 
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.csdn.net/robinson_0612              |
# ------------------------------------------------------------+

filename=/etc/oratab

cat $filename | while read LINE
do
    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

     ;;
    esac
done
exit


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体系结构)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值