首页 > 上海日记 > 如何自动完成ontape零级备份
2010
04-14

如何自动完成ontape零级备份

  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

#----------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命令来处理传输过去的文件。

  大家可以自行修改以上脚本,使之适用于自己的环境。

最后编辑:
作者:北街
身高八尺,腰围也是八尺!
捐 赠如果您觉得这篇文章有用处,请支持作者!鼓励作者写出更好更多的文章!

如何自动完成ontape零级备份》有 17 条评论

  1. 飞猪 说:

    沙发呀沙发~~

  2. 飞猪 说:

    我的沙发竟然又被spam了

  3. 笨笨 说:

    吼吼,学习了,先收藏一下回头试试。

  4. 林西老九 说:

    技术贴,我来支持下

  5. 先看看 说:

    这个目前我还看不懂,哈哈

  6. MK 说:

    初学者,学习了。

  7. 园子 说:

    Ontape 我没有接触过呢。

  8. 龙崽 说:

    好久没到街哥来看了,你的RSS又不动了

  9. 帅哥 说:

    数据库也只学过mysql和access~~

  10. 一起走走 说:

    牛,又是我看不懂的。

  11. 羽中 说:

    现在完全看不懂了。。北街不要脱离群众啊~ 😯

  12. Mr.R 说:

    又是一技术性的文章,看不懂也支持

  13. itopdog 说:

    我没用过这个数据库

  14. 花脸猴 说:

    学习加支持

  15. 北街 说:

    @羽中 可记录我的技术文档是我开博的原因之一啊…… 🙄

  16. leesum 说:

    北街太NB了。 喜欢用插件直接备份

  17. 康秋华 说:

    大家有什么好看法,赶快说说

留下一个回复

你的email不会被公开。