以太坊-GHOST协议

简介:


 为什么要引入GHOST协议?

在区块链中为了提高交易速度,需要减少出块时间从而加快出块速度;区块时间的减少会导致网络安全性下降,而且对大的矿池有利,对小的矿池或单个矿工不利。在以太坊中引入GHOST协议,来解决这个问题。关于为什么出块时间缩短后,会出现安全性下降和对小矿池不利可以参考《以太坊原理简介》中叔块部分内容。

另外,在以太坊中,区块分叉非常常见,所以在发生分叉之后应尽快合并分叉以维护区块链的统。

 

 示例解释Ghost协议

1  场景示例

假设当前以太坊网络中所有矿工都是基于A来挖矿,当一个矿工(w0)打包出一个区块B,并将B广播出去,告诉其他矿工B已经被挖掘出来了,你们可以来基于B来挖矿了。目前以太坊的处快时间是15s,而在15s内,这个区块B可能还没有传遍整个区块链网络,在收到广播前矿工们还是基于A来继续挖矿;假设有四个矿工w1、w2、w3、w4在收到广播前基于A分别挖出了B1、B2、B3、B4,并广播的网络中。

3fd1028dbe706fd1a644d21e9ebc266fb9deff28

此时将面临这样几个问题:

 - 矿工w0、w1、w2、w3、w4都希望自己挖出的区块能放到主链上。

 - 因为w0最早广播,所以也就最可能成为主链上的区块。

 - 如果w0是一个大矿池(p0)中的一个矿工,因为同一个矿池中,所以这个矿池的矿工几乎能够在w0挖出B块以后,立即基于B0开始挖矿;而其他节点因为受到广播的时间比较晚,这样在挖矿中处于劣势,也就很难获得挖矿奖励,矿工们也就失去和p0在同一个网络中挖矿的动力。[传播时间/出块时间]比值越大,那么这种劣势越明显。

区块链的主链只有一条,如何让大家都愿意在同一个条主链上挖矿,并且有动力的挖矿呢?即对于小矿工们而言,愿意接受大矿池挖出来的区块成为主链的区块,并且自己挖出新块以后也能得到一定的奖励,而不会因为广播的时间差而尽做无用功?

 

2  GHOST协议解决方案

30a64f5b19b691778c3297d2159abacc532193cf

如上图所示;矿池p0中的矿工基于B挖矿的时候,可以接纳其他矿工挖出来的区块(B1、B2)作为叔块。因为p0是大矿池,假设p0矿池很快挖出C块并广播出去,因为接纳了两个分叉区块B1、B2,那么B1、B2对应的矿工w1、w2分别获得出块奖励的7/8;另外,p0因为接纳了两个分叉区块,除了出块奖励之外,可以额外得到出块奖励的1/32*2(2指的是接纳的叔块数量)。

还在继续挖C块的矿工,在收到C块信息以后广播后,检验发现p0发布的C块确实是最长链。而挖出B1、B2的矿工w1、w2如果继续在自己的分叉链上继续挖矿,而竞争让自己的分叉链竞争成为主链的可能性很低,这样自己将一无所获;如果接受C对应的链,则可获得区块奖励的7/8作为回报,两相对比很容易选择接纳C对应的链作为主链。如此对于矿池p0和矿工w1、w2都是有益的,如此也能让整个以太坊网络分叉迅速收敛。

因为C区块接纳了B1、B2作为叔块,响应的w1、w2获得了出块奖励;但是对于其他的分叉(B3、B4)来说确实什么都没获得,那么w3、w4能愿意放弃自己挖出来区块么?如何让他们放弃自己所在的分叉,转而拥抱最长的主链?GHOST协议规定,如果D接纳B3、B4,那么B3、B4对应的矿工w3、w4分别能获得出块奖励的6/8,因为D接纳了分叉区块,除了出块奖励以外,还能获得出块奖励的1/32*2。

