码迷,mamicode.com
首页 > 编程语言 > 详细

分布式系统互斥算法---非集中式算法

时间:2015-05-10 15:44:15      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:

集中式算法存在单点失效问题,那么我们接着来看一下非集中式算法。

假设共享资源副本被复制了n次,每个副本有其自身协作者控制访问;如果某个进程要访问共享资源,主要获得m>n/2个协作者投票允许即可。

如图1所示,如果进程0要发起访问请求,只要8个协作者中有5个(包括其自身)投票允许即可。

技术分享

图1

但是该算法也有自身的缺陷,即当某个协作者崩溃时,它将忘记之前投过的票,可能在回复后又投了重复的票给其他请求者;比如已经允许了p进程访问共享资源,之后该协作者重置了,又允许了q进程去访问共享资源,此时可能会出现不一致问题。

为了防止有很多个进程同时发起访问请求导致谁也无法访问共享资源,发起访问的进程可以把请求带上时间戳,其他协作者按照时间戳的先后顺序进行投票允许,同时请求者还需要在访问结束后通知所有其他协作者访问已释放。

分布式系统互斥算法---非集中式算法

标签:

原文地址:http://blog.csdn.net/lixiaojie1012/article/details/45621061

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!