发布网友 发布时间:2022-04-09 12:02
共3个回答
懂视网 时间:2022-04-09 16:23
事务的功能在sqlserver中由来已久,因为最近在做一个数据同步方案,所以有机会再次研究一下它以及快照等,发现还是有很多不错的功能和改进的。这里以sqlserver2008的事务发布功能为例,对发布订阅的方式简要介绍一下操作流程,一方面做个总结备份,一方面与大家进行一下分享和交流。费话就不多说了,进入一下今天的正题:)
这里要说明一下环境:首先我在本地局域网内有两台安装有sqlserver2008的机器(注意:已发布的快照版本无法向老版本数据库兼容,意味着2008下创建的事务或快照发布,无法被sqlserver2005订阅)。当然这两台机器要放在同一个网段,一方面出现性能和安全性考虑,另一方面是我目前还没有找到跨不同网段的快照应用方案(可行性的那种)。
好了,这里我以我们产品数据库为准来介绍一下如何通过发布订阅的方式来进行数据同步。
首先,在要发布的数据库上创建一个我们的产品数据库(这里叫做dnt_new),然后在该数据库实例的左侧导航的“复制”--“本地发布”上击右键,然后选择“新建发布”,如下:
这样,系统就会启动‘发布向导’来引导大家,这里我们在欢迎界面下点击"下一步”,然后在当前窗口中选择要发布的数据库,如下:
点击下一步,然后在接下来的窗口中选择“事务发布”,如下图:
然后点击下一步,选择要同步的数据对象(数据表,存储过程,自定义函数等),如下:
然后就是“项目问题窗口”,因为之前已用dbo身份登陆,所以这里只要点击下一步即可,如下图:
这里可以通过“添加”方式来过滤要同步的数据信息,因为要做全表数据同步,所以这里就不做设置了,感兴趣的朋友可以自己研究一下,这里接着点击下一步,如下:
然后在‘代理安全性’窗口中,点击“安全设置”按钮:
在弹出的‘安全设置’子窗口中设置如下信息,并点击‘确定’按钮:
然后点击下一步按钮:
选择“创建发布”复选框,然后点击下一步,这时向导会让您输入“发布名称”,这里命名为“dnt_new_snap”:
点击“完成按钮”,这里系统就开始根据之前收集的信息来创建该发布对象信息了,如下:
到这里,‘创建发布’的工作就完成了。下面介绍一下创建订阅的流程。在另一个机器的sqlserver实例上,打开该实例并使用“复制”—“新建订阅”,如下图:
这时系统就会启动“新建订阅”向导,点击下一步,并在“发布”窗口中的“发布服务器”下拉框中选择“查打发布sqlserver服务器”项,如下:
然后在弹出窗口中选择之前‘创建发布时所使用的数据库实例’并进行验进登陆,这时,发布服务器的信息就会出现在下方的列表框中:
选择之前我们创建的那个发布对象“dnt_new_snap”,接着点击下一步:
在分发代理位置窗口中,选择“在分布服务器上运行所有代理”,然后点击下一步,然后在“订阅服务器”窗口中的订阅数据库列表框中选择一下要同步的订阅数据库名称(可新建):
点击下一步,然后在‘分发代理安全性’窗口中,点击列表框中的‘…’来设置安装性,并做如下设置(注意红框部分):
然后点击“确定”按钮,之后在向导上点击“下一步”按钮,这时系统就会显示“代理计划执行方式”窗口,选择“连续运行”:
点击下一步,在窗口中选择“立即执行”:
完成了这一步,点击下一步按钮,然后就可以创建该订阅对象了,如果一切运行正常,sqlserver就会从‘发布服务器’那边,将之前指定的数据表和存储过程等同步到当前的‘订阅数据库’中了。
这时我们可以在源数据库(发布服务器)上的表中添加或修改指定表数据信息,在等待1-3秒之后,所做的添加和修改就会同步到‘订阅数据库’上的相应表中。看来目的是达到了,呵呵。
使用Sqlserver事务发布实现数据同步
标签:引导 数据库 运行 导航 blog 今天 height 指定 功能
热心网友 时间:2022-04-09 13:31
方法/步骤
1
机器A、B分别新建标准用户repluser,用于访问初始快照共享文件。
2
机器A新建X_DB数据库,表persion
3
选择复制菜单->本地发布,右键新建发布,next->选择数据库X_DB.
选择发布类型,这里有四种:快照发布、事务发布、可更新订阅的事务发布、合并发布。快照发布和合并发布都是定期取数据,不同的是合并发布可独立更新,可把订阅端的数据更新同步到发布端;测试发现如果两端同时更新,发布端的更新会覆盖掉订阅端的更新。事务发布是事务驱动,只要有更新,立马同步更新。
这里我选择事务同步->next
选择需要复制的表,这里有个*:只有带主键的表才能复制.一路next
设置代理账号,next。最后输入发布名称,发布成功.
选择刚才创建的发布,右键属性,选择快照设置共享路径;也可以选择FTP快照进行FTP共享。这样订阅端就访问这个路径读取初始快照。至此发布端设置完成。
机器B订阅端选择复制->本地订阅-》新建订阅。
选择发布服务器,选择x_db下的x_db_publish
没有x_db,可以自己创建数据库。设置分发与订阅账号。
选择刚创建的订阅,右键属性,修改快照位置:如果发布端使用的共享路径方式就选择备用文件夹,输入共享目录。如果是FTP选择ftp,输入路径。至此设置完毕。
查看下发布端复制监视器,表已传过来。
新增一条。
热心网友 时间:2022-04-09 14:49
sql事务复制 本身就存在延时问题解决办法: 1、建议你用数据库镜像,这样数据绝对是实时同步 2、双机热备方式,此种方式造价有些昂贵追问昂贵为什么呢?开通这个功能需要另外收费吗