13999 75

[水煮经管] 快速了解区块链背后的三项基本技术   [推广有奖]

企业贵宾

巨擘

0%

还不是VIP/贵宾

-

威望
4
论坛币
624047 个
通用积分
147.0356
学术水平
918 点
热心指数
988 点
信用等级
842 点
经验
398692 点
帖子
9795
精华
48
在线时间
17322 小时
注册时间
2014-8-19
最后登录
2022-11-2

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

   快速了解区块链背后的三项基本技术

blockchain_2-100665006-large.jpg


作者  Thijs Maas

编译  Mika

本文为 CDA 数据分析师原创作品,转载需授权


如果问10个人"什么是区块链技术?",你可能会得到10个不同的答案。真正理解区块链的最佳方法是逐步了解当中的基本技术。


因此在本文中,我将介绍区块链技术的三个主要组成部分:区块链本身、点对点网络和共识机制。一旦缺少任何一个部分,比特币将无法存在。首先让我们看到区块链。


# 区块链(blockchain)


简而言之,区块链只是数据结构化的一种方式。区块链是分类账:记录账务记录的文件。


可以把这个文件理解为一本永不会完成的书。


书上的每一页都记录着信息,同时在底部标有页码。通过页码,你马上可以知道该页面所属的位置,比如49页显然位于48页与50页之间。


就像页面一样,区块也都充满了信息。尽管区块没有确切的编号,但它们附有一个时间戳,具有与编号相同的功能。一个新的区块总是加在具有最新时间戳的区块之后。因此形成了链。


区块链很棒的一点时,当中使用了加密技术,因此当书中某一页的信息发生改变时,我们都会注意到。该属性使区块链成为很好的数据结构,用来跟踪记录任何有价值的事物。


1.jpeg


区块链的用例


在比特币的区块链中,区块包含比特币的交易信息。区块中记录了谁发送给谁多少比特币。


由于区块链从一开始就被用于跟踪所有比特币的流向,因此通过检查分类账可以明确谁在某个时间拥有哪些比特币。在任何时间内" 谁拥有多少"就是所谓区块链的当前"状态"。


交易只有在包含到区块中,并被添加到区块链中才会发生,因此,当一个区块被添加到区块链中时,区块链的状态就被更新。毕竟,比特币发送了移动。


这意味着如果我想验证某人是否真的对我做了交易,我必须能够检查区块链的状态。为了做到这一点,分类帐必须是公开的。这里就需要用到点对点网络。


# 点对点网络(peer-to-peer networks)


为了将区块链作为交易数据的分类帐,我必须要检查区块链,查看是否有人对向我的账号或钱包进行了交易。


如果区块链仅存储在一台计算机上,并且恰好被关闭了,那么这是很烦人的。因此,区块链的当前状态需要能够下载、同步并能被全球的计算机所提供。


这些计算机被称为"节点",它们在点对点网络中运行,用来确保区块链的安全性和最新性。每个节点都存储着区块链完整的最新版本。每当添加新的区块时,所有节点都会更新其区块链。


使用点对点网络具有以下优点:


可以随时查看自己区块链的状态;

无需通过某一方查看区块链的真实状态;

无需依靠一台服务器的安全性去确保区块链是否安全;

不法分子必须同时攻击数千台计算机,而不是一台服务器;

区块链不会被删除,因为它必须被所有节点删除。


1_ef93BASjZ-Dgn1_3CY0Frw.jpeg


基于服务器的模型 vs 点对点网络


这很重要,但以上并不意味着区块链就足够安全,能够用于存储或交易任何有价值的事物。


例如,我如何知道区块链中的(交易)数据是正确的?如何知道区块中没有无效的交易?如果存在不同版本的区块链,我何如知道哪个显示了区块链的真实状态?


这些问题能够通过共识机制解决,这种机制是通过点对点网络实现的。


# 共识机制(consensus mechanism)


Napster公司早在1999年就使用了点对点机制。


区块链在比特币出现之前就已经存在。


比特币神秘的匿名创始人——中本聪,在白皮书中通过基于密码学的共识机制,他巧妙地将两者结合起来。共识机制允许点对点网络中的节点一起合作,而不必相互了解或信任。


