热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

SQLServer双服务器架设并数据自动同步教程

自编程序由单机版改为网络版后,使用范围迅速扩大,如何保障数据库万无一失成为一个重要解决的问题于是想到架设双服务器并数据自动同步,详细步骤如下

交待:使用的软硬件环境为Win XP SP2、SQL Server 2000 SP2个人版、普通双核台式机、1000M局域网,A机为已使用的服务器,上面已有数据库和海量数据,B机为此次新架服务器,两机登陆方式均为sql server身份验证模式,其它设置均为默认设置,无特别。A机上另有FTP服务器,用于程序自动更新。

1、在A机上执行数据库备份。

2、用A机上备份下来的数据库备份文件在B机上执行数据库恢复,保证A、B机均有完全相同的数据库。(弄完后发现这上步好像不用做,反正发现时我已经弄完了,也就没有推倒重来验证)。

3、在A、B机上建两个用户名、密码完全一样的用户(控制面板>计算机管理>用户>新建),并把它们加入到administartor组。(如果两台机原来就都用administartor用户登录,那么,把两台机的登录密码改成一样就行,不用另行建新用户)

4、两台机上均进行此操作:启动>程序>管理工具>服务>右键单击SQLSERVERAGENT>属性>登陆>设置为上一步弄的那个用户名和密码。

5、在A机上进入企业管理器,把B机服务器加进服务器组,B机上进入企业管理器,把A机服务器加入服务器组。为省得麻烦,我都用了Sa用于两机互相登录SQL Server。

6、A机进入企业管理器,右键单击要发布的数据库>新建>发布,一步步下去就行,无需要特别设置的地方,走完了后,数据库下面会多出一个“发布”条目,右键点击>属性,可变更发布属性各项设置。要注意几点:1是代理登录用户要用第3步中设置的用户,不能用“系统用户”,2是数据库访问用户要指定(我是用的Sa,省得麻烦),3是要把A机上存放快照的目录设为共享,不共享的话,B机是得不到快照的(我是没用SQL默认的目录,人工指定为FTP服务器的根目录,原因下详),4是注意发布代理的工作频率不要设置过快,必竟生成快照文件,然后通知订阅者,订阅者再来拿数据还是需要一些时间的,至于需要多快,看你数据变动频率以及两机同步的快慢来设定吧,对于我来说,一天的数据丢失完全可以承受,于是乎,我设置了每5小时发布一次。

7、B机进入企业管理器,右键单击要同步的数据库>新建>订阅,一步步下去就行,无需要特别设置的地方。

8、完成后,按理说应该就能同步了,但我发现没有效果,查看A机上的发布管理器日志后发现,原来是B机不能取得A机上的快照文件,一看,原来SQL Server订阅用的端口居然是445,与病毒扫荡波一样,所以被防火墙拦掉了,囧,而我又不具有修改防火墙拦截规则的权限。于是在发布服务器属性中把快照存放目录指定为FTP所在根目录,打开允许FTP,填入FTP服务器访问用户名和密码,重新运行发布代理。B机上删除原订阅,重新建立订阅,设置采用FTP方式,于是问题解决。

PS:网上参考资料均说同步的表需要有主键,但我的系统中有一些表是没有主键的(因为表中每列均存在若干相同值,所以无法加主键,也懒得再去改表结构专门添加个序列,因为加个序列,偶就得改程序了,怕怕——!),最后同样成功了,SO,表有没有主键,肯定是不影响同步的,至少不影响快照同步模式。


推荐阅读
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了在SQL中查询分组后每组行数的统计方法。通过使用count()函数和GROUP BY子句可以统计每组的行数,但是如何统计所有组的行数呢?本文提供了一种实现方法,并给出了相应的SQL查询语句。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了如何找到并终止在8080端口上运行的进程的方法,通过使用终端命令lsof -i :8080可以获取在该端口上运行的所有进程的输出,并使用kill命令终止指定进程的运行。 ... [详细]
author-avatar
leooooo
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有