In classical distributed systems, each process has a unique identity. Today, new distributed systems have emerged where a unique identity is not always possible to be assigned to each process. For example, in many sensor networks a unique identity is not possible to be included in each device due to its small storage capacity, reduced computational power, or the huge number of devices to be identified. In these cases, we have to work with anonymous distributed systems where processes cannot be identified. Consensus cannot be solved in classical and anonymous asynchronous distributed systems where processes can crash. To bypass this impossibility result, failure detectors are added to these systems. It is known that $$\varOmega $$Ω is the weakest failure detector class for solving consensus in classical asynchronous systems when a majority of processes never crashes. Although $${ A }\varOmega $$AΩ was introduced as an anonymous version of $$\varOmega ,$$Ω, to find the weakest failure detector in anonymous systems to solve consensus when a majority of processes never crashes is nowadays an open question. Furthermore, $${ A }\varOmega $$AΩ has the important drawback that it is not implementable. Very recently, $${ A }\varOmega '$$AΩ? has been introduced as a counterpart of $$\varOmega $$Ω for anonymous systems. In this paper, we show that the $${ A }\varOmega '$$AΩ? failure detector class is strictly weaker than $${ A }\varOmega $$AΩ (i.e., $${ A }\varOmega '$$AΩ? provides less information about process crashes than $${ A }\varOmega $$AΩ). We also present in this paper the first implementation of $${ A }\varOmega '$$AΩ? (hence, we also show that $${ A }\varOmega '$$AΩ? is implementable), and, finally, we include the first implementation of consensus in anonymous asynchronous systems augmented with $${ A }\varOmega '$$AΩ? and where a majority of processes does not crash.
Read full abstract