比如网络中A端想让B端里面的100块钱减1,A发送减1命令给B,B收到命令后执行操作,这样B里钱数为99,然后返回确认给A,但是A没收到确认,就认为操作失败,所以A还以为B里面是100块钱,但是实际B已经是99块钱了,怎么办,突然想起的问题,在线等。。。
4条回答 默认 最新
threenewbee 2018-10-21 13:56关注君不见支付宝也有客服,也有人工解决扣款不正常的问题么?
就你说的那个,永远都不能做到100%可靠,因为确认需要再确认才能被确认,而再确认又需要再再确认……
我们需要了解两个原则就可以了
(1)“不可靠”出现的概率有多大,我们不需要理论上100%的可靠,这个做不到,就算你程序做到了,cpu内存也可能因为物理原因出错。
我们要追求的是工程上的概率足够低,即便这种方式在理论上作不到100%也没事。
(2)我们要明白故障导向安全原则,什么意思呢,如果不可靠,发生了故障,会如何。比如你是卖东西的,你不能接受没给钱但是标记给钱了。但是给钱标记为没给钱这是“安全”的。
前一个情况,钱不一定能追回,后一个情况,人工核实了再给也没事。那么发生了故障,我们要让系统导向安全的状态。
类似地,如果高铁列车出现了烟雾报警,那么它会停车(虽然烟雾可能是旅客抽烟,并非严重问题,但是我们与其把检测故障的方式搞得复杂,不如导向安全的状态,然后后续去解决)本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报