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体系结构)
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体系结构)
相关文章推荐
- Linux/Unix shell 脚本清除归档日志文件
- 如何清除掉归档日志文件?
- linux清除tomcat日志文件Shell脚本
- 使用RMAN和控制文件备份删除归档日志的SHELL脚本--RED HAT 5 LINUX 64
- 如何清除Oracle控制文件中的无用记录,例如v$archived_log中的deleted归档日志记录
- Linux删除日志文件和清除日志文件脚本
- 使用RMAN和控制文件备份删除归档日志的SHELL脚本--RED HAT 5 LINUX 64
- 定期清除Kloxo日志文件脚本
- SQL2008清除日志文件脚本
- 如何清除Oracle控制文件中的无用记录,例如v$archived_log中的deleted归档日志记录
- 改良后的 清除日志文件脚本
- 使用RMAN和控制文件备份删除归档日志的SHELL脚本--RED HAT 5 LINUX 64
- shell中通配符无法使用和/使用dev/null文件自动清除日志脚本
- 清除系统日志的shell脚本
- PHP脚本中临时指定错误日志文件
- rman实验之归档模式无备份,正常关机丢失当前联机重做日志文件的恢复
- linux 日志清除脚本
- 清除windows 8 中的临时文件脚本
- [2月14日的脚本] 清除 Windows 8中临时文件 (PowerShell)