今天刚在学数据库的读写分离(主从分离),原本电脑上安装的SQL Server2012是Express版本的,在数据库-->复制下,只有本地订阅,没有本地发布,所以只能把这个版本的数据库删了,装上了Enterprise版本。
等待数据库装完之后,进入数据库就显示如下页面了
data:image/s3,"s3://crabby-images/bd668/bd668339e254dec6b84663848ee0b58902035dc5" alt=""
本地发布和本地订阅都有,为了实现数据库主从分离这个功能,我们还需要开启SQL Server代理服务器,打开本地电脑的服务,启动SQL Server代理服务(默认是没有启动的)
data:image/s3,"s3://crabby-images/f55b8/f55b800f219d8b9a1768cd6ab6e5dd86c8d1edb2" alt=""
启动完服务就可以了开始实现我们要的功能了,首先,我们创建两个数据库TestA(做为主数据库)和TestB(做为从数据库),
主数据库的作用一般用于新增、删除、更改操作
从数据库可以有多个,一般用于查询操作,因为一般网站可能80%的访问是查询。
本次演示在同一台机器上进行。
1、新建本地发布
data:image/s3,"s3://crabby-images/395ba/395ba260ac80e248a9a30917e8a04e129674d16e" alt=""
2、选中需要发布的数据库,以TestA为例
data:image/s3,"s3://crabby-images/01dc6/01dc62191440a084b24a69bff0a28fd9c1197ab5" alt=""
3、发布类型选择事务发布
data:image/s3,"s3://crabby-images/22330/22330c844128278f143099b60e7e0026898dc009" alt=""
4、把我们需要的表选上(示例只创建了一个表)
data:image/s3,"s3://crabby-images/dbdac/dbdac484a4ef311a509a3d59e78215e15e8d076a" alt=""
5、如果有需要,可以进行筛选表行
data:image/s3,"s3://crabby-images/c0f1d/c0f1d481133ad5ee7ede3778d48684d1a5e91654" alt=""
6、创建快照代理
data:image/s3,"s3://crabby-images/22889/22889e0757857f9938d590cefdfa6296cc5d2042" alt=""
7、选中快照代理安全性进行设置
data:image/s3,"s3://crabby-images/3601b/3601be38d49811cc96c45c5253e28217f8ddd3dd" alt=""
data:image/s3,"s3://crabby-images/fd48f/fd48fe1f21267ad0913e1d4ebffdee26a3a11077" alt=""
8、填写发布名称,会在本地发布中显示
data:image/s3,"s3://crabby-images/f3119/f3119212e17508c29cd7e89dfa67f7f6f1f64ffb" alt=""
9、至此本地发布新建完成(会在本地发布中显示所写的发布名称)
data:image/s3,"s3://crabby-images/3244f/3244f2cf86542712877756073a4dcea3a7cb28d5" alt=""
10、接下来新建本地订阅(右键新建订阅,以TestB为例)
data:image/s3,"s3://crabby-images/b206d/b206d0572f4494299cc32e3f442f6394d6aee39a" alt=""
11、选中发布服务器(有几种选择,本机如下)
data:image/s3,"s3://crabby-images/d0050/d0050070d365c10ee9ba10f38a2711076f505031" alt=""
12、如果不是选择本机的(例如查找SQL Server 发布服务器)
data:image/s3,"s3://crabby-images/cd43a/cd43a31f77ee26bb40c447bfc9670e946008a091" alt=""
13、分发代理位置
data:image/s3,"s3://crabby-images/cdce6/cdce60f497cf98a291a8e3f530e6c03e6caebb3c" alt=""
注意:这里我们选中推送订阅
当数据库的数据有变更的时候,就会通过订阅和发布系统通知各个从数据库更新
1、从数据库隔一段时间轮询主数据库,将主数据库中增量的脚本获取后执行(性能低下)
2、当主数据库有数据更新时,主数据库将增量的数据脚本自动推送给各个数据库执行(性能高效,也是我们使用的这种)
14、选择订阅服务器,也就是以我们的TestB为例
data:image/s3,"s3://crabby-images/3ab8d/3ab8d6a688810816b52ef5f7a6cd55262ca1243c" alt=""
15、设置安全性
data:image/s3,"s3://crabby-images/df78b/df78b07b2f37aca47095709855bd8abac433a764" alt=""
data:image/s3,"s3://crabby-images/0e0fe/0e0fe881cbccf31dc4283b8dab77f0c9c2730517" alt=""
16、至此本地订阅发布成功
然而,却出现问题了,在本地订阅中并没有显示发布成功的数据库
通过一步步查看,在我们刚创建的本地发布中,右键‘查看快照代理状态’
data:image/s3,"s3://crabby-images/deb59/deb59f8af93970d7cf698cb21a40ade6a81c30e4" alt=""
发现ReplData文件夹下,访问被拒绝,因为需要给它设置一个Everyone的权限
data:image/s3,"s3://crabby-images/0c522/0c52299a7eaae1dd1f96813a05f0eafefbbe10b7" alt=""
这时候重新启动代理,就可以顺利启动了
data:image/s3,"s3://crabby-images/29e25/29e2582a1c79004d0507970d6c8231e658ced160" alt=""
本地订阅也可以显示了,并且数据顺利同步过去了
data:image/s3,"s3://crabby-images/33cf3/33cf3a5f7c5d80c3cb431174267cdb30b2b1cf6b" alt=""
data:image/s3,"s3://crabby-images/8852d/8852d985a96a2c3d29ef5a3341133723e0f4b95b" alt="" |