先来了解一下一个基本的关于复制的概念。
什么是复制?
复制就是把数据的多个拷贝(复制品)分发到公司中的各个服务器中,通过复制为多台服务器提供相同的数据。这样用户就可以在不同服务器中访问同样的信息。
对于一个拥有大量用户的企业,复制可以分散用户访问服务器的负载。
什么是复制模型?
定义了服务器和数据副本之间的关系。
在复制模型里有三种角色,他们的任务各不相同。
1、 发布服务器:提供数据以便复制到其他服务器。
2、 分发服务器:作为发布和订阅之间的存储区。
3、 订阅服务器:接收复制数据。
一个数据库服务器实例可以充当发布服务器和分发服务器两个角色。
什么是复制类型?
复制类型有以下三种:
1、 快照复制:由发布服务器进行数据的更新和修改,周期性地复制到其他服务器。缺点是可能引起流量的增加。
2、 事务性复制:由发布服务器进行数据的更新和修改,但是复制是实时性的,即当有数据的改变的时候才触发复制的行为,优点是可以减少数据复制的流量。
3、 合并复制:发布服务器和订阅服务器都可以对数据进行更新和修改。复制是实时性的。当数据同步同时发生时,那么发布服务器的修改和订阅服务器的修改被合并在一起。
下面通过一个案例来详解复制的实现方式,本次以合并复制为例。
需求:
需求:现在随着玩家数量剧增,“moshou1”有些不堪重负,于是增加了一个SQL Server2005服务器,默认实例“moshou2”。现在希望将moshou1中的“player”数据库中的“玩家信息表”同步到“moshou2”中的player数据库中的玩家信息表,并要实现玩家无论登录哪个服务器更改个人信息都会同步到另一台服务器。如何实现?
需求分析:使用SQLserver 2005的数据复制功能,实现负载均衡数据库之间的数据同步和更新。本例采用“合并复制”数据的修改由发布服务器和订阅服务器共同来完成。并且数据的修改是实时的。合并复制自动创建初始快照。
备注:本例为了演示的方便,就在同一个服务器两个不同的实例中做这个实验,跟实际情况没有太多的出入。注意截图中的默认实例模拟moshou1,命名实例cool模拟moshou2
(一)、首先要启动SQL server agent的代理服务,moshou1、moshou2这两个实例的服务都必须启动
登录到SQL server的SSMS界面
(二)、定义“玩家信息表”的主键,如果不定义的话,那么在发布服务器的时候会出错
(三)、moshou1上新建发布
打开新建发布向导
选择自己作为分发服务器,即该服务器即是发布服务器也是分发服务器
将SQL server 代理配置为自动启动
设置快照文件夹的位置
选择要发布的数据库
选择发布类型为“合并发布”
订阅服务器类型保存默认
要发布的项目,选择玩家信息表
项目问题保持默认
快照代理,勾选“立即创建快照”
点击快照代理的安全设置按钮,设置快照代理的安全性
创建发布
给该发布起一个名字
下图是创建好的本地发布
(四)、moshou2上新建订阅
查找发布服务器
选择发布服务器
设置合并代理的位置
在订阅服务器上新建订阅数据库
点击右边的按钮,设置合并代理安全性
设置完成后,如图所示
同步计划设置为连续运行
立即初始化订阅
订阅类型保持默认
勾选在向导结束后,创建订阅
(五)、验证一下
打开cool实例下的player数据库,展开表,可以看到同步过来的玩家信息表
在默认实例的player数据库中对玩家信息表进行修改,可以同步到cool的player数据库的玩家信息表中
我们在默认实例的玩家信息表中添加一个列eee,然后可以看到马上就同步到了cool实例的表中

利用SQL server 的复制功能分散用户访问服务器的负载的更多相关文章

  1. 利用 SQL Server Audit 审核哪些用户添加删除更新SQL Agent Job

    有的时候我们需要下放权限给不用的用户,让他们自己能管理一部分SQL Agent Job,此时需要详细记录谁在什么时间修改了Job 甚至删除了Job, 我们可以使用SQL Server 的Audit帮助 ...

  2. 利用SQL Server Management Studio(SSMS)复制数据库

    利用SQL Server Management Studio(SSMS)复制数据库 标签(空格分隔): SQLServer 前言 今天由于客户购买的软件版本确认了,而之前进行开发的本地数据库版本较低, ...

  3. 利用SQL Server 2008 R2创建自动备份计划

    本文主要利用SQL Server 2008 R2自带的"维护计划"创建一个自动备份数据的任务. 首先,启动 Sql Management studio,确保"SQL Se ...

  4. [转]在 SQL Server 2008 中新建用户登录并指定该用户的数据库

    提要:我在 SQL Server 中新建用户登录时,出现了三种错误,错误代码分别是 18456.15128.4064 -----------------------------------  正 文 ...

  5. SQL Server 2008 查询所有用户表

    SQL Server 2008 查询所有用户表的T-SQL语句是: SELECT * FROM sysobjects WHERE [xtype] = 'U' 或者是: SELECT * FROM sy ...

  6. ASP.net(C#)利用SQL Server实现注册和登陆功能

    说说我现在吧,楼主现在从事的事IT行业,主攻DotNet技术:当然这次上博客园我也是有备而来,所有再次奉献鄙人拙作,以飨诸位,望诸位不吝赐教. 世界上大多数的工作都是熟练性的工种,编程也不例外,做久了 ...

  7. 【转载】SQL Server 2008 中新建用户登录并指定该用户的数据库

    提要:我在 SQL Server 中新建用户登录时,出现了三种错误,错误代码分别是 18456.15128.4064 -----------------------------------  正 文 ...

  8. Sql Server 修改表所属用户

    Sql Server 修改表所属用户 exec sp_changeobjectowner 'tablename','dbo' tablename--所要修改的表明 dbo--是表所属的用户,默认是db ...

  9. 四、利用SQL Server 2008 R2创建自动备份计划

    (转) 本文主要利用SQL Server 2008 R2自带的"维护计划"创建一个自动备份数据的任务. 首先,启动 Sql Management studio,确保"SQ ...

随机推荐

  1. 洛谷——P2656 采蘑菇

    P2656 采蘑菇 题目描述 小胖和ZYR要去ESQMS森林采蘑菇. ESQMS森林间有N个小树丛,M条小径,每条小径都是单向的,连接两个小树丛,上面都有一定数量的蘑菇.小胖和ZYR经过某条小径一次, ...

  2. EGS5在linux系统下安装过程

    转载自52MC论坛 作者:xinruibj 平台:Fedora 13 内核版本为:2.6.33, g77版本为:3.4.6: 用户名为xinrui,下面出现这个文件夹xinrui时,修改为你自己的用户 ...

  3. [BZOJ4568][SCOI2016]幸运数字(倍增LCA,点分治+线性基)

    4568: [Scoi2016]幸运数字 Time Limit: 60 Sec  Memory Limit: 256 MBSubmit: 2131  Solved: 865[Submit][Statu ...

  4. sourceinsight tab 空格 对齐 等宽字体

    参考:http://bbs.chinaunix.net/thread-587409-1-1.html 1. SMART TAB的用法. 解决自动缩进. 新开一个PROJECT后,点Options-&g ...

  5. Windows查看所有的端口及端口对应的程序

    步骤一.Windows查看所有的端口 点击电脑左下角的开始,然后选择运行选项,接着我们在弹出的窗口中,输入[cmd]命令,进行命令提示符.然后我们在窗口中输入[netstat -ano]按下回车,即会 ...

  6. 部署步骤“回收 IIS 应用程序池”中出现错误: 无法将通信对象 System.ServiceModel.InstanceContext 用于通信,因为它已经被中止。

    ??? 重启iis应用程序池和网站都不管用,重启vs就好了,一脸懵逼. 有没有更好的方法?

  7. 基于Rebound制造绚丽的动画效果-入门篇

    基于Rebound制造绚丽的动画效果-入门篇 Rebound是什么? Rebound是一个来自 Facebook 公司的 Java物理和动画库.Rebound spring 模型可用于创建动画,让你感 ...

  8. easyui numberbox precision属性

    //设置easyui numbox 最小值为0,保留2为小数 <input id="payPrice" type="text" name="pa ...

  9. pure-ftp 服务配置篇

    FTP 是File Transfer Protocol(文件传输协议)的英文简称,而中文简称为 "文传协议" 用于Internet上的控制文件的双向传输. FTP的主要作用,就是让 ...

  10. ubuntu live cd修复grub引导项

    1. 通过Ubuntu Live CD(安装盘,选择try Ubuntu)进入Ubuntu系统 打开终端,依次进行如下操作: 1. sudo fdisk -l 出现如下界面: 2. 然后会看到,有好多 ...