2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

FISCO BCOS 中交易的一生

  • 2019-11-18
  • 本文字数:1400 字

    阅读完需:约 5 分钟

FISCO BCOS中交易的一生

交易——区块链系统的核心,负责记录区块链上发生的一切。区块链引入智能合约后,交易便超脱『价值转移』的原始定义,其更加精准的定义应该是区块链中一次事务的数字记录。无论大小事务,都需要交易的参与。


交易的一生,贯穿下图所示的各个阶段。本文将梳理交易的整个流转过程,一窥 FISCO BCOS 交易完整生命周期。


交易生成

用户的请求给到客户端后,客户端会构建出一笔有效交易,交易中包括以下关键信息:


发送地址:即用户自己的账户,用于表明交易来自何处。


接收地址:FISCO BCOS 中的交易分为两类,一类是部署合约的交易,一类是调用合约的交易。前者,由于交易并没有特定的接收对象,因此规定这类交易的接收地址固定为 0x0;后者,则需要将交易的接收地址置为链上合约的地址。


交易相关的数据:一笔交易往往需要一些用户提供的输入来执行用户期望的操作,这些输入会以二进制的形式被编码到交易中。


交易签名:为了表明交易确实是由自己发送,用户会向 SDK 提供私钥来让客户端对交易进行签名,其中私钥和用户账户是一一对应的关系。


之后,区块链客户端会再向交易填充一些必要的字段,如用于防交易重放的交易 ID 及 blockLimit。


交易的具体结构和字段含义可以参考编码协议文档


交易构造完成后,客户端随后便通过 Channel 或 RPC 信道将交易发送给节点。


交易池

区块链交易被发送到节点后,节点会通过验证交易签名的方式来验证一笔交易是否合法。若一笔交易合法,则节点会进一步检查该交易是否重复出现过,若从未出现过,则将交易加入交易池缓存起来。若交易不合法或交易重复出现,则将直接丢弃交易。


交易广播

节点在收到交易后,除了将交易缓存在交易池外,节点还会将交易广播至该节点已知的其他节点。


为了能让交易尽可能到达所有节点,其他收到广播过来的交易节点,也会根据一些精巧的策略选择一些节点,将交易再一次进行广播,比如:对于从其他节点转发过来的交易,节点只会随机选择 25%的节点再次广播,因为这种情况一般意味着交易已经开始在网络中被节点接力传递,缩减广播的规模有助于避免因网络中冗余的交易太多而出现的广播风暴问题。

交易打包

为了提高交易处理效率,同时也为了确定交易之后的执行顺序保证事务性,当交易池中有交易时,Sealer 线程负责从交易池中按照先进先出的顺序取出一定数量的交易,组装成待共识区块,随后待共识区块会被发往各个节点进行处理。


交易执行

节点在收到区块后,会调用区块验证器把交易从区块中逐一拿出来执行。如果是预编译合约代码,验证器中的执行引擎会直接调用相应的 C++功能,否则执行引擎就会把交易交给 EVM(以太坊虚拟机)执行。


交易可能会执行成功,也可能因为逻辑错误或 Gas 不足等原因执行失败。交易执行的结果和状态会封装在交易回执中返回。


交易共识

区块链要求节点间就区块的执行结果达成一致才能出块。FISCO BCOS 中一般采用 PBFT 算法保证整个系统的一致性,其大概流程是:各个节点先独立执行相同的区块,随后节点间交换各自的执行结果,如果发现超过 2/3 的节点都得出了相同的执行结果,那说明这个区块在大多数节点上取得了一致,节点便会开始出块。

交易落盘

在共识出块后,节点需要将区块中的交易及执行结果写入硬盘永久保存,并更新区块高度与区块哈希的映射表等内容,然后节点会从交易池中剔除已落盘的交易,以开始新一轮的出块流程。用户可以通过交易哈希等信息,在链上的历史数据中查询自己感兴趣的交易数据及回执信息。


本文转载自 FISCO BCOS 开源社区


2019-11-18 21:421572

评论

