Derek解读Bytom源码-创世区块

作者:Derek

简介

Github地址:https://github.com/Bytom/bytom

Gitee地址:https://gitee.com/BytomBlockchain/bytom

本章介绍Derek解读-Bytom源码分析-创世区块

作者使用MacOS操作系统,其他平台也大同小异

Golang Version: 1.8

创世区块介绍

区块链里的第一个区块创被称为创世区块。它是区块链里面所有区块的共同祖先。

在比原链中创世区块被硬编码到bytomd中,每一个比原节点都始于同一个创世区块,这能确保创世区块不会被改变。每个节点都把创世区块作为区块链的首区块,从而构建了一个安全的、可信的区块链。

获取创世区块

./bytomcli get-block 0
{"bits": 2161727821137910500,"difficulty": "15154807","hash": "a75483474799ea1aa6bb910a1a5025b4372bf20bef20f246a2c2dc5e12e8a053","height": 0,"nonce": 9253507043297,"previous_block_hash": "0000000000000000000000000000000000000000000000000000000000000000","size": 546,"timestamp": 1524549600,"transaction_merkle_root": "58e45ceb675a0b3d7ad3ab9d4288048789de8194e9766b26d8f42fdb624d4390","transaction_status_hash": "c9c377e5192668bc0a367e4a4764f11e7c725ecced1d7b6a492974fab1b6d5bc","transactions": [{"id": "158d7d7c6a8d2464725d508fafca76f0838d998eacaacb42ccc58cfb0c155352","inputs": [{"amount": 0,"arbitrary": "496e666f726d6174696f6e20697320706f7765722e202d2d204a616e2f31312f323031332e20436f6d707574696e6720697320706f7765722e202d2d204170722f32342f323031382e","asset_definition": {},"asset_id": "0000000000000000000000000000000000000000000000000000000000000000","type": "coinbase"}],"outputs": [{"address": "bm1q3jwsv0lhfmndnlag3kp6avpcq6pkd3xy8e5r88","amount": 140700041250000000,"asset_definition": {},"asset_id": "ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff","control_program": "00148c9d063ff74ee6d9ffa88d83aeb038068366c4c4","id": "e3325bf07c4385af4b60ad6ecc682ee0773f9b96e1cfbbae9f0f12b86b5f1093","position": 0,"type": "control"}],"size": 151,"status_fail": false,"time_range": 0,"version": 1}],"version": 1
}

使用bytomcli客户端查询高度为0的区块信息。我们可以看到以上输出结果。

  • bits: 目标值,挖矿时计算的hash之后要小于等于的目标值则新块构建成功
  • difficulty: 难度值,矿工找到下一个有效区块的难度。该参数并不存储在区块链上,是由bits计算得出
  • hash: 当前区块hash
  • height: 当前区块高度
  • nonce: 随机数,挖矿时反复使用不同的nonce来生成不同哈希值
  • previous_block_hash: 当前区块的父区块hash值
  • size: 当前区块的字节数
  • timestamp: 出块时间
  • transaction_merkle_root: 创世区块的merkle树根节点
  • transactions: 当前块中的utxo交易

由于创世区块是第一个块,创世区块的父区块,也就是previous_block_hash参数,默认情况下为0000000000000000000000000000000000000000000000000000000000000000

时间戳timestamp为1524549600,时间为2018-04-24 14:00:00也就是比原链上主网的时间。

源码分析

获取区块链状态

** protocol/protocol.go **

func NewChain(store Store, txPool *TxPool) (*Chain, error) {// ...storeStatus := store.GetStoreStatus()if storeStatus == nil {if err := c.initChainStatus(); err != nil {return nil, err}storeStatus = store.GetStoreStatus()}// ...
}

当我们第一次启动比原链节点时,store.GetStoreStatus会从db中获取存储状态,获取存储状态的过程是从LevelDB中查询key为blockStore的数据,如果查询出错则认为是第一次运行比原链节点,那么就需要初始化比原主链。

初始化主链

** protocol/protocol.go **

func (c *Chain) initChainStatus() error {genesisBlock := config.GenesisBlock()txStatus := bc.NewTransactionStatus()for i := range genesisBlock.Transactions {txStatus.SetStatus(i, false)}if err := c.store.SaveBlock(genesisBlock, txStatus); err != nil {return err}utxoView := state.NewUtxoViewpoint()bcBlock := types.MapBlock(genesisBlock)if err := utxoView.ApplyBlock(bcBlock, txStatus); err != nil {return err}node, err := state.NewBlockNode(&genesisBlock.BlockHeader, nil)if err != nil {return err}return c.store.SaveChainStatus(node, utxoView)
}

初始化主链有几步操作:

  • config.GenesisBlock()获取创世区块
  • 设置创世区块中所有交易状态
  • 存储创世区块到LevelDB
  • state.NewUtxoViewpoint()用于临时小部分utxo状态存储集合
  • 实例化BlockNode,BlockNode用于选择最佳链作为主链
  • 保存最新主链状态

