一个完整的区块栗子
每个区块都有其索引,时间戳(Unix 时间),交易列表,证明 proof(稍后解释),以及前序区块的哈希值。
block = {
'index': 1,
'timestamp': 1506057125.900785,
'transactions': [
{
'sender': "8527147fe1f5426f9dd545de4b27ee00",
'recipient': "a77f5cdfa2934df3954a5c7c7da5df1f",
'amount': 5,
}
],
'proof': 324984774000,
'previous_hash': "2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824"
}
划重点:每个新建立的区块都包含上一个区块的哈希。这一重要概念使得区块链的不可变性成为可能:如果攻击者篡改了链中的前序区块,所有的后续区块的哈希都是错的。
关于 proof:
工作量证明算法(PoW)表述了区块链中的新区块是如何创建或者挖出来的。PoW 的目的是寻找符合特定规则的数字。对网络中的任何人来说,从计算的角度上看,该数字必须难以寻找,易于验证。这是工作量证明算法背后的核心思想。
比特币的工作量算法叫做 Hashcash。它和上面给出例子非常类似。矿工们争相求解这个算法以便创建新块。总体而言,难度大小取决于要在字符串中找到多少特定字符。矿工给出答案的报酬就是在交易中得到比特币。
而网络可以轻松地验证答案。
共识
区块链的核心是去中心化。但是如果要去中心化,怎么知道每个区块都在同一个链中呢?这就是共识问题,如果网络中不只一个节点,必须实现共识算法。
冲突:冲突指的就是一个节点的链和其他节点的不同。要解决冲突,我们制定了一个规则:最长有效链即权威。也就是说,网络中最长的链就是事实上正确的链。有了这个算法,就可以在网络中的多个节点中实现共识。