pos共识机制比pow共识机制安全吗
1、科普Pos共识机制
今天给大家科普下夸克区块链中的POS共识机制到底是什么?PoS共识机制,中文翻译就是权益证明。与它其名的还有另一种共识机制:pow机制。
经过历史发展的证明,PoW机制存在一些缺陷,如在挖掘过程中浪费大量的资源,整个网络的处理效率很低等。早在2011年,就有人曾提出:“是否可以在 PoW的基础上,重新设计一种机制?”可以保留 PoW的优点,也可以解决它的问题"。因此 PoS的共识机制就诞生了,因此, PoS机制在共识层次上借鉴了许多 PoW机制的设计,比如区块设计、矿工选择、分叉处理、交易验证等。
PoS机制采用权益法核算,解决了网络效率低下、资源浪费以及节点间一致性等问题,简单地说,就是谁拥有更多的权益谁来说话。其原则如下:
说到PoW机制为何存在诸多问题,最大的原因在于其规则下造成矿工准入门槛低,每个人都可以成为一个出块节点,每个节点都可以为获得下个区块的记账权进行竞争,一个数据包要有那么多人来处理,必然会造成资源的浪费和低效。
而PoS机制就可以有效解决这个问题,这是因为在POS机制的规则下,提高了每个人成为节点的门槛,比如:虽然每个人都可以成为节点,但如果想成为出块节点获得记账权,就必须满足pos机制的一些规则,如质押一定数量的代币,或者持有一定数量的代币,才可以成为出块节点的候选人。
在满足这些条件之后,系统进行算法选择,选中其中一部分人成为有效的矿工,然后每隔一个周期,进行重新分配,并且这个过程不受人为控制,一切由系统算法决定,保证公平公开不被篡改,这样就可以避免了整个链被某个节点控制。
总结一句话就是PoW机制是每个人都可以成为矿工,而 PoS机制必须通过一系列的筛选后成为矿工。
poS机制的竞争原则在于,谁拥有更多的代币,谁就能更容易的获得记账权。获得记账权的矿工将他打包好的区块经过其他矿工验证,通过全网广播,确认没有问题后,这个区块才会被连接到链上,与全网其他节点的小账本同步,同时他还能得到相应的代币奖励。
简言之,整个过程就是:持币者以代币作抵押,得到记账权力,然后PoS共识会通过选择算法,按持币者的数量,从中选出出块矿工。采矿者在指定的高度上完成打包交易,生成新的区块,并广播它,然后由验证者对所广播的区块进行交易验证,通过验证后,区块得到确认。这就是 PoS共识机制完整的一轮过程。
PoS机制的优点是有效地解决 PoW协议中存在的资源浪费和低效问题。但它也还是存在一些缺点。举例来说, PoS机制中的初始代币分配是非常模糊的,如果初始代币分配失败,将很难形成后续的股权证明。比如,在系统进行算法选择时如果被黑客攻击,如果成功,选举结果就可能被操作。除开这个问题,pos机制还存在一个问题就是,可能会造成两极分化严重,持有代币多的人会更多的获得记账权,继而获得代币奖励,拥有代币少的人,很难去争夺记账权,造成强者恒强的局面。
总的来说,PoW机制和 PoS机制都是区块链上引用的主流机制,它们会携手带领区块链技术的进一步发展,虽然两者存在自身的一定局限性,但未来某一天,这些技术在不断变革创新的同时,必定铸造区块链行业的辉煌。
2、Gate.io芝麻开门如何理解POW、POS、DPOS共识机制?
在区块链的世界里,保证数字货币正常发行,交易确认,维护网络正常运行等,都离不开共识机制,目前最常见的便是 PoW,PoS,DPoS 三种模式。PoW,工作量证明机制。 最先运用在比特币挖矿中,提供算力越多的矿工,获得记账权的概率就越大。 这也是早期主流的挖矿方式,因为它算法简单,安全性比较高,但是随着挖矿难度,交易频次的增加,电力资源消耗过大,出块速度慢等缺点显现出来。无法满足现有的交易需求。
因此,PoS,权益证明机制诞生了。 PoS 按照币龄决定获得记账权的概率,币龄是指持币数量乘以持币天数,一旦获得记账权, 币龄就会被清空,相应也会得到挖矿奖励,然后再进行下一轮记账权的争夺。 这种机制不会产生能源消耗,加快了区块产出和交易确认的速度,提高了效率。 但是,PoS 也并不完美,比如拥有大量币的用户,越容易获得出块奖励,从而加大贫富差距。 最终导致过于中心化,这是目前 PoS 无法解决的。
所以,DPoS,股份授权证明机制也应运而生了。 它通过持币用户投票,选举节点进行出块和处理交易,更大的缩短了共识时间,并且还会分红给投票者和区块网络维护节点,作为他们支持和维护的奖励,优化了前两个机制存在的不 足。但是也会面临贿选而导致中心化的问题。
虽然每一种共识机制都有缺点,但都是为了解决区块链三大问题,扩展性,安全性,去中心 化而诞生,因此无优劣之分,都有价值。
3、区块链目前用到哪些共识机制?它们各自的优缺点和适用范围是什么_百度知 ...
目前主要有四大类共识机制:Pow、Pos、DPos、Pool1、Pow工作量证明,就是大家熟悉的挖矿,通过与或运算,计算出一个满足规则的随机数,即获得本次记账权,发出本轮需要记录的数据,全网其它节点验证后一起存储;
优点:完全去中心化,节点自由进出;
缺点:目前bitcoin已经吸引全球大部分的算力,其它再用Pow共识机制的区块链应用很难获得相同的算力来保障自身的安全;挖矿造成大量的资源浪费;共识达成的周期较长,不适合商业应用
2、Pos权益证明,Pow的一种升级共识机制;根据每个节点所占代币的比例和时间;等比例的降低挖矿难度,从而加快找随机数的速度。
优点:在一定程度上缩短了共识达成的时间
缺点:还是需要挖矿,本质上没有解决商业应用的痛点
3、DPos股份授权证明机制,类似于董事会投票,持币者投出一定数量的节点,代理他们进行验证和记账。
优点:大幅缩小参与验证和记账节点的数量,可以达到秒级的共识验证
缺点:整个共识机制还是依赖于代币,很多商业应用是不需要代币存在的
4、Pool验证池,基于传统的分布式一致性技术,加上数据验证机制;是目前行业链大范围在使用的共识机制
优点:不需要代币也可以工作,在成熟的分布式一致性算法(Pasox、Raft)基础上,实现秒级共识验证;
缺点:去中心化程度不如bictoin;更适合多方参与的多中心商业模式
在使用共识机制,保证数据一致性时的巨大优势(共识机制则是Ripple首先提出的,数据正确性优先的网络交易同步机制,在共识网络中,无论软件代码怎么变动,无法取得共识就无法进入网络,更不要提分叉了)。
——————————————————
PS:稍微自黑下,虽然共识机制绝对能确保任何时候都不会产生硬分叉。但是,这种机制的缺点也比较明显,那就是要取得与其他节点的共识,明显要比当前Bitcoin网络漫长的多。极端情况下,在Ripple共识机制网络中掉线的后果也是很恐怖的。
有可能你家停电一天,第二天整个系统就再也无法与其它Rippled节点取得共识了(共识机制事实上需要超过80%的节点承认了你的数据,你的提交才会被其它节点接受,否则就会被排它的拒绝连接),甚至只能清空自己全部500多GB数据重新同步才能连上其它Ripple节点。
所以目前来说,现有的Rippled端并不适合民用(商用的话影响就比较小,比如RL自己的Rippled节点托管在亚马逊云数据中心,长时间无响应是可以高额索赔的,而且那种地方除了大型灾害几乎不会断),这也是RL一直想改进的方面之一。
目前区块链的共识机制大致可以分为三类:pow,pos,dpos,pow即Proof of Work,工作量证明机制,在POW机制下为了获取记账权和激励,矿工必须通过一定量的工作量进行数学运算,谁最快最准计算出了答案,就获取到了记账权和奖励,这是以时间、资源为担保,确保记账工作的真实和有效性,POW是一种按劳分配的模式,算力越高、挖矿时间越长,获得的数字货币就越多了,比较典型的就是btc,btm,pos,Proof of Stake,权益证明机制,POS也称股权证明机制,是通过持币产生利息,从而对于验证人以及节点进行奖励,这里我们大家首先要了解一个概念,就是币龄.币龄等于币的数量乘以币持有的天数,因而你持有的币数量越多,持有天数越长,你获到的记账权和激励的概率就会越大啦!当你获得激励之后,你的持币天数就会清零,币龄也回被清空这样周而复始,比较有代表性的是量子链,关于dpos是什么,以及这些主要共识机制的利弊是什么,字太多了,可以看看这个视频,里面讲的比较清楚:喵懂区块链11期 | 不了解共识机制,何以谈区块链?
4、POW、POS共识机制的优缺点是什么啊?哪位大神科普下
随着区块链技术的发展和演变,包含了:POW、POS、DPOS、Pool验证池、DBFT、POC、POR等共识算法机制。今天,贝数区块链就和大家一起聊聊POW、POS、DPOS几个主流共识机制的相关知识。关注贝数区块链、从小白变大神!
POW:Proof of Work,工作证明。比特币在Block的生成过程中使用了此机制,找到合理的Block Hash需要经过大要得量尝试计算,计算时间取决于机器的哈希运算速度。POS:Proof of Stake,股权证明。简单来说,就是一个根据你持有货币的量和时间,给你发利息的一个制度,在POS模式下,持币有利息。DSC(动态权益)共识算法:公链项目Penta的独创。分三层:第一层进行代表选举,第二层通过三列筹钱算法挑选议员和观察员组成若干共识组,第三层从候选区块中通过散列抽签算法选取正式块。 知乎里面看看,回答的一大堆。 小白问题5、以太坊技术系列-以太坊共识机制
区块链的特点之一是去中心化。也就是节点会分布在各个地方组成分布式系统。各个节点需要对1个问题达成一致,理想情况下,只需要同步状态即可。如上图所示 B节点将a=1=> a=2的状态同步给 ACDE四个节点,这时系统中状态变为a=2, 但如果其中有恶意节点 AE 收到通知后把a=1=>a=3修改为错误的节点,这个时候大家的状态就不一致了,此时需要共识机制使系统中得到1个唯一正确的状态。
如上面说到分布式系统存在恶意节点导致系统中状态不一致的情况有1个比较著名的虚拟问题-拜占庭将军问题。
拜占庭将军问题是指,N个将军去攻打一座城堡,如果大于一定数量的将军同时进攻则可以攻打成功,如果小于则进攻失败。将军中可能存在叛徒。
这个时候有2种情况
1.如果2个叛徒都在BCDE中,那么共识算法需要让其余2个将军听从A的正确决策进攻城堡。
2.如果A是1个叛徒,共识算法需要让BCDE中剩余的3个忠诚将军保持一致。
这个问题有很多种解法,大家有兴趣可以自行查阅(推荐学习PBFT),我们重点来看看以太坊中目前正在使用的Nakamoto 共识和将要使用的 Casper Friendly Finality Gadget共识是如何解决拜占庭将军问题的。
说到Nakamoto共识和Casper Friendly Finality Gadget共识可能大家不太熟悉,但他们的部分组成应该都比较熟悉-POW(工作量证明)和POS(权益证明)。
POW或POS称之为Sybil抗性机制,为什么需要Sybil抗性机制呢,刚刚我们说到拜占庭将军问题,应该很容易看出恶意节点越多,达成正确共识的难度也就越大,Sybil攻击就是指1个攻击者可以伪装出大量节点来进行攻击,Sybil抗性是指抵御这种攻击能力。
POW通过让矿工或验证者投入算力,POS通过让验证者质押以太坊,如果攻击者要伪装多个节点攻击则必将投入大量的算力或资产,会导致攻击成本高于收益。在以太坊中保障的安全性是除非攻击者拿到整个系统51%算力或资产否则不可能进攻成功。
在解决完Sybil攻击后,通过选取系统中的最长链作为大家达成共识的链。
很多人平时为了简化将pow和pos认为是共识机制,这不够准确,但也说明了其重要作用,我们接下来分析pow和pos。
通过hash不可逆的特性,要求各个矿工不停地计算出某个值的hash符合某一特征,比如前多少位是000000,由于这个过程只能依赖不停的试错计算hash,所以是工作量证明。计算完成后其他节点验证的值符合hash特征非常容易验证。验证通过则成为成为合法区块(不一定是共识区块,需要在最长链中)。
以太坊中的挖矿算法用到2个数据集,1个小数据集cache,1个大数据集DAG。这2个数据集会随着区块链中区块增多慢慢变大,初始大小cache为16M DAG为1G。
我们先来看这2个数据集的生成过程
cache生成规则为有1个种子随机数seed,cache中第1个元素对seed取hash,后面数组中每个元素都是前1个元素取hash获得。
DAG生成规则为 找到cache中对应的元素后 根据元素中的值计算出下次要寻找的下标,循环256次后获得cache中最终需要的元素值进行hash计算得到DAG中元素的值。
然后我们再看看矿工如何进行挖矿以及轻节点如何验证
矿工挖矿的过程为,选择Nonce值映射到DAG中的1个item,通过item中的值计算出下次要找的下标,循环64次,得到最终item,将item中的值hash计算得到结果,结果和target比较,符合条件
则证明挖到区块,如果不符合则更换nonce继续挖矿。矿工在挖矿过程中需要将1G的DAG读取到内存中。
轻节点验证过程和矿工挖矿过程基本一致,
将块头里面的Nonce值映射到DAG中的1个item,然后通过cache数组计算出该item的值,通过item中的值计算出下次要找的下标,循环64次,得到最终item,将item中的值hash计算得到结果,结果和target比较,符合条件则验证通过。轻节点在验证过程中不需要将1G的DAG读取到内存中。每次用到DAG的item值都使用cache进行计算。
以太坊为什么需要这2个不同大小的数组进行辅助hash运算呢,直接进行hash运算会有什么问题?
如果只是进行重复计算会导致挖矿设备专业化,减少去中心化程度。因为我们日常使用的计算机内存和计算力是都需要的,如果挖矿只需要hash运算,挖矿设备则会设计地拥有超高算力,但对内存可以缩小到很小甚至没有。所以我们选用1G的大内存增加对内存访问的频率,增加挖矿设备对内存访问需求,从而更接近于我们日常使用的计算机。
我们看看在Nakamoto共识是如何解决拜占庭将军问题的。首先看看区块链中的拜占庭将军问题是什么?
区块链中需要达成一致的是哪条链为主链,虽然采用了最长链原则,但由于分叉问题,还是会带来拜占庭将军问题。
本来以太坊pow目标是抵抗51%以下的攻击,但如上图如果恶意节点沿着自己挖出的区块不断挖矿,由于主链上有分叉存在,恶意节点不需要达到51%算力就可以超过主链进而成为新的主链,为此以太坊使用了ghost协议给上图中的B1和C1也分配出块奖励,尽快合并到主链中,这样主链长度(按照合并后的总长度算,长度只是抽象概念,以太坊中按照区块权重累加)还是大于恶意节点自己挖矿的。
网络中的用户通过质押一定数量的以太坊成为验证者。每次系统从这些验证者从随机选择出区块创建者,其余验证者去验证创建出的区块是否合法。验证者会获得出块奖励,没有被选中的区块不进行验证则会被扣除一定质押币,如果进行错误验证则会被扣除全部质押币。
如上图,权益证明在每隔一定区块的地方设置一个检查点,对前面的区块进行验证,2/3验证者通过则验证通过,验证通过则该区块所在链成为最长合法链(不能被回滚)。
我们简化地只分析了权益证明本身,在以太坊中权益证明较为复杂的点在于和分片机制结合在一起时的运行流程,这部分会在后面单独将分片机制的一篇文章中详述。
本篇文章主要讨论了共识机制是解决分布式系统中的拜占庭将军问题,以及分析了以太坊中的共识机制一般包括最长链选择和一种sybil抗性机制(pow或pos)。重点分析了pow和pos的流程以及设计思想。后续将开始重点讨论智能合约的部分。

转载请带上网址:http://www.pos-diy.com/posjifour/278529.html
- 上一篇:云闪付如何看pos机是否跳码
- 下一篇:pos机流水不显示对方账户
相关文章推荐
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 babsan@163.com 举报,一经查实,本站将立刻删除。