This paper presents a high-performance consensus protocol, Nezha, which can be deployed by cloud tenants without any support from their cloud provider. Nezha bridges the gap between protocols such as Multi-Paxos and Raft, which can be readily deployed and protocols such as NOPaxos and Speculative Paxos, that provide better performance, but require access to technologies such as programmable switches and in-network prioritization, which cloud tenants do not have. Nezha uses a new multicast primitive called deadline-ordered multicast (DOM). DOM uses high-accuracy software clock synchronization to synchronize sender and receiver clocks. Senders tags messages with deadlines in synchronized time; receivers process messages in deadline order, on or after their deadline. We compare Nezha with Multi-Paxos, Fast Paxos, Raft, a NOPaxos version we optimized for the cloud, and 2 recent protocols, Domino and TOQ-EPaxos, that use synchronized clocks. In throughput, Nezha outperforms all baselines by a median of 5.4x (range: 1.9-20.9x). In latency, Nezha outperforms five baselines by a median of 2.3x (range: 1.3-4.0x), with one exception: it sacrifices 33\% of latency performance compared with our optimized NOPaxos in one test. We also prototype two applications, a key-value store and a fair-access stock exchange, on top of Nezha to show that Nezha only modestly reduces their performance relative to an unreplicated system. Nezha is available at https: //gitlab.com/steamgjk/nezhav2.
翻译:本文展示了一个高性能共识协议, 即 Nezha, 由云租户在没有云中提供任何支持的情况下部署。 Nezha 能够弥合多帕克斯和拉夫特等协议之间的缺口, 多帕克斯和拉夫特等协议可以随时部署, 以及诺帕克斯和光谱和平协会等协议, 能够提供更好的性能, 但需要获得像可编程开关和网络内排序这样的技术, 而云租户没有这种技术。 Nezha 使用一个新的多播种原始协议, 叫做定时制多米诺和TO- EPax多盘。 DOM 使用高精度软件时钟同步来同步发送和接收时钟。 发送者用同步时间标记信息; 接收者将信息标记为最后期限; 接收者按最后期限顺序处理信息, 在期限或之后进行。 我们优化的云租户开关开关、 NOPax 和两个最近的协议, 多米诺和TO- EPaxx, 仅使用同步时钟。 在通关中, Nzha 超过所有非基线的基线, 以5 Nex 汇率 的中, 将业绩 以一个中 的中 。