zoukankan      html  css  js  c++  java
  • 多个数据库间同步技术

    1、发布订阅的方法   http://bbs.csdn.net/topics/230030667?page=1   时间差1分钟左右
    2、数据库镜像的方法
    3、定时DTS 或者 SSIS 增量传输的方法

    4 、备份还原技术 http://bbs.csdn.net/topics/230030667?page=3

    我之前也有过搂住一样的需求,当时用了发布/订阅,愣是没搞定。
    后来另辟蹊径,找到了非常简单实效的方法。
    A服务器为主服务器,客户端更新都更新在A服务器上;
    B服务器为次服务器,B定时与A保持一致,结果B机时A的一个拷贝/备份,只是时间上有一个差。
    
    实现方法:A定时备份;B定时以A的备份进行还原
    
    具体方法如下:(MS-SQL中)
    
    打开A服务器企业管理器,找到管理-SQL Server代理-作业,创建一个新作业,名字可以起备份,作业中创建一个步骤:
    SQL code
    
    ?
    1
    BACKUP DATABASE [TEST] TO  DISK = 'F:SQL_SERVERTESTDB.BACKUPTEST_BACKUP.BAK'  WITH  INIT
    
    以上TEST是数据库名称
    然后在该作业里创建一个调度:具体周期时间的根据实际需求确定,比如每隔15分钟...
    保存并运行作业。把F:SQL_SERVER设为共享。
    
    打开B服务器企业管理器找到管理-SQL Server代理-作业,创建一个新作业,名字可以起备份,作业中创建一个步骤:
    SQL code
    ?
    1
    exec master..xp_cmdshell  'net use  \SERVER-A_IPSQL_SERVERTESTDB.BACKUP  password  /user:username'
    
    以上目的就是同A取得联系,为后续还原做准备
    然后再添加第二个步骤:
    SQL code
    ?
    1
    restore database [TEST] from disk='\SERVER-A_IPSQL_SERVERTESTDB.BACKUPTEST_BACKUP.BAK'
    
    注意两个服务器都要有相同的数据库存放路径,我这里是备份放在F:SQL_SERVERTESTDB.BACKUP,数据库放在F:SQL_SERVERTEST
    调度和A一样就行了。
    保存并运行作业。
    
    看看是不是实现了B同步于A?
    我就是用这种方法建立了3个服务器,自从这样做以来就没出现过因服务器down而造成的客户端不可用。
    
    如果实际需求和我得有点出入的话,我相信只要稍微调整两个服务器中作业的步骤就可以了。

    5、少量数据直接用触发器。

    6、web 服务 技术。

    7、日志传送

  • 相关阅读:
    c++命名空间重命名
    ssh保持长连接的配置方法
    macos平台上使用 sed
    c++的使用
    NAT介绍以及穿透各种类型nat的技术实现包括对称型nat
    组态图绘制软件的实现
    关于五防系统
    Linux的应用
    java常用包及其类概述
    springboot整合redis
  • 原文地址:https://www.cnblogs.com/ymecho/p/3579210.html
Copyright © 2011-2022 走看看