以太坊-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

 

相关文章
|
传感器 算法 物联网
《移动互联网技术》第三章 无线定位技术:掌握位置服务和室内定位的基本概念和工作原理
《移动互联网技术》第三章 无线定位技术:掌握位置服务和室内定位的基本概念和工作原理
769 0
|
Web App开发 编解码 缓存
一套优秀Java云HIS医院信息管理系统SaaS源码
云HIS系统源码采用B/S(Browser/Server)架构,用户通过浏览器输入服务器地址或域名来访问使用。
1842 1
一套优秀Java云HIS医院信息管理系统SaaS源码
|
8月前
|
数据采集 大数据 BI
终于有人把指标管理平台讲明白了!
企业常因数据口径不一、重复开发、效率低下等问题陷入“数据扯皮”。搭建指标管理平台可统一标准,提升数据质量与协作效率。通过FineBI等工具,实现数据连接、指标管理、分析应用三层架构,推动数据驱动决策,助力企业降本增效,真正实现数据资产化。
终于有人把指标管理平台讲明白了!
|
人工智能 自然语言处理 算法
经典大模型提示词工程技术路线概述
本文概述几种经典提示词工程方法,总结关键信息,分析其优势和局限,并分享笔者的一点思考。
990 105
经典大模型提示词工程技术路线概述
|
安全 PHP 开发者
Web安全-URL跳转与钓鱼
Web安全-URL跳转与钓鱼
476 8
|
存储 NoSQL Java
分布式session-SpringSession的应用
Spring Session 提供了一种创建和管理 Servlet HttpSession 的方案,默认使用外置 Redis 存储 Session 数据,解决 Session 共享问题。其主要特性包括:提供 API 和实现来管理用户会话,以中立方式替换应用程序容器中的 HttpSession,简化集群会话支持,并在单个浏览器实例中管理多个用户会话。此外,Spring Session 允许通过 headers 提供会话 ID 以使用 RESTful API。结合 Spring Boot 使用时,可通过配置 Redis 依赖和支持缓存的依赖实现 Session 共享。
431 0
分布式session-SpringSession的应用
|
Ubuntu 关系型数据库 数据库
在Ubuntu 18.04上安装和使用PostgreSQL的方法
在Ubuntu 18.04上安装和使用PostgreSQL的方法
493 1
|
存储 NoSQL Java
教程:Spring Boot与RocksDB本地存储的整合方法
教程:Spring Boot与RocksDB本地存储的整合方法
|
Windows
windows 技巧篇-查看文件夹被那个进程占用,文件夹占用解除方法
windows 技巧篇-查看文件夹被那个进程占用,文件夹占用解除方法
3040 0
windows 技巧篇-查看文件夹被那个进程占用,文件夹占用解除方法
|
存储 安全 区块链
一文说清楚IPFS分布式存储系统
一文说清楚IPFS分布式存储系统
4087 1

热门文章

最新文章