xiezhaoxuan 2018-10-21 08:30 采纳率: 0%
浏览 524
已采纳

死循环的问题,网络通信中如何实现可靠交付

比如网络中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)我们要明白故障导向安全原则,什么意思呢,如果不可靠,发生了故障,会如何。比如你是卖东西的,你不能接受没给钱但是标记给钱了。但是给钱标记为没给钱这是“安全”的。
    前一个情况,钱不一定能追回,后一个情况,人工核实了再给也没事。那么发生了故障,我们要让系统导向安全的状态。
    类似地,如果高铁列车出现了烟雾报警,那么它会停车(虽然烟雾可能是旅客抽烟,并非严重问题,但是我们与其把检测故障的方式搞得复杂,不如导向安全的状态,然后后续去解决)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?