自动实现 ontape 日志备份

来源:百度文库 编辑:神马文学网 时间:2024/03/29 17:45:07

自动实现ontape日志备份

作者:darrenshen.cublog.cn  出处:darrenshen.cublog.cn  更新时间: 2007年03月11日 
 
自动实现ontape日志备份,这样我们就可以编写一个脚本,让操作系统在系统不忙时自动调用。

  1 )   $ONCONFIG 中参数 TAPEDEV已设置
        TAPEDEV    /opt/informix/backup/logback   # Tape device path
        TAPEBLK    16               # Tape block size (Kbytes)
        TAPESIZE    2000000  # Maximum amount of data to put on tape (Kbytes)
   2)  备份数据的存放目录  /opt/informix/backup/logback;
   3)  备份过程产生的日志文件放在/opt/informix/backup/autobackup.log目录下; 
   4) ftp.cmd 文件放在 /opt/informix/backup目录下;

#----------Autobackup.sh  Begin----------

#
#autobackup.sh
#

#加载数据库环境
. /opt/informix/setenv

#设置备份日志文件
LOGFILE=/opt/informix/backup/autobackup.log
#取得当前系统日期
DATE=`date +%Y%m%d`

echo "---------- INFORMIX SYSTEM BACKUP(`date +%c`) ----------" >>$LOGFILE 2>&1

#生成一个备份的目标文件
touch /opt/informix/backup/logback >>$LOGFILE 2>&1
chown informix:informix /opt/informix/backup/logback >>$LOGFILE 2>&1
chmod 660 /opt/informix/backup/logback  >>$LOGFILE 2>&1

#开始零级备份
echo ` ` | ontape -c >>$LOGFILE 2>&1

#将备份完成后的文件加上时间戳
mv -f //opt/informix/backup/logback  /opt/informix/backup/logback .$DATE >>$LOGFILE 2>&1

#压缩备份
compress -f /opt/informix/backup/logback .$DATE >>$LOGFILE 2>&1

#将备份文件传输到其它机器上
cp -f /opt/informix/backup/logback .$DATE.Z /Backup/ftp >>$LOGFILE 2>&1
ftp -n < /opt/informix/backup/logback/ftp.cmd
rm -f /opt/informix/backup/logback ftp/* >>$LOGFILE 2>&1


#删除5天前的备份
COUNTS=`ls /Backup|sort|wc -l`
echo "There is $COUNTS files in //opt/informix/backup/logback ..." >>$LOGFILE 2>&1
if [ $COUNTS -ge 7 ]  then
echo "An oldest file will be delete ,please wait..." >>$LOGFILE 2>&1
OLDFILE=`ls /Backup|sort|head -1` >>$LOGFILE 2>&1
cd /Backup
rm -f $OLDFILE >>$LOGFILE 2>&1
echo "Delete file completed ,$OLDFILE was deleted." >>$LOGFILE 2>&1
else
echo "There is no more then 6 file ,nothing to do..." >>$LOGFILE 2>&1
fi

#释放数据库无用内存
onmode -F

#------------autobackup.sh  End-----------

以上脚本可以使用操作系统的crontab命令,指定时间,自动运行,不用人工干预。
另外附上使用ftp命令的自动传输教本。

#------------ftp.cmd begin---------------------------

open 9.185.43.62

User  backup backup123

cd /RemoteBackup

bin

bin

bin

bin

put /opt/informix/backup/logback /ftp/* /RemoteBackup/backup

Bye
#--------------------------ftp.cmd end ----------------------