zoukankan      html  css  js  c++  java
  • linux/windows系统oracle数据库简单冷备同步

    linux/windows系统oracle数据库简单冷备同步

    我们有一个财务系统比较看重财务数据的安全性,同时我们拥有两套系统,一个生产环境(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_backupdbDB_%P_DATE%.DMP>> autoftp.txt
    echo get /home/oracle/_F%P_DATE%.LOG D:data_backupdb\_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_backupdbDB_20140729.DMP
    get /home/oracle/_F20140729.LOG D:data_backupdb\_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、导出传输导入,时间点需要错开,这个时间点不好控制

  • 相关阅读:
    洛谷P4979 矿洞:坍塌
    [SHOI2015]脑洞治疗仪
    洛谷P2135 方块消除
    洛谷P1436 棋盘分割
    洛谷P2796 Facer的程序
    浅谈位运算
    [SDOI2006]最短距离
    12耐心_预测未来
    11耐心_有效市场假说
    02C++条件变量
  • 原文地址:https://www.cnblogs.com/TimBing/p/4434880.html
Copyright © 2011-2022 走看看