Python & 区块链

一个完整的区块栗子

每个区块都有其索引,时间戳(Unix 时间),交易列表,证明 proof(稍后解释),以及前序区块的哈希值。

block = {
    'index': 1,
    'timestamp': 1506057125.900785,
    'transactions': [
        {
            'sender': "8527147fe1f5426f9dd545de4b27ee00",
            'recipient': "a77f5cdfa2934df3954a5c7c7da5df1f",
            'amount': 5,
        }
    ],
    'proof': 324984774000,
    'previous_hash': "2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824"
}

划重点:每个新建立的区块都包含上一个区块的哈希。这一重要概念使得区块链的不可变性成为可能:如果攻击者篡改了链中的前序区块,所有的后续区块的哈希都是错的。

关于 proof:

工作量证明算法(PoW)表述了区块链中的新区块是如何创建或者挖出来的。PoW 的目的是寻找符合特定规则的数字。对网络中的任何人来说,从计算的角度上看,该数字必须难以寻找,易于验证。这是工作量证明算法背后的核心思想。

比特币的工作量算法叫做 Hashcash。它和上面给出例子非常类似。矿工们争相求解这个算法以便创建新块。总体而言,难度大小取决于要在字符串中找到多少特定字符。矿工给出答案的报酬就是在交易中得到比特币。

而网络可以轻松地验证答案。

共识

区块链的核心是去中心化。但是如果要去中心化,怎么知道每个区块都在同一个链中呢?这就是共识问题,如果网络中不只一个节点,必须实现共识算法。

冲突:冲突指的就是一个节点的链和其他节点的不同。要解决冲突,我们制定了一个规则:最长有效链即权威。也就是说,网络中最长的链就是事实上正确的链。有了这个算法,就可以在网络中的多个节点中实现共识。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值