「毕」 5. Fabric 的改进
本文最后更新于:1 年前
本文总结论文阅读中对于 Fabric 的改进方案,并梳理一下毕设的改进思路。
1 Fabric [1]
1.1 交易流程
- 客户将其交易发送给一定数量的背书节点。
- 每个背书节点在隔离环境中模拟执行交易,并计算相应的读写集以及访问的每个键的版本号。模拟成功后返回背书响应给客户端。
- 客户端收集足够数量的背书,然后将这些响应打包发送给排序节点。
- 排序节点首先对传入交易的顺序达成共识,然后将消息队列划分为块。
- 块被传递给对等节点,然后由对等节点验证并提交它们。
1.2 阶段展示
1.3 改进思路
有实验使用 Fabric 网络发送大量的转账交易,结果如下:
可以看出大量的交易因为读写冲突被中止了,而发送空白交易的对比试验总的 TPS 与发送转账交易的 TPS 相差不大,这说明系统的瓶颈并不在于智能合约的计算上。
由此可以得出两种改进思路:
增加系统的整体吞吐量
将原本会被 Fabric 中止的交易变为成功的交易
2 增加吞吐量
2.1 Optimizing Fabric [2]
此文对 Fabric 1.0 做了大量测试,发现以下瓶颈:
- 身份的加密操作
- 区块中的交易串行验证
- 对 CouchDB 的多个 REST API 调用
优化(单通道提升 16 倍):
- MSP Cache
- 并行 VSCC 验证
- 区块 MVCC 验证时的批量读写
2.2 FastFabric [3]
优化:
- 排序阶段仅使用交易 ID,并行处理多个交易,提高共识效率
- 使用内存中的哈希表代替 LevelDB/CouchDB 来储存世界状态,提高访问速度
- 分离背书和验证的角色
- 缓存解析的区块数据
- 并行验证块和块中交易的有效性
结果:
- Opt O-I: 只使用交易 ID
- Opt O-II: 并行处理传入交易
- Opt P-I: 使用内存哈希表
- Opt P-II: 验证与提交分离
- Opt P-III: 缓存解析数据
3 提高成功率
3.1 Fabric++ [4]
优化:
- 事务重新排序机制(transaction reordering mechanism)
- 早期中止(early abort)
重排算法:
- 建立所有交易的冲突图
- 识别冲突图中的所有环
- 识别每一笔交易出现在哪个环中
- 依次中止出现在最多环中的交易,直到图无环
- 使用剩余的交易建立一个可串行化调度
早期中止:
结果:
3.2 FabricSharp [5]
优化:
- Fabric++ 过度中止了跨块读取的交易
- Fabric++ 没有考虑跨块并行交易之间的依赖,重排效果受限
- 更好的早期中止和交易重排算法
六种基本依赖:
Fabric/Fabric++ 不允许在两个交易之间的 anti-rw,因为后一个交易将读取前一个更新的旧版本,因此必须中止。
如果两个交易 Txn1 和 Txn2 表现出 c-rw 或 anti-rw 依赖性,则改变顺序不会影响它们的依赖顺序。
如果两个交易 Txn1 和 Txn2 表现出 c-ww 依赖性,交换它们的顺序将翻转它们的依赖顺序。
- 由上可知:如果环没有 c-ww 依赖关系,则无法重新排序为可序列化。
- 所以对于一个新交易,所有待排序交易(包括新交易)中除了 c-ww 的所有依赖项中如果存在依赖环,直接中止新交易。
Overview
4 改进思路
4.1 交易合并
在模拟执行阶段对交易类型进行判断,如果符合简单转账交易的类型,则添加一个可合并的标志,后续在排序节点中对该类交易进行合并,以减少验证阶段 MVCC 冲突。
4.2 交易重排
在 Fabric 2.4.0 排序节点中生成交易依赖图,复现并改进交易重排序的算法,降低交易的读写冲突率。
4.3 并行验证
根据排序阶段生成的交易依赖图,在验证阶段对相互独立的交易链进行并行验证,提高系统的吞吐量。
5 参考文献
[1] Androulaki E , Barger A , Bortnikov V , et al. Hyperledger fabric: a distributed operating system for permissioned blockchains[C]// European Conference on Computer Systems.ACM, 2018.
[2] Nathan S , Thakkar P , Vishwanathan B . Performance Benchmarking and Optimizing Hyperledger Fabric Blockchain Platform: IEEE, 10.1109/MASCOTS.2018.00034[P]. 2018.
[3] Gorenflo C , Lee S , Golab L , et al. FastFabric: Scaling Hyperledger Fabric to 20,000 Transactions per Second[J]. IEEE, 2019.
[4] Sharma A , Schuhknecht F M , Agrawal D , et al. Blurring the Lines between Blockchains and Database Systems: the Case of Hyperledger Fabric[C]// ACM SIGMOD 2019. ACM, 2019.
[5] Ruan P , Loghin D , Ta Q T , et al. A Transactional Perspective on Execute-order-validate Blockchains[J]. 2020.