ZooKeeper is a crash-tolerant system that offers fundamental services to Internet-scale applications, thereby reducing the development and hosting of the latter. It consists of >3 servers that form a replicated state machine. Maintaining these replicas in a mutually consistent state requires executing an Atomic Broadcast Protocol, Zab, so that concurrent requests for state changes are serialised identically at all replicas before being acted upon. Thus, ZooKeeper performance for update operations is determined by Zab performance. We contribute by presenting two easy-to-implement Zab variants, called ZabAC and ZabAA. They are designed to offer small atomic-broadcast latencies and to reduce the processing load on the primary node that plays a leading role in Zab. The former improves ZooKeeper performance and the latter enables ZooKeeper to face more challenging load conditions.
@InProceedings{elsanosi_et_al:OASIcs.ICCSW.2017.3, author = {EL-Sanosi, Ibrahim and Ezhilchelvan, Paul}, title = {{Improving the Latency and Throughput of ZooKeeper Atomic Broadcast}}, booktitle = {2017 Imperial College Computing Student Workshop (ICCSW 2017)}, pages = {3:1--3:10}, series = {Open Access Series in Informatics (OASIcs)}, ISBN = {978-3-95977-059-0}, ISSN = {2190-6807}, year = {2018}, volume = {60}, editor = {Leahy, Fergus and Franco, Juliana}, publisher = {Schloss Dagstuhl -- Leibniz-Zentrum f{\"u}r Informatik}, address = {Dagstuhl, Germany}, URL = {https://drops.dagstuhl.de/entities/document/10.4230/OASIcs.ICCSW.2017.3}, URN = {urn:nbn:de:0030-drops-84452}, doi = {10.4230/OASIcs.ICCSW.2017.3}, annote = {Keywords: Atomic Broadcast, Server Replication, Protocol Latency, Throughput} }