实现 Informix 的 ontape 零级备份自动完成 - Unix爱好者家园
来源:百度文库 编辑:神马文学网 时间:2024/04/28 21:26:43
实现 Informix 的 ontape 零级备份自动完成 作者:大梦 出处:Unix爱好者家园unix-cd.com 更新时间: 2004年07月20日
[ 作者:大梦 转贴自:http://www.91talk.net 点击数:250 文章录入:sdccf ]
ontape是informix数据库的简单易用的备份工具,但是它必须交互进行,对数据库的日常维护有一定的限制,比如,我们想在晚上进行备份,而不是在白天工作的时间。
下面我就简单示例,实现ontape的自动备份,这样我们就可以编写一个脚本,让操作系统在系统不忙时自动调用。
假设:
1 ) $ONCONFIG 中参数 TAPEDEV已设置
TAPEDEV /Backup/archive0 # Tape device path
TAPEBLK 16 # Tape block size (Kbytes)
TAPESIZE 2000000 # Maximum amount of data to put on tape (Kbytes)
2) 备份数据的存放目录 /Backup ;
3) 备份过程产生的日志文件放在/opt/informix/archive目录下;
4) ftp.cmd 文件放在 /opt/informix/archive目录下;
#----------Autobackup.sh Begin----------
#
#autobackup.sh
#
#加载数据库环境
. /opt/informix/setenv
#设置备份日志文件
LOGFILE=/opt/informix/archive/archive.log
#取得当前系统日期
DATE=`date +%Y%m%d`
echo "---------- INformIX SYSTEM BACKUP(`date +%c`) ----------" >>$LOGFILE 2>&1
#生成一个备份的目标文件
touch /Backup/archive0 >>$LOGFILE 2>&1
chown informix:informix /Backup/archive0 >>$LOGFILE 2>&1
chmod 660 /Backup/archive0 >>$LOGFILE 2>&1
#开始零级备份
echo ` ` | ontape -s -L 0 >>$LOGFILE 2>&1
#将备份完成后的文件加上时间戳
mv -f /Backup/archive0 /Backup/archive.$DATE >>$LOGFILE 2>&1
#压缩备份
compress -f /Backup/archive.$DATE >>$LOGFILE 2>&1
#将备份文件传输到其它机器上
cp -f /Backup/archive.$DATE.Z /Backup/ftp >>$LOGFILE 2>&1
ftp -n < /opt/informix/archive/ftp.cmd
rm -f /Backup/ftp/* >>$LOGFILE 2>&1
#删除5天前的备份
COUNTS=`ls /Backup|sort|wc -l`
echo "There is $COUNTS files in /Backup..." >>$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 /Backup/ftp/* /RemoteBackup/archive0
Bye
#--------------------------ftp.cmd end ----------------------
在远端系统上同样可以使用crontab命令来处理传输过去的文件。
大家可以自行修改以上脚本,使之适用于自己的环境。
[ 作者:大梦 转贴自:http://www.91talk.net 点击数:250 文章录入:sdccf ]
ontape是informix数据库的简单易用的备份工具,但是它必须交互进行,对数据库的日常维护有一定的限制,比如,我们想在晚上进行备份,而不是在白天工作的时间。
下面我就简单示例,实现ontape的自动备份,这样我们就可以编写一个脚本,让操作系统在系统不忙时自动调用。
假设:
1 ) $ONCONFIG 中参数 TAPEDEV已设置
TAPEDEV /Backup/archive0 # Tape device path
TAPEBLK 16 # Tape block size (Kbytes)
TAPESIZE 2000000 # Maximum amount of data to put on tape (Kbytes)
2) 备份数据的存放目录 /Backup ;
3) 备份过程产生的日志文件放在/opt/informix/archive目录下;
4) ftp.cmd 文件放在 /opt/informix/archive目录下;
#----------Autobackup.sh Begin----------
#
#autobackup.sh
#
#加载数据库环境
. /opt/informix/setenv
#设置备份日志文件
LOGFILE=/opt/informix/archive/archive.log
#取得当前系统日期
DATE=`date +%Y%m%d`
echo "---------- INformIX SYSTEM BACKUP(`date +%c`) ----------" >>$LOGFILE 2>&1
#生成一个备份的目标文件
touch /Backup/archive0 >>$LOGFILE 2>&1
chown informix:informix /Backup/archive0 >>$LOGFILE 2>&1
chmod 660 /Backup/archive0 >>$LOGFILE 2>&1
#开始零级备份
echo ` ` | ontape -s -L 0 >>$LOGFILE 2>&1
#将备份完成后的文件加上时间戳
mv -f /Backup/archive0 /Backup/archive.$DATE >>$LOGFILE 2>&1
#压缩备份
compress -f /Backup/archive.$DATE >>$LOGFILE 2>&1
#将备份文件传输到其它机器上
cp -f /Backup/archive.$DATE.Z /Backup/ftp >>$LOGFILE 2>&1
ftp -n < /opt/informix/archive/ftp.cmd
rm -f /Backup/ftp/* >>$LOGFILE 2>&1
#删除5天前的备份
COUNTS=`ls /Backup|sort|wc -l`
echo "There is $COUNTS files in /Backup..." >>$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 /Backup/ftp/* /RemoteBackup/archive0
Bye
#--------------------------ftp.cmd end ----------------------
在远端系统上同样可以使用crontab命令来处理传输过去的文件。
大家可以自行修改以上脚本,使之适用于自己的环境。
实现 Informix 的 ontape 零级备份自动完成 - Unix爱好者家园
实现 Informix 的 ontape 零级备份自动完成 - Unix爱好者家园
实现 Informix 的 ontape 零级备份自动完成
自动实现 ontape 日志备份 - Unix爱好者家园
自动实现 ontape 日志备份 - Unix爱好者家园
Informix 数据库灵活备份的探讨 - Unix爱好者家园
Informix ON-Bar 备份解决方案 - Unix爱好者家园
自动实现 ontape 日志备份
自动实现 ontape 日志备份
Informix 几种数据去重的方法 - Unix爱好者家园
Informix 中求时间间隔的函数 - Unix爱好者家园
Informix 几种数据去重的方法 - Unix爱好者家园
几个常用的 Informix 命令 - Unix爱好者家园
Informix 数据库一致性检查 - Unix爱好者家园
SavWareHA 双机备份系统的解决 - Unix爱好者家园
每天备份 mysql 数据库的脚本 - Unix爱好者家园
Linux 环境下双机(多机)自动互备份方案 - Unix爱好者家园
MYSQL 备份策略 - Unix爱好者家园
让 MySQL 数据库自动恢复的具体操作 - Unix爱好者家园
自动FTP的小脚本 - Unix爱好者家园
Informix 培训教材整理之04 OnLine 的设置对性能的影响 - Unix爱好者家园
安装 Informix 的产品时需要设置哪些环境变量 - Unix爱好者家园
Informix 培训教材整理之02 CPU虚处理器的配置 - Unix爱好者家园
Informix 如何更加有效的创建主键和外键 - Unix爱好者家园