"共识算法的目的是根据特定的状态转换规则,考虑到安全的更新状态,其中执行状态转换的权利分布在用户中,这些用户能够通过算法共同进行交易。"——以太坊创始人 Vitalik Buterin


如果你还是不太清楚,其实共识机制就是一系列规则,网络中的节点通过运行网络软件来达成一致。这些规则确保网络正常工作并保持同步。


共识协议规定:

如何将区块添加到区块链中;

区块何时被认为是有效的;

如何解决冲突。


## 添加区块


不同的区块链添加区块的方式各不相同。其中最广为人知的共识机制是比特币的工作量证明(Proof of Work )。


工作量证明的第一条规则是,平均每10分钟应该在区块链中添加一个区块。


促进这一过程是所谓的"挖矿"。试图在区块链中链添加区块的节点(称为"矿工")使用计算机的计算能力尝试解决密码"难题"。规则规定,只有这个难题被解决时,区块才能被链中到区块链中。


解决这一难题的矿工"挖掘"新的区块增加到区块链中,同时矿工会得到网络的奖励。预定数量的新币将被创建,并奖励给矿工,以及该区块中包含的所有交易的成本。


随后,所有矿工将开始挖掘下一个区块。


2.jpeg


比特币挖掘设备。为了获得足够的挖掘处理能力,你需要大量的GPU。


比特币的工作量证明不是唯一的共识机制。分布式账本中也常使用权益证明(Proof of Stake)。在基于权益证明的机制中,某人可以对他的币进行"下注",以便被选中从而添加下一个区块。从某种意义上相当于,一位赌徒说:"我用币打赌我正确添加了这个区块。" 如果他说谎就失去币。


关于哪种共识机制是最好的存在很大的争论。尽管如此,无论区块是如何创建的,网络中的其他节点仍需要决定该区块是否有效。


## 区块的有效性


当矿工解决这个难题并挖掘了这个区块时,网络中的所有节点将检查该区块是否有效,并将其添加到区块链的副本中。节点首先要对有效性达成一致。只有这样,网络才会同步并更新区块链的状态。


只有当遵循共识机制的规则时,节点才会将新的区块添加到区块链中。他们运行的软件将检查区块是否有效。无效的区块将被拒绝。


当然,区块与其中包含的交易有效性一致。以比特币为例,协议规定,如果没先从他人那个收到比特币,或者挖到比特币,那么你无法发送被特比。


换句话说,如果发件人者收到足够的比特币进行交易,节点软件将检查区块中的所有交易。为此,需要检查网络的状态。


3.jpeg


假设我已收到1比特币,我之后将其发送给Alice。接着我试图将相同的比特币发送给Bob。只要我的第一笔交易被添加到链中,所有节点都会更新区块链,从而得出我已经没有那个比特币了。那么我给Bob的交易将会被节点拒绝。节点软件发现该区块不遵循规则时,它们不会将该区块更新到区块链中。


规则还规定,交易只有在比特币所有者的进行数字签名时才有效。只有钱币的所有者才能对交易签字。因此,只有你可以花费你的比特币。


## 如何解决矛盾


在偶然的情况下,两名矿工可能同时向区块链中添加有效区块。想象一下,一部分节点接受了一个有效的区块,其他节点接受了另一个区块。前者包括我与Alice的交易,后者包括我与Bob的交易。现在同时存在两种不同的区块链状态!


我们将其称为(无意)的"分叉(fork)":区块链分成两个不同的链。Alice和Bob谁才收到了我的比特币?两条链中的哪一条是'真正的'区块链?


通常会通过一条简单的规则解决这个问题:最长的区块链获胜。


4.png


区块链分叉的可视化


当出现分叉时,一些矿工将开始在其中一条上进行挖矿,而另一些开始在另一条上进行挖矿。不可避免的是,一条区块链将比另一条拥有更多的矿工,因此添加区块的速度会更快。其他的矿工将换到较长的区块链上,那么分叉的区块链将会消亡。这对主区块链没有任何损失。


我们为什么知道这一直都会发生?


