第312章 拜占庭容错算法(第1/2页)
蔡志远继续解释道:
“比如,现在一共有五名将军,其中两名将军认为应该进攻,而另外两名将军认为应该撤退。
“这时候,第五名将军是个叛徒,他告诉进攻的将军『我也会进攻』,又告诉撤退的将军『我也会撤退』。
“于是,想要进攻的将军认为,现在有三支军队同意进攻,超过了半数,所以明天应该进攻。
“而想要撤退的将军认为明天应该撤退。
“最后的结果,就是两个将军进攻,两个将军撤退,导致战争失败。
“这就是『去中心化』所带来的问题,因为这五个将军都是平级的,没有一个拥有绝对权限的指挥者,所以在互相商量策略的过程中,就会产生这样的问题。”
郑杰恍然点头:“原来如此!那这个办法怎么解决呢?也没办法验证具体是哪个将军在说谎吧?”
蔡志远解释道:“其实要解决这个问题很简单:多问几遍就行了。
“假设我是其中一名将军a,而将军b告诉我他要和我一起进攻。
“如果我信了,那就有可能会被骗,因为将军b有可能是叛徒,他可能只跟我说了进攻,跟别人说了撤退。
“所以,这时候我应该再去问将军c,我问他:‘将军b跟你说的是进攻还是撤退?’
“然后我再去挨个问其他所有的将军,汇总将军b给他们说的所有信息。
“其他将军告诉我的『将军b给他们的信息』也不一定真实,因为其他将军里面可能也有叛徒,可能存在『将军b跟他们说进攻,他们却告诉我将军b说了撤退』这种情况。
“所以,我挨个问一遍『将军b对你们说了什么』,如果『进攻』比较多,那我就把将军b的意见记为『进攻』;
“然后再挨个问一遍『将军c对你们说了什么』,如果『撤退』比较多,那我就把将军c的意见记为『撤退』。
更多内容加载中...请稍候...
本站只支持手机浏览器访问,若您看到此段落,代表章节内容加载失败,请关闭浏览器的阅读模式、畅读模式、小说模式,以及关闭广告屏蔽功能,或复制网址到其他浏览器阅读!
本章未完,请点击下一章继续阅读!若浏览器显示没有新章节了,请尝试点击右上角↗️或右下角↘️的菜单,退出阅读模式即可,谢谢!