oracle数据库求余,Linux余Windows系统Oracle数据库简单冷备同步

5268f80b9b1e01f982625ef6fac83ca1.png

我们有一个财务系统比较看重财务数据的安全性,同时我们拥有两套系统,一个生产环境(Linux),一个应急备份环境(Windows)。备份环

我们有一个财务系统比较看重财务数据的安全性,同时我们拥有两套系统,一个生产环境(Linux),一个应急备份环境(Windows)。备份环境对生产环境实行实时备份同步,备份方式也有两种:热备冷备。Oracle热备一般用Oracle DG服务即可,但Oracle DG服务是要另行收费的,这对于客户来说也是一笔不小的开支。于是我们采用Oracle冷备的方式,基本流程是:数据库定时通过expdp方式导出,然后通过ftp传到应急备份环境,应急备份环境然后执行impdp导入,这样既可完成冷备。

一、Linux Oracle数据库端:

1、添加crontab定时时间

2、编写shell脚本,实现数据库导出

#!/bin/bash

yy=`date +%Y`

mm=`date +%m`

dd=`date +%d`

time=$yy$mm$dd

ORACLE_BASE=/oracle/app/oracle;

export ORACLE_BASE;

ORACLE_HOME=$ORACLE_BASE/product/11.2;

export ORACLE_HOME;

PATH=$ORACLE_HOME/bin:$PATH;

export PATH;

f_dmp="FDB_${time}.DMP"

f_log="_F${time}.LOG"

echo "expdp ods/ods@dw1 directory=backup_db dumpfile=$f_dmp logfile=$1$f_log SCHEMAS=meta,ods,mid,app reuse_dumpfiles=y;"

echo "exporting data ..."

expdp ods/ods@dw1 directory=backup_db dumpfile=$f_dmp logfile=$1$f_log SCHEMAS=meta,ods,mid,app reuse_dumpfiles=y;

echo "expdp user data success!"

二、应急备份环境使用ftp传输dmp文件,当然生产环境linux必须得支持ftp

@echo off

SET P_YEAR=%date:~0,4%

SET P_MONTH=%date:~5,2%

SET P_DAY=%date:~8,2%

SET P_DATE=%P_YEAR%%P_MONTH%%P_DAY%

echo oracle> autoftp.txt

echo oracle>> autoftp.txt

echo prompt>>autoftp.txt

echo bin>> autoftp.txt

echo get /home/oracle/FDB_%P_DATE%.DMP D:\data_backup\db\DB_%P_DATE%.DMP>> autoftp.txt

echo get /home/oracle/_F%P_DATE%.LOG D:\data_backup\db\_F%P_DATE%.log>> autoftp.txt

echo mdel /home/oracle/*.DMP>>autoftp.txt

echo mdel /home/oracle/_F*.LOG>>autoftp.txt

echo bye>> autoftp.txt

ftp -s:"autoftp.txt" 127.0.0.1(IP地址)

exit

ftp一般使用ftp -s ftp.txt文本的方式执行ftp操作,以上操作先根据当前时段生成对应的ftp.txt文本

oracle

oracle

prompt

bin

get /home/oracle/FDB_20140729.DMP D:\data_backup\db\DB_20140729.DMP

get /home/oracle/_F20140729.LOG D:\data_backup\db\_F20140729.log

mdel /home/oracle/*.DMP

mdel /home/oracle/_F*.LOG

bye

get /home/oracle/*.dmp C:\20141119.DMP

三、dmp文件既然传输到Windows系统中了,就可以使用impdp来进行导入操作了,导入操作当然也要用Windows的定时服务来启动

@echo off

REM

REM

SET P_YEAR=%date:~0,4%

SET P_MONTH=%date:~5,2%

SET P_DAY=%date:~8,2%

SET P_DATE=%P_YEAR%%P_MONTH%%P_DAY%

impdp ods/ods@dw directory=backup_db dumpfile=DB_%P_DATE%.dmp SCHEMAS=meta,ods,mid,app table_exists_action=REPLACE

pause

这种方式有几个明显的缺点:

1、exp导出,导入对数据库性能会有一定的影响

2、数据库不能实时同步,对于数据同步要求高和数据安全性高的自然不适用

3、导出传输导入,,时间点需要错开,这个时间点不好控制

Oracle数据库的冷备及完全恢复

本文永久更新链接地址:

1428d0e076c3959ab11d28a39bc84fab.png

5268f80b9b1e01f982625ef6fac83ca1.png

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值