您的位置:首页 > 运维架构 > Shell

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

2013-04-15 10:53 471 查看
      对于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/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体系结构)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: