High-throughput blockchains require efficient transaction broadcast mechanisms that can deliver transactions to most network nodes with low bandwidth overhead and latency. Existing schemes coordinate transmissions across peers to avoid sending redundant data, but they either incur a high latency or are not robust against adversarial network nodes. We present Strokkur, a new transaction broadcasting mechanism that provides both low bandwidth overhead and low latency. The core idea behind Strokkur is to avoid explicit coordination through randomized transaction coding. Rather than forward individual transactions. Strokkur nodes send out codewords -- XOR sums of multiple transactions selected at random. Since almost every codeword is useful for the receiver to decode new transactions, Strokkur nodes do not require coordination, for example, to determine which transactions the receiver is missing. Strokkur's coding strategy builds on LT codes, a popular class of rateless erasure codes, and extends them to support multiple uncoordinated senders with partially-overlapping continual streams of transaction data. Strokkur introduces mechanisms to cope with adversarial senders that may send corrupt codewords, and a simple rate control algorithm that enables each node to independently determine an appropriate sending rate of codewords for each peer. Our implementation of Strokkur in Golang supports 647k transactions per second using only one CPU core. Our evaluation across a 19-node Internet deployment and large-scale simulation show that Strokkur consumes 2--7.6x less bandwidth than the existing scheme in Bitcoin, and 9x lower latency that Shrec when only 4% of nodes are adversarial.
翻译:高通量块链要求高效的交易广播机制,它可以将交易传送到大多数网络节点,低带宽管理器和延缓器。现有的计划协调同行之间的传输,以避免发送冗余数据,但是它们要么存在高潜值,要么对对抗性网络节点不强。我们提出Strokkkur,这是一个新的交易广播机制,提供低频管理器和低延缓器。Strokkkkkkkur的核心思想是避免通过随机交易编码来进行明确的协调。 Strokkkkkkkur节点发送代码 -- -- XOR 数的多个随机选择交易。由于几乎所有的代码都对接收者有用,可以解码新交易,但是它们要么是高端,要么是高端,要么是高端。 Strkkkkkkkk 的编码战略建立在低频的LT码之上,一种流行的无价定码。 Strokkrg 代码的扩展它们是为了支持多个不协调的发送者,其交易流只能部分重叠。 Strkkkkkkk 数据数据流。 Strekkkkkk 引入机制来应对可能发送腐败编码错误错误的第二代代码,在每批次版本中发送错误代码中发送错误代码,而无需一次运行次版本。