免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2998 | 回复: 4
打印 上一主题 下一主题

如何同时执行两个不同服务器上的数据库 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-10-26 09:56 |只看该作者 |倒序浏览
现在的情况是
要进行两个不同数据库中的数据同时操作,这两个数据库放在不同服务器上,用户在应用程序中点一下操作, 一个数据库中的表的一个字段的值加1,而另一个数据库中的表的一个字段的值减1,问题是要两个要实现类似于事务的功能,一个服务器操作不成功,就要全部回滚操作,即另一个已经执行操作的服务器要恢复操作。 比如说,服务器1表中字段加1成功,而服务器2表中字段减1不成功,则要对服务器1对表的操作回滚。以此来实现两个服务器的数据兑换同步。
可是我想来想去也想不到一个好办法啊。

论坛徽章:
0
2 [报告]
发表于 2006-10-26 15:44 |只看该作者
在其中一个库里写个过程 在同一事务里处理 应该可以吧 没有试过

论坛徽章:
0
3 [报告]
发表于 2006-10-27 22:46 |只看该作者
感觉和跨行取款的原理差不多..

论坛徽章:
0
4 [报告]
发表于 2006-10-28 09:55 |只看该作者
DTC 就是解决这个问题的.  DTC=Distribution Transaction Coordinator  分布式事务协调器

通常,DTC 采用两阶段提交实现.

各种编程语言应该都有相应的支持机制.

论坛徽章:
0
5 [报告]
发表于 2006-10-28 23:20 |只看该作者
把两个操作放在同一个事务中进行
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP