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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | #----------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命令的自动传输教本。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | #------------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命令来处理传输过去的文件。
大家可以自行修改以上脚本,使之适用于自己的环境。


沙发呀沙发~~
我的沙发竟然又被spam了
吼吼,学习了,先收藏一下回头试试。
技术贴,我来支持下
这个目前我还看不懂,哈哈
初学者,学习了。
Ontape 我没有接触过呢。
好久没到街哥来看了,你的RSS又不动了
数据库也只学过mysql和access~~
牛,又是我看不懂的。
现在完全看不懂了。。北街不要脱离群众啊~
又是一技术性的文章,看不懂也支持
我没用过这个数据库
学习加支持
@羽中 可记录我的技术文档是我开博的原因之一啊……
北街太NB了。 喜欢用插件直接备份