为什么B3、B4被D接纳时,矿工获得的奖励是6/8,而B1、B2被C接纳时,矿工获得的奖励是7/8呢?那是因为D距离B3、B4的路径更远,B3、B4竞争成为主链的希望更加渺茫,所以奖励自然会少一些。

当然如果基于A挖出来的子块远远不止B、B1、B2、B3、B4,那么接下来一个区块同样可以引用这些B级叔块,不过最大的深度不超过6。

 

 GHOST协议

1    GHOST协议

区块可以不引用叔块,但最多引用两个叔块。

叔块必须是区块的前2层~前7层的祖先的直接的子块。

被引用过的叔块不能被重复引用。

引用叔块的区块,可以获得挖矿报酬的1/32,也就是5*1/32=0.15625 Ether。最多获得2*0.15625=0.3125 Ether

被引用的叔块,其矿工的报酬和叔块与区块之间的间隔层数有关系。

2  报酬与间隔层数

间隔层数

报酬比例

报酬(ether)

1

7/8

4.375

2

6/8

3.75

3

5/8

3.125

4

4/8

2.5

5

3/8

1.875

6

2/8

1.25

 

相关文章
|
传感器 算法 物联网
《移动互联网技术》第三章 无线定位技术:掌握位置服务和室内定位的基本概念和工作原理
《移动互联网技术》第三章 无线定位技术:掌握位置服务和室内定位的基本概念和工作原理
795 0
|
存储 监控 安全
智慧工地管理平台的技术架构和工作原理
智慧工地管理平台是将互联网+的理念和技术引入建筑工地,从施工现场源头抓起,最大程度的收集人员、安全、环境、材料等关键业务数据,依托物联网、互联网,建立云端大数据管理平台,形成“端+云+大数据”的业务体系和新的管理模式,打通从一线操作与远程监管的数据链条,实现劳务、安全、环境、材料各业务环节的智能化、互联网化管理,提升建筑工地的精益生产管理水平。实现“互联网+”与建筑工地的跨界融合,促进行业转型升级。
1020 1
|
Web App开发 编解码 缓存
一套优秀Java云HIS医院信息管理系统SaaS源码
云HIS系统源码采用B/S(Browser/Server)架构,用户通过浏览器输入服务器地址或域名来访问使用。
1900 1
一套优秀Java云HIS医院信息管理系统SaaS源码
|
8月前
|
数据采集 大数据 BI
终于有人把指标管理平台讲明白了!
企业常因数据口径不一、重复开发、效率低下等问题陷入“数据扯皮”。搭建指标管理平台可统一标准,提升数据质量与协作效率。通过FineBI等工具,实现数据连接、指标管理、分析应用三层架构,推动数据驱动决策,助力企业降本增效,真正实现数据资产化。
终于有人把指标管理平台讲明白了!
|
JSON Go C语言
Go语言之定义结构体(Struct)-《Go语言实战指南》
Go 语言中的结构体(`struct`)是一种复合数据类型,可将多个不同类型的字段组合成一个类型。本文介绍了结构体的基本定义、实例创建方式、字段访问与修改、零值特性、比较规则、嵌套使用及标签功能。通过示例代码详细讲解了如何定义和操作结构体,以及其在 JSON 编码等场景的应用。
|
安全 PHP 开发者
Web安全-URL跳转与钓鱼
Web安全-URL跳转与钓鱼
524 8
|
Ubuntu 关系型数据库 数据库
在Ubuntu 18.04上安装和使用PostgreSQL的方法
在Ubuntu 18.04上安装和使用PostgreSQL的方法
526 1
【Qt 学习笔记】Qt常用控件 | 输入类控件 | Combo Box的使用及说明
【Qt 学习笔记】Qt常用控件 | 输入类控件 | Combo Box的使用及说明
2028 0
|
API 开发者 Docker
python中版本不兼容问题
【5月更文挑战第3天】python中版本不兼容问题
2237 2
|
Linux 编译器 iOS开发
CMake 秘籍(一)(2)
CMake 秘籍(一)
249 0