发布
暂无评论
  • 数字货币交易软件系统开发介绍(搭建)

    数字货币交易软件系统开发介绍,张森:I85薇2946电OIIO,数字货币交易系统软件开发简介,数字货币交易APP系统开发介绍,数字货币交易系统软件开发价格,数字货币交易系统软件开发案例,数字货币交易APP系统开发,数字货币交易系统开发方案,任何数据存入到这

    2021-10-20

  • 自适应熔断原理分析与源码解读

    熔断机制(Circuit Breaker)指的是在股票市场的交易时间中,当价格的波动幅度达到某一个限定的目标(熔断点)时,对其暂停交易一段时间的机制。此机制如同保险丝在电流过大时候熔断,故而得名。

    2022-09-07

  • 人工智能新范式,创新生产力崛起

    在人工智能的漫长历程中,我们见证了诸多伟大的里程碑,而当下,我们正站在一个新的历史节点。从CHATGPT到生成式AI(Generative AI),人工智能正在经历一场前所未有的革命。

    2023-09-07

  • 基于业务和平台理解数字营销概念

    数字营销产业链上最核心的角色就是就是受众人群,即浏览广告的用户,之所以称为受众人群,通常会把用户按照画像特点基于标签进行人群分类,数字营销的基本就是广告主把营销内容传递到潜在的消费者,并触发用户交易动作。

    2021-11-14

  • 国家发改委:利用区块链等新技术开展绿色电力交易试点

    据国家发改委官网消息,国家发改委、国家能源局近日正式复函国家电网公司、南方电网公司,推动开展绿色电力交易试点工作。复函的“技术可实现”分析部分,提及利用区块链等新技术。

    2021-09-07

  • 2021 年 7 月券商 App 行情刷新及交易体验评测报告

    最新券商APP评测报告出炉

    2021-08-12

  • DeFi:“三无模式”开辟金融新蓝海

    DeFi的意义不仅在于业务模式创新,站在社会价值的角度,DeFi的积极意义还在于金融普惠性和透明度的提升。而除此之外,DeFi还正在面向全球用户,创造一个无需准入、规则透明、规模极具想象力的金融统一大市场。

    2022-09-01

  • 网络:先有去中心化还是先有点对点?

    研究去中心化和点对点的关系可以让你更深刻地理解区块链网络。

    2021-08-02

  • C2C 交易软件系统开发(源码)

    C2C交易软件系统开发,张森:I85薇2946电OIIO,C2C交易系统软件开发,C2C交易系统软件开发资料,C2C交易软件系统开发介绍,C2C交易系统软件开发搭建,C2C交易系统软件开发案例,C2C交易系统开发搭建,随着短视频的强势崛起,越来越多的传统企业把目光瞄向了这

    2021-10-19

  • OpenSea 交易平台开发 NFT 系统部署技术

    NFT交易平台OpenSea市场上的交易是可以实现智能交易的控制,这意味着是在去中心化平台上进行的交易。而是通过保证公平交易来促进卖方获得这些报酬。OpenSea在双方之间进行交易。尽管如此平台交易仍没有在市场中以2.5%的价格与每个市场的竞争者达成交易。Open

    2023-04-07

  • ipfs 矿机是什么?ipfs 矿机挖出的币能交易吗?

    Filecoin主网上线快一年的时间,热度一直持续不下,引来币圈、链圈的投资者们关注入场,其中就有一部分小白投资者对IPFS挖矿的不太了解,所以今天就来聊一下IPFS挖矿:ipfs矿机是什么?ipfs矿机挖出的币能交易吗?

    2021-08-31

  • 场外 OTC 交易系统 APP 开发(案例)

    场外OTC交易系统APP开发,张森:I85薇2946电OIIO,场外OTC交易系统源码开发,场外OTC交易APP系统开发简介,场外OTC交易软件系统开发简介,场外OTC交易软件系统开发案例,场外OTC交易系统开发介绍,场外OTC交易系统软件开发搭建,区块练将有助于确保数据的安全

    2021-10-20

  • 着眼今生:揭秘区块链技术的发展现状

    这一讲,我们一起关注区块链技术的发展现状。

    2021-07-23

  • 区块链 + 数字人民币:怎样理解数字人民币体系架构?

    而伴随着数字人民币的发展,总有声音将其和区块链技术联系起来。

    2021-08-16

  • 存储:区块链的存储设计有定式吗?

    这一讲我会带你深入单个区块链节点,让你了解区块链存储是如何设计的。

    2021-07-28

  • 茶酒交易小程序开发难吗??

      茶酒交易系统开发介绍,找广州【裴经理:I35薇電35O7同号9592】,茶酒交易软件开发,茶酒交易APP开发,茶酒交易小程序开发,茶酒交易公众号开发,茶酒交易模式开发,茶酒交易源码搭建,茶酒交易平台开发,茶酒交易系统前景怎么样,茶酒交易系统开发需要多

    2021-08-30

  • 在 7 月 4 日,PoseiSwap 治理通证 $POSE 上线了 BNB Chain 上的头部

    在 7 月 4 日,PoseiSwap 治理通证 $POSE 上线了 BNB Chain 上的头部 DEX PancakeSwap(POSE/ZBC 交易对),在 $POSE 开盘交易的 10 分钟内,其最高涨幅达到了 2169.22%,所有的早期投资者基本都从中获得了不菲的收益,进一步引发市场的高度关注。

    2023-07-05

  • 共识(下):区块链领域的两类常用算法

    这一讲,我将为你梳理区块链中常用到的共识算法。

    2021-08-06

