GHOST,DAG,SPECTRE,PHANTOM和CONFLUX技术原理
??DAG概念,当做继比特币,以太坊后新的一代区块链技术(区块链3.0),那么DAG区块链是什么?DAG的由来是什么?它的技术理念是怎么样的?运行在DAG区块链上的协议有哪些?
??要想解释DAG,离不开Yonatan Sompolinsky 和 Aviv Zohar两位以色列人,他们是DAG区块链这一概念的提出者。在DAG之前,Aviv Zohar提出了一个GHOST协议(以太坊初期就采用了GHOST协议),该协议解决的是链分叉带来的安全性问题,而分叉的区块链 在GHOST协议下数据结构就从一条链变成了一个树(Tree),而之后Aviv Zohar进一步提出了一个inclusive协议,在inclusive协议规则下,区块的结构就变成了有向无环图(DAG)。
接下来本文将:
??1.介绍 GHOST协议,DAG由来 背后的 设计原理
??2.介绍三种针对DAG型区块链设计的协议,SPECTRE、PHANTOM和CONFLUX。
??GHOST协议是为了解决 分叉 导致 链安全性降低 的一个协议。
??下边将通过解释什么是 分叉 ,为什么 分叉会降低链的安全性 , 链上扩容 为什么会导致更多分叉来详细介绍GHOST协议。
一笔比特币交易为什么要等6个区块的交易时长呢?
??等待不是为了 防范51%攻击 的。落后6个区块,如果拥有超过51%的算力,只要足够长的时间,一定能够产生更长的链完成攻击。它是为了防止 分叉 带来的风险。
??比特币在 理想情况 下,不同节点之间有相同的一条区块链,全部节点都是基于 同一个区块 进行挖矿,但当两个挖矿节点 几乎同时 挖到一个新的区块,当它们接收到对方产生的区块时,不同的节点将选择基于 其中一个 区块挖矿, 分叉 产生了。之后节点会根据哪条 分叉更长 ,选择哪条是主链进行挖矿,而不是主链的分叉区块全部被 抛弃 。
??比特币每天都会发生 二分叉 ,但出现连续的 六次分叉 几乎不可能,于是要等待6个区块的确认时间。(这种分叉不是来自恶意攻击,是 偶然性以及网络延迟 导致的。
分叉将‘攻击不超过51%算力,比特币就是安全的’这一理论推翻。
??在比特币中,当链有 分叉 时,将选择分叉 最长 的链作为主链,恶意攻击就是产生一条比主链更长的链 代替主链。
??下图中蓝色区块代表诚实区块,红色代表攻击区块。2号、3号蓝色区块产生 分叉 ,此时攻击节点产生5个攻击区块(红色)就能产生一条 更长 的链完成攻击。虽然蓝色区块总数更多(有6个), 但分叉的区块没有增加链的长度 ,这种情况下,红色攻击方在算力(假设每个区块代表算力相同)没有超过51%的情况下攻击成功。
??比特币当前安全的原因在于10分钟的区块时间降低了分叉可能性,但其实际安全算力仍低于51%,也就是说,不需要51%的算力也能攻击成功。
??采用 大区块 以及 小的产出时间 将导致链有 很多分叉。 ??
??比特币当前处理交易量很低,改进这个缺陷一个可行方法就是 增大区块的大小和减小区块的产出时间 。大区块需要更多的网络传输时间、单位时间更多的区块数都会导致 更多的分叉 。 ??
?? 链上扩容的方案对比特币处理交易能力提升是巨大的 ,假如每个区块大小变为原来的八倍(8M),出块时间缩短为原来的五分之一(2分钟),理想情况下,比特币的处理交易量将变为原来的 40倍 ,实际情况会产生分叉,交易量不会有这么高。
?? 主链选择中,采用计算最大子树来代替比特币中的最长链规则。 ??
??比特币的最长链规则在有分叉情况下,将降低链的安全性,分叉越多,安全性越低。链上扩容将导致更多分叉,导致链不安全。
??Yonatan Sompolinsky提出GHOST规则, 当有分叉时,通过计算最大子树,也就是每条分叉拥有的所有区块数来决定哪条链是主链 。图0中,链在区块0后分叉了,上边分叉总计有6个蓝色区块,下边分叉有5个红色区块,蓝色区块1是主链,所以 红色攻击失败 。 ??
?? 在有大量分叉的情况下,GHOST规则将链安全性直接提到了51%,分叉对采用GHOST协议的链安全性没有影响。
??根据GHOST规则,上图中虽然诚实节点产生了12个区块,但加入主链的只有4个区块,大量区块 被丢弃 ,假定比特币每个区块大小变为原来的八倍(8M),出块时间缩短为原来的十分之一(1分钟),分叉率为0.33(产生的区块加入主链的概率),比特币的处理交易能力将变为原来的 26.6倍 。
GHOST协议解决了链上扩容导致分叉带来的安全性问题。
区块的结构类型就从一条链变为树
??在GHOST的提出后,Yonatan Sompolinsky提出一种新的设想,新产生的区块指向所有已知的分叉末端区块,即一个区块有多个父亲,此时 区块链就从一条链变为多条分叉链共同组成的的结构,这样的链结构就被叫做DAG(有向无环图) 。
Yonatan Sompolinsky进而提出了在DAG上运行的 inclusive协议 ,原理如下:
遗憾的是, Yonatan Sompolinsky之后并没有详细介绍补充该协议 ,而是提出了一种新思路的DAG协议——SPECTRE。
??看完上边内容之后,你会发现, 最长链规则下,分叉的区块对比特币安全性和交易量没有任何贡献 ,白白的浪费了算力,而 GHOST通过计算分叉区块个数来提升链的安全性 ,但分叉区块除了纳入区块计数外,区块内包含的交易信息却全部 被丢弃 。
??这种新的区块结构带来了新的特性,当然,比特币的 最长链规则 也可以在DAG上实施,只不过安全性和处理交易能力不佳,而GHOST协议可以提高安全性和处理交易能力,为了 最大化 利用DAG区块链特性,社区提出了不同的协议,接下来介绍Yonatan Sompolinsky 提出的 SPECTRE协议 ,以及 PHANTOM协议 ,以及国内某社区提出的 CONFLUX协议 。
丢弃主链概念,所有产生的区块共同构成账本,不丢弃任何一个区块
??只要是产生的区块就不会被丢弃,所有的区块都是有效的,所有区块共同组成账本,这样进一步提高了区块链的处理交易能力, 该设计的关键在于设计算法来保证区块链不会被恶意攻击成功。 ??
??SPECTRE协议较为复杂,下边将从其如何产生区块、如何处理冲突交易以及产生可信交易集三个方面进行描述。
SPECTRE协议中,当产生区块时,要指向之前所有分叉的末端区块。
?? 下图中,左边为比特币产生区块时,当有分叉出现,新区块将选择基于其中一个产生新的区块,而SPECTRE中,将基于所有分叉末端区块产生新的区块。同时,当有新区块产生时,节点要立刻将新区块(包含基于哪些区块产生这一信息)发送给与自己相连接的节点。
??仔细观察,GHOST协议中虽然有分叉,但每个区块都只基于前边某一个区块产生,而SPECTRE协议中要基于当前节点知道的所有末端区块产生下一个区块。
SPECTRE协议将矿工维持交易不冲突的要求剥除 ??
??比特币就像一本 权威 的账本,只要是里边记录的,就一定是真的(不考虑分叉和恶意攻击),而SPECTRE产生的DAG就像一本 不权威 账本,里边的交易信息可能冲突(上边图1中两个1区块中可能包含冲突交易信息)。 ??
??该协议下,挖矿节点只 负责迅速挖区块 (能够达到1秒一个区块),而对分叉中可能包含的冲突交易在挖矿阶段并 不做任何处理 ,将记录交易速度最大化,让DAG这种区块链有着恐怖的处理交易能力。
??是时候解决挖矿不解决的 冲突交易 问题了,SPECTRE的思路是设计一个计算投票的算法,让诚实区块会投票给诚实的区块,后边的诚实区块会给前边的 堆叠算力 ,从而让恶意攻击失败,其安全算力也是 51% 。 ??
??拿双花举例,下图中,X和Y区块中包含着两条冲突交易会导致双花,此时DAG中的区块会对X和Y进行投票, 决定哪一个交易有效。
投票规则如下,投X的标蓝,投Y的标红,X ??根据投票结果,X中的那条交易信息 有效 ,Y中对应的那条交易信息 无效 。 ??Yonatan Sompolinsky也对 不指向前边区块 以及 产生区块不发给邻居节点的恶意攻击 有进行分析,在投票规则中,低于50%算力的攻击者会失败。 ?? SPECTRE可信交易集就相当于超过当前6个区块的比特币链里组成的交易集合。 ??区块链从数字加密货币的角度来说,就是一个 账本 ,从账本上的交易信息中得出每个 账户 所拥有的货币,所以,得出 确定的、不可能更改 的交易信息就至关重要,SPECTRE可信交易集产生过程如下: SPECTRE并不会对所有区块进行排序,所有区块没有一个完整的线形顺序,有的只是决定冲突信息先后的区块顺序对。 ?? ??SPECTRE协议非常 适合DAG型数字加密货币 ,但当它用于智能合约时,它的缺陷就出来了,智能合约需要一个 严格的线性顺序 ,对此Yonatan Sompolinsky新设计了 PHANTOM 协议来对DAG区块形成一个 线性顺序 ,下边将详细介绍PHANTOM协议。 ??PHANTOM的挖矿机制和SPECTRE一样,会产生同样类型的DAG,不同的是PHANTOM通过对 区块连通度分析 ,判定区块诚实还是恶意,按照分类对区块排序,对DAG区块产生一个严格的 线性顺序 ,通过线性顺序来判断 冲突交易有效性 。 DAG中,攻击者有两种攻击手段, 一产生的区块不基于已知的末端区块,二不立即发布自己产生的区块 ,前者会让自己区块指向的区块变少,后者让其他节点产生的区块不会指向自己的区块,这两种情况都会导致这些恶意区块的与其它区块的 连接度低 。 接下来,进行区块 诚实和恶意 判定,判定分两步,第一步最重要, 实现复杂也耗费时间 ,主要为通过对区块连通度的判定,将强连通度的区块标为蓝色视为诚实区块,弱的标为红色视为恶意区块。 ??第二步 先对蓝色区块集排序 ,拓扑排序,然后对 红色区块集排序 。红色区块的顺序要处于弱势,例如上图中C,它处于A和I之间,那么它的顺序会排在I的前一个区块,而D、H都会排在C前。 注意通过考虑最大延迟时间设定连通度的值,几乎所有正常诚实节点产生的区块都会被标记为蓝色 ??Yonatan Sompolinsky在PHANTOM协议论文结尾,提出一种将PHANTOM + SPECTRE结合起来的可能协议,没有详细展开介绍。下图是几种协议的对比: ??至此,介绍了Yonatan Sompolinsky一开始从分叉导致不安全提出的GHOST,到后来将DAG引入区块链,设计了SPECTRE协议,以及为智能合约考虑的PHANTOM协议。接下来,介绍国内某社区提出的CONFLUX协议。 ??GHOST有 主链但丢弃分叉区块 ;SPECTRE 没有主链,包含所有分叉,但没有线性顺序 ;PHANTOM 没有主链,包含分叉且有线性顺序 ,而CONFLUX 即有主链,又是DAG,利用主链让DAG产生线性排序 ,下面将从挖矿机制和区块排序两方面来说明CONFLUX协议。 ??CONFLUX协议定义了根源边和参考边。 新区块是基于前一个主链区块产生的,新区块用根源边(实线)指向前一区块,用参考边(虚线)指向分叉的其他区块末端 ,如下图最后一个新区块实线指向H,虚线指向分叉末端区块K。 根源边用于代表区块基于哪个区块产生,给哪个区块堆叠算力,参考边用于表示分叉的其它区块产生在该区块之前。 挖矿过程如下: 根源边只能有一条,参考边可多条(视情况而定) 以主链区块为分割点,将DAG分段,段间段内设计简单排序算法 ??通过上述排序,DAG有了一个 线性顺序 ,上图DAG区块顺序为 Genesis, A, B, C, D, F, E, G, J, I, H, and K 。接下来对该线性顺序的区块里的交易信息进行交易排序, 单一区块 里可能包含的冲突交易将直接按照该区块内交易信息排列 先后顺序 决定。 GHOST论文 虚拟货币的投资是我专精做的事情,当然也买了比特币,虽然现在看来赚得不多,但我在投资能力上的提升,让我咬咬牙,下一个牛市,让父母安享晚年,让未来的孩子获得更多资源,是没问题的。 所以这个回答,只要你好好阅读,相信会让你在今后的投资赚钱成长路上加分! 首先,我大致看了所有回答,有人说自己赚钱了,可是卖掉之后比特币依然在涨,也有人说自己亏钱,盲目高位入场,结果大跌,割肉离场了。 还有人玩期货合约爆仓,亏得负债累累甚至妻离子散,总之,这一切,在我看来,都会归因于两点,一个是对比特币这个投资标的的本质认识不够,另一个是对区块链这个行业的市场周期没有清晰的认识。 (那关于比特币的本质,在本次的回答中我就不再一一赘述了,因为已经再另一个问题中回复了,详细的可以关注币币,查看币币往期的回答。) 那我今天要着重讲的是区块链这个行业以及比特币的周期,分为三个部份,给你全面讲解: 一、什么是市场周期? 二、比特币的周期及区块链的周期是什么样的? 三、如何利用周期规律,抓住时代的机遇,正确投资,改变命运? 一、什么是市场周期? 如果你平时需要买菜做饭,细心观察的话,可能就会发现,过去最近这段时间猪肉涨价了,每斤最高有到四十多块左右。 印象中买过最便宜的猪肉有7块左右,甚至猪瘟被报出来之后,大众恐慌,需求短期下降,猪的产量也下降,供大于求导致价格下降。 经过一段时间后,猪瘟事件慢慢调节,大众日常需求量恢复,随着迎来节假日需求又慢慢增加,但是很多养猪户的猪N年前就已经全杀了,供小于求导致的价格暴涨。 这是猪肉价格的例子,我们再看一个发生在过去几年大蒜价格的例子。 你会发现一个有意思的规律,就是:通货膨胀导致民间所说的“钱不值钱”自然天灾导致产量下降、供小于求导致价格暴涨,中间商趁机囤货,居奇操控价格、无良媒体放肆鼓吹,引起更大面积的恐慌。 刚需加上吃过群众不明就里的抢购,造成进一步紧缺,市场消息不透明,导致农民大面积种植。 产量过剩导致供过于求价格的大跌,价格大跌没有再问起,产量下降……2——3年内完成一个“涨跌”的全过程。 这一切综合起来,就构成了我们所说的 “市场周期”。 而作为普通的“蒜农”就如发改委的一名官员评论这件事情时所说的:“在丰收时——跌价,减产——涨价的轮回中,农民每次都滞后于市场的脉动,永远“踩不准点!” 这背后的原因是什么呢? 二、比特币的周期及区块链的周期是什么样的? 我们把视角拉回到区块链资产投资上,在这里找答案。 我们来用“蒜”的价格变化呈现的周期,和比特币价格变化呈现的区块链“周期”的变化来做个类比。 关于比特币的周期,区块链领域知名投资人赵东18年在微博上有这样一番言论:(请注意,接下来我是转速赵东的话。) #欧易OKEx# #比特币[超话]# #数字货币#
?? 投票听起来像是一个主动地中心化行为,实际上不是,程序根据当前DAG区块所处的状态自发完成这一区块投票计算过程,就相当于,给定一个DAG数据,输入为两条冲突信息,运行该规则算法,将得出一对冲突交易的哪一个为有效。
??比特币中的高度代表的就是 线形顺序 ,高度低的区块中交易信息先于高度高的区块里的信息,高度高的区块就不能 包含和高度低的区块冲突的交易 ,而SPECTRE有大量的分叉,区块高度不能代表线形顺序,前边的区块交易信息不一定先于后边的分叉区块交易信息,交易信息的有效性要由投票算法来决定,区块投票算法很快,再加上它将 所有分叉区块 都包含进来,也就没有了比特币所面临的 分叉风险 (等待6个区块),交易确认时间可以达到10秒。
至此,和比特币相比,SPECTRE对应的DAG区块链有三个特点:
SPECTRE和PHANTOM是两个完整的独立的协议,不是一个对另一个的补充。
?? 诚实区块在考虑网络最大延迟下,经过一定时间一定会传遍整个网络,一定会被后边的区块所指向,诚实节点在产生新区块时也一定会指向自己所知道的末端区块。
??通过对 区块指出去的边和指向该区块的边 进行分析,也就是区块的 连通度 ,当考虑最大的网络延迟,连通度会有一个 极限值K ,低于该值的区块可以被认定为恶意区块,在排序中要处于 劣势 。
??至此,PHANTOM协议实现了对DAG的 线性排序 ,通过线性顺序就可以提取 无冲突交易集 ,进而提取 可信交易集 ,虽然耗时较长,满足智能合约的要求。
??CONFLUX协议下产生的区块链如上(图2),接下来对其进行线性排序,排序算法如下:
??至此,CONFLUX对DAG所有区块产生一个 线性顺序 ,进而可以对区块内交易信息排序,产生 无冲突交易集 ,超过一定时间的无冲突交易组成 可信交易集 。 主链只是排序的标尺,作为分割时段的标准,CONFLUX包含所有分叉区块。
Inclusive论文
SPECTRE论文
PHANTOM论文
CONFLUX论文
DAGlabs 相关讲解视频合集 比特币的区块产生时间是大概多久
10分钟。
1、比特币区块的产生时间为什么是10分钟?
中本聪(比特币的发明者)自己决定的,区块的生产速率应保持每10分钟1个区块的平均平均速度,因为:区块链估计需要10分钟才能将最新的区块传播到全球所有节点。为了使区块链保持正确同步。如果以更快的速度生产区块,则地球另一端的某些节点可能无法足够快地追上最新交易数据,这可能导致节点不再正确对齐,从而导致“区块断裂”,这是区块链必须尽量避免以保持安全的基本措施。
2、那为什么时间短就不安全呢?
如果你把它改成1分钟,问题就来了——我们假设任何一个新的区块传遍网络需要2分钟。那么,如果10分钟产生一个区块,那么新区块在传播过程中没收到它的节点又生成了一个新区块的几率还不算大,因为毕竟只是全网平均产生区块时间的1/5。然而,如果1分钟产生一个区块的话,问题就大了——假设区块传输速度平均,那么几乎可以确定,在新产生的区块传输到一半的时候,还没收到这个区块的网络有很大可能性也生成了一个新的了。
于是,一个分叉就产生了。而这种情况是很可能会出现的,也就是说,这个网络里会长期存在至少一个分叉。这样的网络显然是不安全的,因为比特币的假设是“如果想要作弊,你得算赢所有的竞争者,也就是全网51%的算力。”但是,如果网络里常年有两个以上的分叉,说明全网的算力被分摊了,于是,想要作弊的话,只需要算赢一半的网络就够了,也就是25%算力。很显然,这样比特币的可靠性就降低了。比特币交易一天停好几次
自己好,明天来为自己关于比特币一天交易几次(比特币一天交易几次最好)很多人还不知道,往常让我们一同来看看吧
1.比特币是相似电子邮件的电子现金,交易双方需求相似电子邮箱的“比特币钱包”和相似电邮地址的“比特币地址”。
2.和收发电子邮件一样,汇款方经过电脑或智能手机,按收款方地址将比特币直接付给对方。
3.比特币交易规则:比特币是t+0交易,即当天可不限次买入卖出交易时间:比特币属于虚拟密码币,它的交易在全球范围内一周7天,一天24小时无休止交易,没有每日涨停跌停限制。
4.从交易的时间下去看,每天的清晨1点钟是比特币交易浮动最大的时间段。
5.比特币属于虚拟密码币,它的交易在全球范围内一周7天,一天24小时无休止交易,没有每日涨停跌停限制。
6.比特币交易是没有时间限制的,24小时交易,所以要学会自控风险。
上述文章形式就是为自己带来的关于比特币一天交易几次(比特币一天交易几次最好)解答,假设还有其他的疑问,请继续关心比特币的周期及区块链的周期是什么样的?
比特币区块确认时间多久一次
十分钟。因为为了确保比特币区块的安全,所以都是每隔一点时间进行确认,这样可以保证安全,一般的确认时间都是十分钟,你可以可以根据自己的情况进行延长。