eos源码赏析(八):EOS智能合约入门之区块生产

2023-12-29 06:30

本文主要是介绍eos源码赏析(八):EOS智能合约入门之区块生产,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

插件初始化

 区块的生产是在producer_plugin里面实现的,和其他所有插件一样,插件初始化的时候从配置文件中读取相关参数如:私钥相关、区块产生相关、交易设置相关等参数并写到内存中去,接下来会使用到。和所有其他插件的初始化一样,大都是从配置文件中读取,然后根据关键字去匹配,匹配成功则写入内存,代码不再粘贴。

C++Tips

在插件启动的时候会调用on_block()函数,在这个函数中会将区块生产者集合和已激活区块生产者集合求交集,在这里使用了std::set_intersection,如下图所示:

 

        下面通过一个简单的例子来介绍下std::set_intersection函数的功能及用法,我们知道射雕三部曲中主线人物之间的关系一直是串联起来的,如郭靖黄蓉夫妇不仅在《射雕英雄传》一书中侠肝义胆,在《神雕侠侣》一书中更是完美阐释了侠的本义:侠之大者,为国为民。

        两本书中都有郭靖黄蓉夫妇,而神雕中没有杨康,射雕中没有张三丰,我们可以使用std::set_intersection来求两者的交集,如下图所示,打印结果为两本书中都存在郭靖和黄蓉,类似的std::set_union可以求两个集合的并集,std::set_different可以求两个集合的差集。

 

插件启动        

 

        言归正传,插件启动的时候会先从数据库中获取上一次最后一个不可逆区块的id并根据这个id从数据库中获取这个区块的相关信息。如图中所示,我上一次产生区块的id为142,代码断点调试可以看到这个lib_num为142且lib为142对应的区块相关信息。然后就开始了循环产生区块的过程,也就是我们最开始启动nodeos那一串串的打印。

 

在上图中调用了schedule_production_loop()之后会调用start_block()函数,由此开始产生区块。

 

在产生区块之前,首先调用获取上一个区块状态的指针,为了方便看到这个状态中都包含有什么,我们可以看到block_header_state结构体中包含有哪些内容,BM在注释中说到这个结构体定义了一些(尽可能少的)状态去验证区块产生或交易的参数。其中包含有DPoS共识机制下不可逆的区块个数,BFT-DPoS共识机制下不可逆的区块个数等参数,并实现了诸如设定新的区块生产者set_new_producer和set_confirmed等函数。

很遗憾的是本来上篇文章介绍完共识机制,本篇准备结合源码分析下BFT-DPoS的,然而源码中似乎并未涉及到BFT-DPoS,整个区块产生和验证过程中均未提到,且通过block_header_state的调试结果来看dpos_irreversible_blocknum是正常的也就是产生的区块均使用dpos区块做了不可逆的验证,但是bft_irreversible_blocknum的结果一直是0,不管产生多少区块,这个结果都是0。当然这是因为我部署了本地单节点的测试环境,无法说明问题,下一步在进行多节点部署的时候,继续去验证这个问题。

区块生产

 

现在让我们回到start_block上面来,看看区块产生的过程。在获取到上一个区块状态之后,有个延时的操作,如图中注释的,简单翻译过来就是:上次我们产生了一个区块,再产生下一个区块之前先等待50ms(也就是1/10个区块产生周期),如果区块生产者等不了50ms,那么就等500ms吧。那么这个等待是起什么作用呢?我们知道区块的产生、区块写入数据库、使用共识机制广播出去、区块经由其他节点的确认都需要耗时。如果在未完成以上操作之前就产生下一个区块,就可能产生分叉的现象。但是具体为什么设置50ms,我们还不得而知。此时设置产生区块的标志位为:producing,即开始产生区块。

 

在真正实现出块之前,还对该节点上有多少区块需要当前区块生产者确认进行了判断。如果区块生产者不属于当前节点,则直接舍弃。如果区块生产者属于当前节点但是从未产生区块,则也不需要确认。如果区块生产者属于当前节点且生产过区块且和上一个区块信息不同,则进行确认。这些都完成之后,开始调用chain.start_block(),并传入block_time(区块产生等待时间)及blcoks_to_confirm(等待确认的区块个数)。

在chain::controller类中开始start_block()如下图示:

这个pending直译过来是悬而未决的,在这里我们把它定义成一个待产生而未产生的区块,pending结构体中包含有以下内容,其中database::session是有关数据库操作的地方,这里我们不做过多分解,block_state_ptr其实就是取的上一个已产生区块的指针,action_receipt是当前区块接收到的action,在前面关于智能合约调试中,我们用到了相关的action。

 

而最后一个参数,block_status和block_state_ptr是不一样的,它指示当前待产生而未产生的区块的状态,这个状态量有四种:

 

        1)不可逆状态:这个区块已经被应用过且认为是不可逆的。

        2)合法状态:这个区块被一个合法的生产者认证且在该节点之前已经被应用过,但是是可逆的,也就是可能被认证的次数未达到应有的2/3以上节点的个数。

        3)完成状态:区块已产生,未在该节点上使用过且可逆。

        4)未完成状态:未完成的区块。

        这里区块pending初始化状态为未完成状态,且通过maybe_promote_pending()函数可以做出判断,返回false。pending初始化完成之后,通过push_trasncation()将产生的区块信息打包进去。

 

        关于push_transcation注释中已经说明:这个函数是在区块中创建一个新的交易的入口点,他将对交易的信息进行权限校验,同时决定是立刻执行还是延时执行这个交易。交易完成之后会将交易结束之后的回执信息打包到即将产生的区块中。至此,完成了一个区块的生产过程。在区块生成之后还进行了无效区块的删除、区块生产者权限更新等操作。

 

        本文主要介绍了区块产生的流程及我们所谓的区块中到底包含有哪些内容。当然,还未涉及到区块产生之后的操作,如入库、上链、广播等过程。接下来的文章我们会一步步的去分析。

            如果你对eos开发感兴趣,长按以下二维码,关注本公众号,一起学习eos开发.

 

    微信公众号

         有任何疑问或者指教请添加本人个人公众号,当然有对eos开发感兴趣或者金庸粉的也可以添加,备注eos开发或金庸,拉你进群一起交流

 

           个人微信帐号


 

这篇关于eos源码赏析(八):EOS智能合约入门之区块生产的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/548616

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL