Py学习  »  区块链

科普 | 极简科普篇——区块链是什么?

以太坊爱好者 • 5 年前 • 397 次点击  

-区块链是什么?(这张图是我用素描软件画的)-


如果你对区块链深感好奇,却又不知道它究竟是什么,这篇文章就是你的菜。本文旨在让你了解区块链是什么,因此在写作过程中简化了部分内容。如果能助你理解区块链技术是什么,那我的任务就完成了。

小贴士:为了更好地理解区块链技术,请不要忽略本文提到的图片。这些图片相当重要!


区块链是什么?



-区块链-

是的,区块链 = 区块+链条 = 一串(区块)

我们首先把区块链和转账系统进行类比。记住,区块链有很多用例,而转账系统只是其中之一。

假设,我从自己的账户里转了一部分钱到你的账户。在我进行这笔交易时,一定要有个地方写入交易信息。

这个地方就是区块

区块中,我们会写入如下信息:

  • 谁在转账给谁?

  • 交易金额

  • 签名等其他信息

public class Block {  public String data;  public String hash;  ... }

所以区块和银行支票类似,都是一种信息载体。

除信息(I)外,每个区块都有一个独一无二的哈希值(H)作为身份标识。哈希值(H)是一个很重要的概念。

交易越多,区块也会越多。

这些区块通过一根链条相互连接成了一个区块链。

为什么要让区块相互连接呢?

是为了保证信息的安全性。

连接方式:当前区块的哈希值取决于上一个区块的哈希值。

下面举个简单的栗子🌰。

假设我们有 3 个区块,包含如下信息:

  • 区块 1 包含的信息为 I1I1 的哈希值为 H1

  • 区块 2 包含的信息为 I2 ,I2 的哈希值为 H2

  • 区块 3 包含的信息为 I3 ,I3 的哈希值为 H3

H2 是由 H1 和 I2 结合起来算出的。同样地,H3 是由 H2 和 I3 结合起来算出的,依此类推。

-哈希值说明-

H2 = 某种加密函数(H1, I2)

H3 = 某种加密函数(H2, I3).

那 H1 从何而来?首先,我们要取一个默认值 H0 。

H1=某种加密函数(H0, l1),其中 H0 是个默认值。

-稳定的区块链-

到目前为止,上图的区块链是稳定的。

现在如果有人把区块 2 的信息 I2 改成 I2' ,I2 的哈希值 h2 改成 h2' ,其他区块保持不变。在这种情况下,区块链就会变成下图中的不稳定状态。

-不稳定的区块链-

区块链不稳定的原因如下:

  • H3 ≠ 某种加密函数(H2', I3),H3 的值发生了变化。

  • 用 H2' 代入公式重新得出H3' = 某种加密函数(H2', I3)

  • H4'H5'H6' 也以此类推。

修改后,这个区块链就会变得像下图一样稳定。

-稳定的区块链-

这样的话,所有修改要经过端对端修改和审核。那黑客入侵电脑修改数据也就没那么容易了。如果有黑客修改了数据,区块链就会变得不稳定,立马就会被发现。

   List blockList = new ArrayList();

我们将区块放在一个类似上图的列表中,这样已知当前区块所在 position (位置),很容易就能通过运行 blocklist.get(position — 1) 找到上一个区块。存储区块的方法有很多。

区块互连主要是为了保证安全性。


接下来深度科普区块链是什么


区块链是一个分布式的去中心化分类账,用来存储交易信息等数据,这些数据为整个区块链网络中的节点所共享

这么说是不是把区块链定义得太过复杂了?

不过不用担心。我来帮你剖析一下难点。


分类账

分类账是承载区块列表的主要记录载体。


存储数据

区块能存储数据(信息)。此处对数据的定义很广泛,可以是我们能想到的任何数据。我们就拿交易信息这一数据来举个例子。


分布式的去中心化分类账

数据处理通常由一个中心机器负责。但是区块链里有很多机器(因此它不是中心化的),且所有机器都是点对点相互连接。另外,这些机器维护的是同一本分类账。因此,区块链被称为分布式的去中心化分类账。

换句话说,因为同一区块链网络中的所有人都共享同一本分类账,所以说区块链是分布式的。每个人都有整个分类账的副本,一旦有什么东西添加进去,副本马上就会更新。


为整个区块链网络中的节点所共享

在区块链网络中,所有机器全都相互连接。每个节点(机器)都持有相同的分类账副本。这就意味着整个区块链网络中的节点都共享一本分类账。


区块链是如何运作的?


区块链的运作步骤:

  • 阿米特(Amit)想创建一个交易。

  • 阿米特创建了一个交易。

  • 阿米特将该交易提交到网络上。

  • 网络中的机器验证交易并予以批准。

  • 阿米特的交易被打包上链。

  • 更新后的区块链在全网广播。

  • 转账完成。

现在理解区块链的定义以及它的运作方式了吧。


既然区块链是分布式的,那它如何保证安全性呢?


区块链利用密码学来生成数字签名。提到数字签名,先要了解下私钥和公钥的概

念。

我们每个人都可以获得自己的私钥和别人的公钥。

私钥:只有所有者可以访问。

公钥:网络中的每个人都可以访问彼此的公钥。

假设我想创建一个交易。我用自己的私钥对信息进行加密来创建一个数字签名。

-数字签名-

然后我把交易(内含信息、公钥以及上图所示的数字签名)提交到网上进行审批。

-交易-

在这一过程中,网络会利用公钥来解密数字签名,并从签名中提取信息。

如果原信息与从上图所示的签名中提取出来的信息相匹配,就可以通过审批,否则就无法通过。

如果两个信息不匹配,可能是以下原因:

  • 原信息在中途被操控了。

  • 生成数字签名时所用的私钥与所提供的公钥不匹配。

这就是网络如何能发现篡改的方法。因此区块链是安全的。

这就是今天要讲的关于区块链的全部内容。请继续关注我的“循序渐进入门区块链”系列教程。

区块链学习愉快🙂



原文链接: 

https://medium.com/mindorks/what-is-blockchain-simplest-introduction-to-the-blockchain-764a468e1575
作者: Amit Shekhar
翻译&校对: 李丽 & 闵敏

本文由作者授权 EthFans 翻译及再出版。


你可能还会喜欢:

科普 | 区块链是什么鬼?

科普 | 以太坊到底是啥?

科普 | Vitalik: 25分钟认识以太坊(上)



今天看啥 - 高品质阅读平台
本文地址:http://www.jintiankansha.me/t/WH2np7IG9h
Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/24048
 
397 次点击