暂无图片
暂无图片
6
暂无图片
暂无图片
暂无图片

GBase数据库自动备份脚本

张维群 2020-10-19
3408

ontape是GBase 8s数据库的简单易用的备份工具,但是它必须交互进行,对数据库的日常维护有一定的限制,比如,我们想在晚上进行备份,而不是在白天工作的时间。
  下面我就简单示例,实现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/gbasedbt/archive目录下;
  4) ftp.cmd 文件放在 /opt/gbasedbt/archive目录下;
  #----------Autobackup.sh Begin----------
  #
  #autobackup.sh
  #

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

#设置备份日志文件
  LOGFILE=/opt/gbasedbt/archive/archive.log

#取得当前系统日期
  DATE=date +%Y%m%d

echo “---------- gbasedbt SYSTEM BACKUP(date +%c) ----------” >>$LOGFILE 2>&1

#生成一个备份的目标文件
  touch /Backup/archive0 >>$LOGFILE 2>&1
  chown gbasedbt:gbasedbt /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/gbasedbt/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命令来处理传输过去的文件。
  大家可以自行修改以上脚本,使之适用于自己的环境。

最后修改时间:2020-10-20 09:42:03
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论