问题:
区块链为什么要有出块时间?为什么不是发个交易就出个块?
回答:
其实这个问题其实包含两部分。
1. 区块链系统为什么要通过难度调整限制出块间隔?
一句话解释:矿工的网络带宽有限,要通过出块间隔限速。
在比特币中,每一个节点都需要同步全网的交易。如果出块大小和出块间隔没有限制的话,当 TPS 过高时,会发生同步问题,即普通节点因为网络带宽有限。无法同步全部数据信息。如果一些节点同步了一个分支,另一些节点同步另一个分支,而他们都没有足够的带宽同时同步两个分支,这链就分叉了啊。这会极大影响安全性。Conflux 的技术文章也分析了这件事情,如何内行地评价公链(一)从真正的不可能三角谈起。
2. 即使通过 PoW 限制总 TPS,为什么不设置成一个区块放一笔交易?
一句话解释:系统优化,提升带宽使用和执行效率。
这来源于系统设计中一个通用的优化思想--batching,就是批量处理。如果一个区块放一笔交易,着元数据带来的开销会显著增加,同时会带来很多系统实现上的性能挑战。比如,当区块链系统的吞吐率达到每秒几千笔交易的时候,网络带宽通常会成为瓶颈。而交易就是区块链网络中主要需要传输的数据。如果每笔交易都附带许多DAG相关的元数据(例如对其它DAG结点的引用),那么对网络带宽的压力就会大大增加。另外,维护交易粒度的DAG也会大大增加本地计算的复杂度。