被硬编码的创世区块

** config/genesis.go **

func genesisTx() *types.Tx {contract, err := hex.DecodeString("00148c9d063ff74ee6d9ffa88d83aeb038068366c4c4")if err != nil {log.Panicf("fail on decode genesis tx output control program")}txData := types.TxData{Version: 1,Inputs: []*types.TxInput{types.NewCoinbaseInput([]byte("Information is power. -- Jan/11/2013. Computing is power. -- Apr/24/2018.")),},Outputs: []*types.TxOutput{types.NewTxOutput(*consensus.BTMAssetID, consensus.InitialBlockSubsidy, contract),},}return types.NewTx(txData)
}func mainNetGenesisBlock() *types.Block {tx := genesisTx()txStatus := bc.NewTransactionStatus()txStatus.SetStatus(0, false)txStatusHash, err := bc.TxStatusMerkleRoot(txStatus.VerifyStatus)if err != nil {log.Panicf("fail on calc genesis tx status merkle root")}merkleRoot, err := bc.TxMerkleRoot([]*bc.Tx{tx.Tx})if err != nil {log.Panicf("fail on calc genesis tx merkel root")}block := &types.Block{BlockHeader: types.BlockHeader{Version:   1,Height:    0,Nonce:     9253507043297,Timestamp: 1524549600,Bits:      2161727821137910632,BlockCommitment: types.BlockCommitment{TransactionsMerkleRoot: merkleRoot,TransactionStatusHash:  txStatusHash,},},Transactions: []*types.Tx{tx},}return block
}

mainNetGenesisBlock主要有如下操作:

  • 生成创世区块中的交易,默认就一笔交易
  • 设置块中的交易状态为false
  • 将创世区块设置为merkle树的根节点
  • 实例化Block块并返回

genesisTx函数生成创世区块中的交易,默认就一笔交易,一笔交易中包含input输入和output输出。

input输入:
输入中有一句话"Information is power. -- Jan/11/2013. Computing is power. -- Apr/24/2018."这是为了纪念Aaron Swartz的精神

output输出:
输出中我们看到consensus.InitialBlockSubsidy创世区块的奖励。总共140700041250000000/1e8 = 1407000412。也就是14亿个BTM币。

计算即权力

引用比原链创始人长铗的话:

4月24号,我们主网上线,信息即权力,2013年Jaruary11;计算即权力,2018年April24。这句话是为了纪念Aaron Swartz的精神,信息即权力可以视为互联网宣言,致力于信息自由传播,让公民隐私得到保护。计算即权力,致力于让资产自由的交易,自由的流动,让公民的财富得到保护,我觉得这是非常好的纪念。

转载于:https://www.cnblogs.com/bytom/p/9528070.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/365988.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用调试器进行事后跟踪

