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.csdn.net/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.csdn.net/jiangjunshow

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很好,那么你需要完成一个Linux/Unix Shell编程的大作业,这是一个非常有趣的任务。下面是一些可能的项目想法: 1. 实现一个简单的 Shell:创建一个简单的 Shell,它可以执行基本的命令,例如 cd,ls,pwd,echo等。你可以使用 C 语言来实现它。 2. 批量文件重命名:编写一个脚本,可以批量更改文件名。例如,将所有文件名以“old_”开头的文件更改为以“new_”开头的文件。 3. 自动备份脚本:编写一个脚本,可以定期备份指定目录中的文件。你可以使用 tar 命令来完成压缩和解压缩任务。 4. 系统监控工具:编写一个 Shell 脚本,可以监控系统资源使用情况。例如,你可以通过查看系统日志文件,检查 CPU 和内存使用情况,以及查看网络流量。 5. 进程管理工具:编写一个 Shell 脚本,可以管理系统中的进程。例如,你可以通过脚本来启动、停止或重启进程,或者查看进程的状态等。 6. 网络脚本:编写一个脚本,可以执行网络操作。例如,你可以编写一个脚本来扫描网络,查找开放的端口,或者测试网络带宽等。 7. 日志分析工具:编写一个 Shell 脚本,可以分析系统日志文件。例如,你可以编写一个脚本来查找错误,或者收集统计信息。 8. 系统安全工具:编写一个 Shell 脚本,可以检查系统安全性。例如,你可以编写一个脚本来查找漏洞,或者测试系统的防火墙规则等。 以上是一些可能的项目想法,你可以根据自己的兴趣和能力来选择。无论你选择哪个项目,都需要仔细研究相关技术,并且在实现过程中保持耐心和毅力。祝你好运!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值