因为矿工是以自我利益行事的经济行为者。矿工没有兴趣对会消亡的分叉区块链进行挖矿。分叉区块链上的所有交易从未在主区块链上发生,这意味着在分叉链上挖矿的矿工不会因为其工作而获得奖励。


在极少数情况下,分叉链上可能产生大量的挖矿能力。这时则需要一段时间才能确定哪条是主区块链。一般认为,在6个区块链后确认交易是明智之举。


5.png


区块链分叉的可视化。一般不会超过5个区块。


在区块链中添加区块需要巨大的处理能力,以及最长的区块链取胜的规则,这保证了区块链的安全性。攻击网络的唯一方法就是回到区块链中的某个区块,进行分叉并从那里挖新区块。然而,要做到这一点,攻击者必须重新完成矿工的,并赶上主区块链。如果没有比整个矿工网络更多的计算能力,这几乎是不可能实现的。简单地说,这种操作所需的电力和GPU成本非常昂贵。


blockchain-and-the-supply-chain.png


原文链接:

https://hackernoon.com/3-steps-to-understanding-blockchain-8a285572daa3

广告图-区块链就业班.jpg


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:点对点网络 工作量证明 共识机制 数据结构 如何解决 区块链

已有 4 人评分经验 论坛币 热心指数 信用等级 收起 理由
心静如月 + 60 + 20 + 2 + 1 热心帮助其他会员
happy_287422301 + 100 + 2 鼓励积极发帖讨论
zl89 + 80 精彩帖子
np84 + 100 精彩帖子

总评分: 经验 + 340  论坛币 + 20  热心指数 + 4  信用等级 + 1   查看全部评分

本帖被以下文库推荐


https://www.cda.cn/?seo-luntan
高薪就业·数据科学人才·16年教育品牌
沙发
风从四面八方来 学生认证  发表于 2018-6-15 20:41:45 来自手机 |只看作者 |坛友微信交流群
widen我的世界 发表于 2018-6-15 15:16
快速了解区块链背后的三项基本技术
作者  Thijs Maas编译  Mika本文为 CDA 数据分析师原创作品,转载需 ...
智商捉急,感觉看起来还是有点费劲(#-.-)

使用道具

藤椅
夏日鸡鸡咕咕叫 发表于 2018-6-15 22:30:44 来自手机 |只看作者 |坛友微信交流群
widen我的世界 发表于 2018-6-15 15:16
快速了解区块链背后的三项基本技术
作者  Thijs Maas编译  Mika本文为 CDA 数据分析师原创作品,转载需 ...
又膨胀了 居然点开了这种文章

使用道具

板凳
L-long 发表于 2018-6-16 00:20:21 |只看作者 |坛友微信交流群
好东西,不过看起来还是有点费劲

使用道具

报纸
sdlinxj 在职认证  发表于 2018-6-16 05:47:58 来自手机 |只看作者 |坛友微信交流群
widen我的世界 发表于 2018-6-15 15:16
快速了解区块链背后的三项基本技术
作者  Thijs Maas编译  Mika本文为 CDA 数据分析师原创作品,转载需 ...
明了直观的解读

使用道具

地板
hifinecon 发表于 2018-6-16 08:29:39 |只看作者 |坛友微信交流群
block chain, way to go!

使用道具

7
gzgysr 发表于 2018-6-16 11:41:23 |只看作者 |坛友微信交流群

使用道具

8
林子涵 发表于 2018-6-16 14:26:34 来自手机 |只看作者 |坛友微信交流群
widen我的世界 发表于 2018-6-15 15:16
快速了解区块链背后的三项基本技术
作者  Thijs Maas编译  Mika本文为 CDA 数据分析师原创作品,转载需 ...
可以作为课外知识了解下

使用道具

9
lixingang1992 发表于 2018-6-16 19:18:29 来自手机 |只看作者 |坛友微信交流群
widen我的世界 发表于 2018-6-15 15:16
快速了解区块链背后的三项基本技术
作者  Thijs Maas编译  Mika本文为 CDA 数据分析师原创作品,转载需 ...
了解一下

使用道具

10
abraham1234 学生认证  发表于 2018-6-16 20:42:22 来自手机 |只看作者 |坛友微信交流群
很有帮助的帖子 感谢楼主

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加JingGuanBbs
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-25 19:01