我最近一直在使用的大多数调试器的好功能是能够在断点上记录信息。 这对理解代码而无需修改是非常有用的,它涉及字节码修改。 让我们考虑一下这种非常琐碎且效率低下的函数实现,以返回斐波那契数列中的第n个数字。 public class Fib {public long fib(…

链表排序c++代码_[链表面试算法](一) 链表的删除-相关题型总结(6题)

在数据结构的最高层抽象里,只有两种结构,数组和链表。这两种结构,是所有其他数据结构实现的基础。队列和栈,可以用链表和数组来实现。图,可以用邻接表和邻接矩阵来实现,其中,邻接表就是链表&…

JS原生方法实现jQuery的ready()

浏览器加载页面的顺序: 1、 解析HTML结构 2、 加载外部脚本和样式表文件 3、 解析并执行脚本代码 4、 构造HTML DOM模型ready() 5、 加载图片等组件 6、 页面加载完毕onload() ready事件是在DOM模型构造完毕时触发 load事件是在页面加载完毕后触发 function…

程序员高效工具列表

FQ必备 *** 文件管理器 wox 或者 Listary , everything 截图软件 Snipaste 下载器 Fish 冰点 Markdown 工具 Typora 图床工具 PicGo 思维导图 Xmind 抓包工具 Wireshark 协议工具 Fiddler 接口测试工具 PostMan 剪切板工具 Ditto 害怕截图丢失? 博客园…

c语言如何空格键返回主菜单,C语言中scanf函数与空格回车的用法说明

众所周知,C语言中的scanf函数的作用是从标准输入设备(通常是键盘)读取输入值,并存储到参数列表中指针所指向的内存单元。下面从几个方面说一下一些稍微细节的东西。下面的实验都在vc6.0中通过。1、scanf的返回值scanf通常返回的是成功赋值(从标准输入设备…

Linear_algebra_03_矩阵

1. 矩阵的线性运算: 2.1 矩阵的乘法:Xik * Ykj Zij 2.2 矩阵乘法性质: 3.1 矩阵的幂次方运算 3.2 矩阵转置的运算律 3.3 方阵运算 4 分块矩阵的运算 5. 矩阵的初等变换 5.1 单位矩阵I经过一次初等变换所得到的矩阵称为初等矩阵. 5.2 初等矩…

在Activiti中执行自定义查询

(这可能最终会出现在Activiti 5.15版本的用户指南中,但是我已经想共享它了) Activiti API允许使用高级API与数据库进行交互。 例如,对于检索数据,查询API和本机查询API的用法很强大。 但是,对于某些用例&a…

jquery ready方法实现原理

先看这两句代码:window.addEventListener(load,loaded,false);document.addEventListener(DOMContentLoaded,loaded,false);总结:load事件是在页面所有元素都加载完后触发;DOMContentLoaded,它是指dom tree加载完就触发;防止了页面加载被堵塞…

js转json工具_菜鸟丨Egert3D微信小游戏发布与Unity工具使用

本次教程将会为大家介绍Egret3D工具导出Unity场景对象的使用,以及发布微信小游戏流程。让大家对Egret 3D有更加熟悉的了解。需求工具:1、Unity场景导出插件;2、微信开发者工具。导出插件的使用一、打开需要导出的Unity场景,并且把…

MySQL----示例知识点整理

示例语句: select count(0),hour(c.created_at) from behavior_client_view c join behavior_share son c.share_uuids.uuidwhere s.agent_uuid(select uuid from user where mobile12606666333 and deleted0)and DATE_FORMAT(c.created_at,%Y-%m) >DATE_FORMAT(…

c语言c1变成e并输出,【图片】(原创)用纯C变了个变色输出字符的程序。。。【c语言吧】_百度贴吧...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼#include#include#includemain(){char c;int i,j,k,l,m,n,o;int x,y;char c1;int a,b,d,e;x35;y8;textcolor(13);gotoxy(35,10),cprintf("photoshop2014");textcolor(11);gotoxy(20,11);cprintf(" My name is zhou …

OI杂记

从今天开始记录一下为数不多天的OI历程 8.25 上 今天举行了难得的五校联考,模拟noip,题目的解压密码竟然是$aKnoIp2o18$,对你没有看错!!! 7:50老师?啊啊啊啊,收不到题目啊&#xff0…

ebpf基础篇(二) ----- ebpf前世今生

bpf 要追述ebpf的历史,就不得不提bpf. bpf(Berkeley Packet Filter)从早(1992年)诞生于类Unix系统中,用于数据包分析. 它提供了数据链路层的接口,可以在数据链路层发送和接收数据.如果网卡支持混杂模式,所有的数据包都可以被接收,即使这些数据包的目的地址是其它主机. BPF最为…

Java,Steam控制器和我

您是否想过是否可以将现有的东西用于新的东西? 我看了一些所谓的“蒸汽控制器”(从现在开始为SC)的镜头,并看着我的游戏手柄。 问我自己是否有可能以类似蒸汽的方式使用它,我找到了一些Java库并创建了一个项目&#xf…

unknown column in field list_tf.feature_column的特征处理探究

1. 背景tf.estimator是tensorflow的一个高级API接口,它最大的特点在于兼容分布式和单机两种场景,工程师可以在同一套代码结构下即实现单机训练也可以实现分布式训练,正是因为这样的特点,目前包括阿里在内的很多公司都在使用这一接…

jQuery clearQueue

clearQueue()方法与clearQueue()方法结合&#xff1b; .clearQueue()可用于删除通过.queue()方法添加到通用jQuery序列的任何函数。 示例&#xff1a; <!DOCTYPE html><html><head><style>div { margin:3px; width:40px; height:40px;position:absol…

Docker设置HTTP代理

参考资料&#xff1a;为docker配置HTTP代理服务器 一、注释掉namesserver的配置 [rootnvwa ~]# cat /etc/resolv.conf # Generated by NetworkManager search apa.gad.schneider-electric.com nameserver xx.xx.xx.xx nameserver xx.xx.xx.xx 改为&#xff1a; [rootnvwa ~]# c…

C语言oj中a b怎么做,【HDUOJ】第1002题 A + B Problem II 纯C语言解法

【HUDOJ-1002】1.原题&#xff1a;Problem DescriptionI have a very simple problem for you. Given two integers A and B, your job is to calculate the Sum of A B.InputThe first line of the input contains an integer T(1<T<20) which means the number of tes…

截止到2013年,核心Java帖子

随着2013年即将结束&#xff0c;我最近发现了几篇与我认为“核心Java”知识有关的帖子。 该帖子列出了三个帖子&#xff0c;并提供了一个简短说明的论坛。 我这样做有两个目的&#xff1a;&#xff08;1&#xff09;帮助他人意识到这些优秀职位的存在&#xff1b;&#xff08;2…

jQuery 超屏加载

jQuery 超屏加载&#xff0c;当文档超出屏幕的高度时&#xff0c;加载最新下个列数据 $(window).scroll(function () {var height $(document).height(); //页面的高度var keheight $(window).height(); //浏览器可视的高度var sheight $(document).scrollTop(); //滚动的高…