发现更多内容

区块链矿机挖矿游戏开发,区块链矿机游戏开发

v16629866266

腾讯基于 Flink SQL 的功能扩展与深度优化实践

Apache Flink

flink

官宣|焱融科技完成1.2亿元A+轮融资

焱融科技

分布式 存储 焱融科技 企业融资 创业公司

带你了解TCP/IP,UDP,Socket之间关系

赖猫

socket udp TCP/IP

android开发实战!面试的时候突然遇到答不上的问题怎么办?Android校招面试指南

欢喜学安卓

android 程序员 面试 移动开发

并发队列:ArrayBlockingQueue实际运用场景和原理

叫练

阻塞队列 LinkedBlockingQueue 并发队列 阻塞List ArrayBlockingQueue

KubeEdge@MEC:Kubernetes容器生态与5G的结合

华为云开发者联盟

5G 边缘计算 网络 kubeedge 5G MEC

2天完成17TB数据量迁移,华为云数据库是如何做的?

华为云开发者联盟

数据库 mongodb 大数据 智慧地图 地理信息服务

最最新版钱包tok量化区块链挖矿系统源码

luluhulian

你需要的Docker知识点都在这里了。

后台技术汇

28天写作 2月春节不断更

深入理解JVM中的类加载机制

Simon郎

JVM

盘点软件开发中那些有趣的边际效应

架构精进之路

认知提升 七日更 28天写作 2月春节不断更

webpack | 进阶用法4:如何进行构建速度和体积分析

梁龙先森

大前端 webpack 28天写作 2月春节不断更

高并发高性能服务器是如何实现的?

赖猫

c++ 高并发 linux开发 服务器开发 多线程高并发

怎么和小伙伴语音连麦,你造吗?

anyRTC开发者

ios android WebRTC sdk 语音通话

Elasticsearch Document 查询内部原理

escray

七日更 28天写作 死磕Elasticsearch 60天通过Elastic认证考试 2月春节不断更

资本市场发展趋势学习笔记

JiangX

28天写作

混合云的五个优势

混合云

C/C++后台开发需要点亮哪些技能树||(鹅厂为例) Linux百里

赖猫

c++ Linux 后台开发 linux开发 服务器开发

收购环信、因Clubhouse股价飙升30%,

ToB行业头条

SpringBoot 接口幂等性的实现

xcbeyond

Spring Boot Java、 幂等性 28天写作

火出圈的Clubhouse,究竟有什么奥秘?

拍乐云Pano

flutter RTC 语音聊天室 社交APP出海 clubhouse

【经验分享】如何融合CMMI与企业需求,自定义推进数字化转型

嘉为蓝鲸

DevOps 敏捷 持续交付 CMMI 能力成熟度模型

【LeetCode】双指针反转字符串

Albert

算法 LeetCode 2月春节不断更

程序员成长第二篇:如何快速入门

石云升

程序员 28天写作 2月春节不断更

浏览器同源策略,听说过么?

华为云开发者联盟

浏览器 jsonp CORS 同源策略 跨域

智汇华云 | ArSDN之多集群简介

华云数据

华云数据

京东扫描平台EOS—JS扫描落地与实践

京东科技开发者

大前端

DCache 分布式存储系统|Key-Value 缓存模块的创建与使用

TARS基金会

nosql 微服务 MySQL 高可用 分布式数据储存 TARS

android开发手册apk!Android开发者跳槽指南终获offer

欢喜学安卓

android 程序员 面试 移动开发

解读|2020年CNCF云原生调研报告

焱融科技

容器 云原生 存储 cncf

FISCO BCOS中交易的一生_开源_李陈希_InfoQ精选文章