Why is exactly once semantics infeasible?

前端 未结 3 1354
悲哀的现实
悲哀的现实 2021-02-05 17:09

In RPC semantics where Erlang has hope for the best, SUN RPC with at-least once and Java RMI with at-most-once but no one has exactly once semantics.

Why does it seem i

3条回答
  •  暗喜
    暗喜 (楼主)
    2021-02-05 17:41

    Consider what happens if the server crashes between carrying out the request and recording that it has carried out the request?

    You can get at-most-once by recording the request, then carrying it out. if you get a crash between the two, then you've (erroneously) recorded it as carried out, so you won't do it again. Hence at-most-once

    Bizarrely, this one (with timeouts) is patented: http://www.freepatentsonline.com/7162512.html. Except as I argue above, it doesn't guarantee exactly-once.

    You get at-least-once by carrying it out, then recording it. If you get a crash between the two, you'll carry it out again if the request is repeated.

    But it's not really feasible to say "exactly once" in all circumstances

    (There are similar scenarios for network errors rather than server crashes)

提交回复
热议问题