实现Oracle异地数据自动备份的方案

数据库 Oracle
Oracle数据库中数据库备份是十分重要的一个操作环节,Oracle中数据库备份保证了数据库的永久存在不易丢失,下文中将为大家讲解如何实现Oracle异地数据自动备份的方案。

Oracle异地数据自动备份现在在很多地方都得到了广泛的应用,就比如在大型商业应用中,数据的异地容灾备份十分重要,也必不可少。笔者根据自己的实践经验,设计了一套简洁地实现异地数据自动备份的方案,可供数据库管理人员参考。文中所有的程序都经过测试,运行良好。这里模拟的异地运行环境为一主一备两套SunSolaris系统,所采用的备份方法为Oracle数据库提供的标准备份:export。

相关命令

文中主要用到三个命令,这里先单独介绍一下:

export:将数据库中数据备份成一个二进制系统文件,它有三种模式:用户模式、表模式、整个数据库模式。还可分为三种备份类型:完全型、积累型、增量型。本文以整个数据库模式下的完全型为例说明。export使用格式为:expuseridfile。

其中:userid的用法为username/userpassword,即Oracle中的用户名/口令。userid必须为exp的第一个参数,file指备份文件所放位置及名称。

ftp:一般情况下可通过交互方式实现两台主机间的数据传输,即需要手工输入目标主机的IP地址、用户名、口令等。但是当用户使用ftp命令时,系统将会先在该用户的注册目录中寻找.netrc文件,并首先执行该文件。这样,我们可以通过编写一个.netrc的文件来达到自动备份的目的。要注意该文件必须命名为.netrc,且必须存放在启动ftp命令主机上的用户注册目录里。ftp常用选项:

-i:进行多文件传送时关闭交互提示;

-n:在连接之后不进行自动登录。

本文使用“-i”选项,以关闭交互提示。

crontab:cron是一个永久进程,它由/etc/rc.local启动执行。cron检查/var/spool/cron/crontabs/目录中的文件,找到所要执行的任务和执行任务的时间,并自动完成。该目录中文件由crontab命令建立。用户所建立的crontab文件存于/var/spool/cron/crontabs中,其文件名与用户名一致,本文使用crontab的用户为Oracle,所建立的文件名也为Oracle。

cron使用者的权限记载在下列两个文件中:/usr/var/adm/cron/cron.deny和/usr/var/adm/cron/cron.allow。前面的文件中所列的用户不允许使用crontab命令;后一文件中所列的用户允许使用crontab命令。crontab命令的常用格式为:

crontab-l:显示用户的crontab文件的内容;

crontab-r:从crontabs目录中删除用户的crontab文件;

crontab-e:编辑用户的crontab文件。

crontab文件每行中有6个字段,前5个为时间设定段,第6个为所要执行的命令。时间段分别为:minutes、hours、dayofmonth、month、dayofweek,字段之间用空格或Tab分开。字段如果为“*”,表示该字段在所有可能的取值范围内取值;如果一个字段是由连字符隔开的两个数字,表明命令可以在两个数字之间的范围内执行。

备份数据库

设定数据库的拥有者为Oracle,用户名为mistest,其口令为test,新建备份目录为/export/home/oracle/backup。建立一个命名为testbackup的备份文件,文件内容如下:

ORACLE-HOME=/export/home/oracle/815;exportORACLE-HOME

ORACLE-SID=ora815;exportORACLE-SID

rm/export/home/oracle/backup/*

rq=丶date+“%m%d”丶

/export/home/oracle/815/bin/expmistest/testfile=/export/home/oracle

/backup/exp$rq.dmplog=/exoport/home/oracle/backup/exp$rq.log

说明:前两句对Oracle数据库初始化,第3条语句清空备份目录,第4条语句建立一个取当前日期的变量,以便在最后一条语句的备份文件名里含有当前日期信息。testbackup编写完成后,用“chmod+xtestbackup”命令授予它可执行权限。

异地传输

在备份主机里建立一个备份目录:/database/oradata/newbackup,在本地主机Oracle用户的注册目录/export/home/oracle里建立一个.netrc文件。设定好备份主机的IP地址,备份主机上的用户为oraclebk,口令为testbk2。.netrc文件内容为:

machinex.x.x..x

loginoraclebk

passwordtestbk2

macdefinit

bin

lcd/export/home/oracle/backup

cd/database/oradata/backup

mput*

bye 

说明:前3条语句完成在备份主机上的登录,第4条语句定义一个名为init的宏,第5条语句表示以二进制传输,第6条语句表示进入本地工作目录,第7条语句表示进入备份主机目录,第8条语句完成将本地主机/export/home/oracle/backup目录下的所有文件传输至备份主机/database/oradata/backup目录下,最后一条语句退出ftp会话进程。.netrc文件编写完成后,用命令“chmod600.netrc”使该文件只能被该用户所访问。

自动执行

我们以oracle用户登录本地主机,用“crontab-e”编写crontab文件用以启动自动备份进程。oracle文件内容如下:

1023***/export/home/oracle/testbackup

3023***ftp-ix.x.x.x

说明:第1条语句指定每天自动在23点10分执行对数据库的备份,第2条语句指定每天自动在23点半启动ftp,将备份文件传输到备份主机(备份主机为符合语句中指定IP地址的主机)。

Oracle文件只能在Oracle用户名下用“crontab-e”命令来编辑。编辑完成后,可以在用“crontab-l”命令来查看crontab文件内容,同时在/var/spool/cron/crontabs目录下查看是否增加了一个Oracle文件。

至此,本地主机可以每天定时备份数据库,并定时把备份数据传到备份主机。这样,较好地实现了Oracle数据异地自动备份,本地主机如果有什么故障,数据有了可靠备份,同时,在一定程度上也减轻了系统管理人员烦琐、重复的备份工作。

 

责任编辑:迎迎 来源: 电脑初学网
相关推荐

2010-04-09 15:35:28

Oracle数据库

2018-03-27 08:44:37

服务器备份异地

2011-08-02 16:03:47

Oracle数据库冷备份冷备份异地恢复

2009-07-03 09:44:30

Oracle Data

2010-05-04 14:57:27

Oracle数据库

2009-08-12 18:16:37

Oracle数据库自动UNIX

2010-04-19 12:54:01

Oracle数据库

2010-04-09 15:22:57

Oracle数据库

2013-09-09 17:17:18

MYSQL自动备份

2018-12-12 19:10:01

Oracle数据库自动备份

2010-04-14 09:41:10

Oracle数据备份

2010-04-12 11:12:53

Oracle数据处理

2018-10-18 09:01:14

异地备份堆栈云备份

2011-05-16 11:29:00

MySQL自动备份

2010-10-26 13:33:08

Oracle自动备份

2011-05-12 13:42:01

2011-03-28 16:12:55

mysql自动远程备份

2010-04-26 11:58:42

2010-04-19 13:15:00

Oracle数据库

2009-03-26 11:42:36

定时备份Oracle
点赞
收藏

51CTO技术栈公众号