informix数据库备份方式有哪些

informix数据库备份方式有哪些,第1张

在大型的项目开发中,一个项目组通常会在小型的模拟环境中进行初步开发,待系统初步稳定后,再把开发环境移到新系统中,最后才把旧系统切换到新系统中去。但在模拟环境中,一般数据库服务器的配置都较低,而且不会有专门的数据备份措施,一旦掉电或误 *** 作,便容易出现数据丢失、数据库毁坏的情况,开发人员的一番心血便会白费。因此,需要一种简单而又有效的数据备份方法。

我们假设模拟环境的数据库服务器的 *** 作系统是Rerhat Linux 7,数据库服务器为Informix Online Dynamic Server 7.0,需要备份的数据库名称为dbtemp。在开发过程中,我们要求能对数据库表结构和其中的数据每天都能定时进行自动备份。因此我们需要使用crontab进行工作日程安排,crontab是 *** 作每个用户的守护程序和该执行的时间表。 crontab文件的格式:M H D m d cmd。

M: 分钟(0-59)。

H:小时(0-23)。

D:天(1-31)。

m: 月(1-12)。

d: 一星期内的天(0~6,0为星期天)。

cmd要运行的程序,程序被送入sh执行,这个shell只有USER,HOME,SHELL这三个环境变量。

root用户使用crontab -e命令编辑crontab文件,在本例中,文件内容如下:

#backup zhdata start

24 15 * * * su -l -c "dbschema -d dbtemp -ss /opt/informix/data/dbtemp.sql" informix

25 15 * * * su -l -c "dbaccess dbtemp /opt/informix/data/create_unload.sql" informix

27 15 * * * su -l -c "dbaccess dbtemp /opt/informix/data/unload.sql" informix

#backup zhdata end

文件中的第一条语句指定每天下午3点24分创建数据库dbtemp模式文件dbtemp.sql第二条语句指定每天下午3点25分使用dbaccess执行create_unload.sql 文件,create_unload.sql文件内容如下: UNLOAD TO /opt/Informix/data/unload.sql DELIMITER ''

SELECT "unload to /opt/informix/data/"||tabname||

".txt delimiter '$' select * from "||tabname

FROM systables WHERE tabid >99

这是一条嵌套式SQL语句,能够把数据库中的除系统表以外的所有表找出来。假设数据库中除了系统表外,还有用户表userinfo1,userinfo2,.…,userinfon,那么执行该语句后生成的unload.sql文件内容将为:

unload to /opt/Informix/data/userinfo1.txt delimiter '$' select * from userinfo1

unload to /opt/Informix/data/userinfo1.txt delimiter '$' select * from userinfo2

…… unload to /opt/Informix/data/userinfo1.txt delimiter '$' select * from userinfon

然后第3条语句指定每天下午3点27分使用dbaccess执行unload.sql文件,unload语句完成的是把表中的数据内容倒出成以指定分隔符分隔字段的文本文件在本例中,unload.sql文件实现导出数据库中出系统表以外的各表数据,生成以'$'符号分隔的文本文件,即把数据库除系统表以外的各表数据都导成以'$'符号分隔的文本文件,存放在/opt/Informix/data目录下面。这样,一个简单的数据备份便完成了

informix冷备可以用dbexport命令:

dbexport -d 数据库名称 -ss -o 数据导出目录 >xxx.log

恢复用dbimport命令:

dbimport 数据库名称 -i 数据导出目录 -c -l buffered -d default_dbspacename

导入完成后,进dbaccess,执行sql语句进行数据库级别统计更新

update statistics

ontape是informix数据库的简单易用的备份工具,但是它必须交互进行,对数据库的日常维护有一定的限制,比如,我们想在晚上进行备份,而不是在白天工作的时间。

下面我就简单示例,实现ontape的自动备份,这样我们就可以编写一个脚本,让 *** 作系统在系统不忙时自动调用。

假设:

1 ) $ONCONFIG 中参数 TAPEDEV已设置

TAPEDEV/Backup/archive0 # Tape device path

TAPEBLK16 # Tape block size (Kbytes)

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

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


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9984862.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存