链客,专为开发者而生,有问必答!
此文章来自区块链技术社区,未经允许拒绝转载。
第一章:区块链基本知识
1.区块链概念
顾名思义,“区块链”是一个链表,这个链表由所有人共同维护和认可。
1.1.什么是区块链
区块链(Block chain)是一种分布式共享数据库(数据分布式储存和记录),利用去中心化和去信任方式集体维护一本数据薄的可靠性的技术方案。
如果把区块链作为一个状态机,则每次交易就是试图改变一次状态,而每次共识生成的区块,就是参与者对于区块中所有交易内容导致状态改变的结果进行确认。
1.2.区块链的特点
区块结构有两个非常重要的特点:
l每个区块的块头包含了前一区块的交易信息的压缩值,因此从创始块到当前区块形成了链条。
l每个区块主体上的交易记录是前一区块创建后、该区块创建前发生的所有价值交换活动。
1.3.区块链节点(以比特币网路为例)
任何机器都可以运行一个完整的比特币节点,一个完整的比特币节点包括如下功能:
•比特币钱包:允许用户在比特币网络上进行交易;
•完整区块链:记录了比特币历史上的所有交易,通过特殊的结构保证历史交易的安全性,并且用来验证新交易的合法性;
•矿工:通过记录交易及解密数学题来生成新区块,如果成功可以赚取奖励;
•路由功能:把其它节点传送过来的交易数据等信息再传送给更多的节点。
在比特币网络中的节点,除了路由功能以外,其它的功能都不是必须的,有的节点只有钱包功能,有的节点只负责挖矿。
1.4.新区块如何产生
•网络中的所有节点都会通过解数学题争取得到创建当前区块的权利;
•当一个节点解题成功后,就会把题的答案和构建的区块通过比特币网络发送给其它节点;
•其它节点只要验证通过了这个答案,就会立刻停止自己创建当前区块的努力,把传过来的区块加到本地区块链中,然后根据这个区块的区块头的哈希值填充下一个区块的区块头中的信息,立刻开始下一个区块的构建。
这样,网络中就完成了一个区块链中新区块的构建过程。
2.区块结构
整个区块数据包结构如下图:
具体字段含义描述如下:
子结构名称
作用说明
大小
神奇数
神奇数总是等于0xD9B4BEF9,作为区块之间的分隔符
4字节
区块大小
记录了当前区块的大小
4字节
数据区块头部信息
记录了当前区块的头部信息,其HASH值是下一个新区块的参数
80字节
交易计数
当前区块所记录的交易数
1-9字节
交易详情
记录了当前区块保存的所有交易细节
无特定参考值
备注:由于区块中的交易记录很多导致区块的数据很大,所以区块主体只负责记录交易信息,而区块链的大部分功能都是由区块头实现的。
2.1.区块头结构
子结构名称
作用说明
大小
版本号
数据区块的版本号
4字节
前一个区块的记录
记录了前一个数据区块的HASH值,当前区块的HASH值一定比它小
32字节
Merkle树的根值
记录了当前区块中所有交易Merkle树的根节点的HASH值
32字节
时间戳
记录了当前区块生成的时间,按照UNIX时间格式
4字节