当前位置: 首页 > news >正文

FISCO BCOS技术架构解析:从多群组设计到性能优化实践

 

目录

FISCO BCOS整体架构设计

多群组架构与数据隔离机制

交易流程与执行机制

安全架构与隐私保护

性能优化与压测实践

应用案例与生态工具


FISCO BCOS作为中国领先的金融级开源联盟链平台,自2017年由金链盟开源工作组推出以来,已在政务、金融、医疗、版权等众多领域实现了规模化应用。本文将深入剖析FISCO BCOS的技术架构设计原理,详解其多群组架构如何实现数据隔离与隐私保护

FISCO BCOS整体架构设计

FISCO BCOS采用分层模块化设计,整体架构划分为四个逻辑层次,各层之间通过定义清晰的接口进行交互,形成了高内聚、低耦合的系统结构。这种设计不仅保证了系统的稳定性和可维护性,还提供了良好的扩展性,使平台能够适应不同行业场景的需求。

基础层作为整个系统的根基,提供了区块链运行所需的基础数据结构和算法库。这一层包含了密码学算法(如SM2、SM3、SM4等国密算法)、数据结构(如Merkle Patricia Trie)、序列化协议等核心组件。基础层的特点在于其可插拔的设计,开发者可以根据实际需求替换不同的算法实现,例如在金融领域采用国密算法以满足合规要求,而在国际业务场景中则可以使用更通用的加密算法。

核心层是FISCO BCOS的"心脏",实现了区块链的核心逻辑,可进一步分为链核心层和互联核心层两个子层。链核心层负责实现区块链的链式数据结构、交易执行引擎和存储驱动,确保交易能够被正确执行并持久化存储。互联核心层则专注于网络通信,实现了P2P网络协议、共识机制和区块同步机制,保障网络中的节点能够高效、可靠地达成一致。核心层采用了多线程和异步IO等高性能编程技术,能够充分利用现代多核处理器的计算能力。

表:FISCO BCOS核心层组件与功能

组件类别主要模块核心功能性能指标
链核心层交易执行引擎执行智能合约、更新状态支持5000+ TPS
链核心层存储驱动数据持久化、快速检索支持RocksDB/MySQL
互联核心层P2P网络节点发现、消息广播万级节点连接
互联核心层共识机制区块验证、节点协作PBFT/Raft支持

管理层为系统运维和治理提供了必要的工具和接口,包括参数配置、账本管理和AMOP(Advanced Messages On Protocol)等。其中AMOP是FISCO BCOS的特色功能之一,它允许机构间在区块链网络之外建立安全的点对点通信渠道,适用于需要多次协商的业务场景管理层还提供了丰富的治理功能,如节点准入控制、权限管理和证书黑名单等,确保联盟链能够在多方参与的环境中安全、有序地运行。

接口层是系统与外部交互的桥梁,面向开发者提供了多种协议的RPC接口、SDK和交互式控制台FISCO BCOS支持JSON-RPC和WebSocket等多种通信协议,并提供了Java、Python、Go等主流语言的SDK,极大降低了开发者的学习成本。命令行交互控制台则集成了丰富的查询和管理功能,包括区块链状态查询、节点管理和合约部署调用等,同时还提供了Solidity到Java合约文件的编译工具,提升了开发效率。

FISCO BCOS的架构设计充分考虑了金融行业对性能、安全和合规的高要求。通过模块化的设计,各层可以独立升级和优化,而不影响其他组件。例如,在需要提升交易处理能力时,可以专注于优化核心层的交易执行引擎;当需要支持新的加密标准时,则只需在基础层进行相应调整。这种架构不仅使FISCO BCOS能够满足当前金融行业的需求,也为未来的技术演进留下了充足的空间。

多群组架构与数据隔离机制

FISCO BCOS创新性地提出了多群组架构设计,这是其区别于其他区块链平台的核心特性之一。多群组架构允许在同一区块链网络中创建多个逻辑上独立的群组,每个群组相当于一个独立的账本,拥有自己的交易流、数据存储和共识过程,而不同群组之间则实现了严格的数据隔离。这种设计完美解决了联盟链场景中不同业务间的隐私保护需求,同时避免了搭建多条物理链带来的运维复杂度。

多群组架构的典型应用场景可以通过一个案例来说明:假设机构A、B、C共同构建了一个区块链网络来运行业务1,随后机构A和B需要启动业务2,但希望业务2的相关数据和交易处理不被机构C感知。在传统的FISCO BCOS 1.3系列系统中,机构A和B需要重新搭建一条独立的区块链来运行业务2,导致运维管理员需要同时维护两条链和两套端口配置。而在FISCO BCOS 2.0及更高版本中,机构A和B只需新建一个群组来运行业务2即可,运维管理员仅需维护一条物理链,大大降低了运维复杂度

表:单链架构与多群组架构对比

对比维度传统单链架构FISCO BCOS多群组架构优势分析
隐私隔离所有数据全局可见群组间数据完全隔离满足业务隐私需求
资源利用率每条链独立资源网络资源共享节省硬件成本
运维复杂度多链独立运维统一网络管理降低运维难度
性能扩展单链性能受限多群组并行处理提升整体吞吐量

多群组架构的技术实现依赖于三个关键机制:网络准入控制账本白名单数据存储隔离。在网络层面,所有节点共享底层P2P网络,但通过网络准入控制确保只有经过授权的节点才能加入特定群组.每个群组维护自己的账本白名单,网络层会根据白名单对消息进行过滤,只有属于同一群组的节点才会接收和处理相应的消息。例如,当node0的群组1向node1发送消息packetA时,网络层会将群组ID(1)添加到packetA的包头形成{groupID(1) + packetA}的数据包,接收方node1会检查源节点node0是否在群组1的白名单中,如果不是则拒绝该数据包。

在数据存储层面,每个群组拥有独立的存储空间,包括区块数据、状态数据和系统表等。FISCO BCOS采用"逻辑隔离,物理共享"的存储策略,不同群组的数据存储在同一个物理数据库中,但通过命名空间隔离确保不会相互干扰。这种设计既保证了数据隔离的安全性,又避免了为每个群组单独维护数据库带来的资源浪费。存储分为世界状态(State)和分布式存储(AMDB)两部分,世界状态包括MPTState和StorageState,负责存储交易执行的状态信息。值得注意的是,StorageState性能高于MPTState,但不存储区块历史信息,开发者可以根据业务

相关文章:

FISCO BCOS技术架构解析:从多群组设计到性能优化实践

目录 FISCO BCOS整体架构设计 多群组架构与数据隔离机制 交易流程与执行机制 安全架构与隐私保护 性能优化与压测实践 应用案例与生态工具 FISCO BCOS作为中国领先的金融级开源联盟链平台,自2017年由金链盟开源工作组推出以来,已在政务、金融、医疗、版权等众多领域实现…...

Ceph异地数据同步之- S3对象异地同步复制

#作者:闫乾苓 文章目录 关键组件说明数据流说明部署步骤配置主区域配置次要区域S3对象文件同步测试 关键组件说明 在Ceph RGW的多站点复制架构中,Realm、Zonegroup 和 Zone 是关键的组织结构,用于管理多站点的配置和数据同步 Realm(领域)&a…...

iOS按键精灵辅助工具在游戏开发中的创新应用

一、iOS自动化测试辅助工具 在移动游戏开发领域,iOS按键精灵类辅助工具不同于传统的安卓自动化方案,iOS环境下的自动化测试面临更严峻的技术挑战,但通过创新方法仍可实现精准控制。 # 基于图像识别的智能定位算法示例 def find_button(butt…...

3D案例丨多个3D工业相机拼接检测 开启360°新视界

在高速生产线上,经常需要在极短的时间内对工件进行全方位的外观检测,如:线缆直径和直线度检测、锂电池外观缺陷检测、铁轨截面尺寸检测等。 这需要传感器完整还原被测物的截面面轮廓形状,并获取精准的截面轮廓数据。但单一相机的…...

打分函数分类

在分子对接中,打分函数用于评估配体与受体结合的亲和力。不同类型的打分函数有各自的优势和应用场景。常见的打分函数主要分为以下几类: 1. 基于物理(力场)的打分函数 (Force/physics-field-based scoring functions) 这种打分…...

实践 DevOps 项目:使用 Terraform、Helm、SonarQube 和 GitLab CI/CD 在 AWS EKS 上实践全栈部署

在当今快节奏的软件开发领域,自动化至关重要。在本文中,我将向您展示如何构建一个全面的 DevOps 流水线,该流水线能够: 使用 Terraform 预置完整的 AWS 基础设施。部署一个包含私有子网和公共子网、RDS PostgreSQL 以及完整配置的…...

EFT干扰和共模干扰

EFT干扰本质上属于共模干扰的一种具体表现形式,但严格来说不能简单等同于共模干扰。以下从原理、特征及区别角度展开分析: 1. EFT干扰的原理 定义:EFT(Electrical Fast Transient,电快速瞬变脉冲群)干扰是…...

android 下提示 SQLITECIPHER driver not loaded

问题描述: 在android下出现 SQLITECIPHER driver not loaded 错误 解决办法: 在QT的Android目录下面放入 libplugins_sqldrivers_sqlitecipher_arm64-v8a.so...

[D1,2]回溯刷题

文章目录 组合 组合 回溯的基础结构 #组合总和 注意startIndex的更新是用i来更新的,不然会产生重复的组合...

使用 VBA 宏创建一个选择全部word图片快捷指令,进行图片格式编辑

使用 VBA 宏批量选择图片 ✅ 第一步:创建 .dotm 加载项文件 1、使用环境 office word 365,文件格式为.docx 图片格式为.PNG 2、创建 .dotm 加载项文件 打开 Word,新建一个空白文档。 按下 Alt F11 打开 VBA 编辑器。 点击菜单栏&#xff…...

SQL 关键字

SQL 包含许多关键字,这些关键字用于执行各种数据库操作。以下是主要的 SQL 关键字分类: 数据查询语言 (DQL) SELECT - 从数据库中选择数据 FROM - 指定要查询的表 WHERE - 指定查询条件 GROUP BY - 对结果集进行分组 HAVING - 对分组结果进行过滤 …...

从PPT到PNG:Python实现的高效PPT转图工具

从PPT到PNG:Python实现的高效PPT转图工具 在日常工作中,PPT(PowerPoint)文件是我们常用的演示工具。然而,有时候我们需要将PPT的内容提取为图片格式(如PNG)以便于展示或保存。手动将每一页PPT保…...

TCP和UDP协议

前言 TCP(传输控制协议)和UDP(用户数据报协议)是两种主要的传输层协议;它们在连接方式、可靠性、效率等方面有显著区别。 关键对比 差异总结 可靠性: TCP通过确认应答、重传等机制确保数据可靠传输&#…...

高并发内存池(三):PageCache(页缓存)的实现

前言: 在前两期内容中,我们深入探讨了内存管理机制中在 ThreadCache 和 CentralCache两个层级进行内存申请的具体实现。这两层缓存作为高效的内存分配策略,能够快速响应线程的内存需求,减少锁竞争,提升程序性能。 本期…...

使用pybind11开发可供python使用的c++扩展模块

在做紫微斗数程序的时候用到了padas库,不过也只用了它下面几个功能: 1、读入csv文件,构造DataFrame; 2、通过行列标题查找数据; 3、通过行标题读取一行数据。 用这几个功能却导入了pandas、numpy、dateutil、pytz等一堆库,多少有点划不来,于是想用c++开发一个实现这几…...

系统与网络安全------网络通信原理(5)

资料整理于网络资料、书本资料、AI,仅供个人学习参考。 传输层解析 传输层 传输层的作用 IP层提供点到点的连接传输层提供端到端的连接 端口到端口的连接(不同端口号,代表不同的应用程序) TCP协议概述 TCP(Transm…...

JavaScript防抖与节流

目录 防抖(Debounce) 一、防抖的定义 二、防抖的实现原理 三、防抖的代码实现 四、代码解析 五、使用示例 1. 输入框实时搜索(延迟执行模式) 2. 按钮防重复点击(立即执行模式) 六、总结 节流&…...

Java网络编程实战(多人聊天室-CS模式)

一、C/S模式核心原理 1.1 基本架构 C/S(Client/Server)模式采用客户端-服务器架构: 服务器端:持续运行,负责消息路由和广播客户端:用户交互界面,连接服务器进行通信通信协议:TCP&…...

Vue3.5 + Vite6.x 项目的完整 Stylelint 配置方案,支持 .vue/.html 内联样式、Less/SCSS/CSS 等多种文件类

Vue3.5 Vite6.x 项目的完整 Stylelint 配置方案,支持 .vue/.html 内联样式、Less/SCSS/CSS 等多种文件类型 一、完整依赖安装 npm install --save-dev stylelint stylelint-config-standard postcss-html # 解析 Vue/HTML 文件中的样式postcss-scss …...

23种设计模式Java版(带脑图,带示例源码)

设计模式 1、创建型 1.1、单例模式(Singleton pattern) 确保一个类只有一个实例,并提供该实例的全局访问点。 1.2、工厂方法(Factory Method) 它定义了一个创建对象的接口,但由子类决定要实例化哪个类。工厂方法把实例化操作推迟到子类。 1.3、抽象…...

mapbox高阶,使用graphology、graphology-shortest-path前端插件和本地geojson数据纯前端实现路径规划

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️graphology 插件1.3.1 ☘️概念1.3.2 ☘…...

【已解决】vscode升级后连接远程异常:“远程主机可能不符合XXX的先决条件”解决方法

vscode提示升级,每次都升了,突然某次关闭后无法连接远程,查询资料是因为从VS Code 1.86.1版本开始(2024年1月)要求glibc版本>2.28。 命令“ ldd --version”可查看glibc版本为2.27: rootXXXXXXX:~$ ld…...

Springboot整合JAVAFX

Springboot整合JAVAFX 实体与VO设计 pom.xml文件如下&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xs…...

【算法】——一键解决动态规划

前言 动态规划是一种高效解决​​重叠子问题​​和​​最优子结构​​问题的算法思想。它通过​​分治记忆化​​&#xff0c;将复杂问题分解为子问题&#xff0c;并存储中间结果&#xff0c;避免重复计算&#xff0c;从而大幅提升效率。 ​​为什么重要&#xff1f;​ ​​优化…...

Git使用与管理

一.基本操作 1.创建本地仓库 在对应文件目录下进行&#xff1a; git init 输入完上面的代码&#xff0c;所在文件目录下就会多一个名为 .git 的隐藏文件&#xff0c;该文件是Git用来跟踪和管理仓库的。 我们可以使用 tree 命令&#xff08;注意要先下载tree插件&#xff09…...

npm、nvm、nrm

NVM (Node Version Manager) 常见指令 NVM 是一个用于管理 Node.js 版本的流行工具&#xff0c;允许你在同一台机器上安装和切换不同版本的 Node.js。以下是 NVM 的常见指令&#xff1a; 安装与卸载 nvm install <version> - 安装指定版本的 Node.js 例如&#xff1a;…...

Java 文件内容转换为MD5哈希值

若要把读取到的 files 列表里的内容转换为 MD5 哈希值&#xff0c;你可以逐个遍历 files 列表中的元素&#xff0c;将每个元素的内容计算成 MD5 哈希值。 以下是一个完整的 Java 示例代码&#xff0c;展示了如何实现这一功能&#xff1a; import java.io.BufferedInputStream…...

未来郴州:科技与自然的交响诗篇

故事背景 故事发生在中国湖南郴州&#xff0c;描绘了未来城市中科技与自然共生共荣的奇妙图景。通过六个充满诗意的场景&#xff0c;展现雾能转化系统、立体生态书库、智能稻田等创新设计&#xff0c;编织出一曲人类智慧与自然韵律共鸣的未来交响。 故事内容 在东江湖的晨雾中&…...

UE5 运行时动态将玩家手部模型设置为相机的子物体

在编辑器里&#xff0c;我们虽然可以手动添加相机&#xff0c;但是无法将网格体设置为相机的子物体&#xff0c;只能将相机设置为网格体的子物体 但是为了使用方便&#xff0c;我们希望将网格体设置为相机的子物体&#xff0c;这样我们直接旋转相机就可以旋转网格体&#xff0…...

Ubuntu系统下的包管理器APT

Ubuntu系统下的包管理器APT 在Linux操作系统生态中&#xff0c;软件包管理工具是连接用户与系统功能的桥梁。Ubuntu作为基于Debian的流行发行版&#xff0c;其强大的包管理系统APT&#xff08;Advanced Packaging Tool&#xff09;为开发者与系统管理员提供了便捷的软件生命周…...

超级码科技发布镂空AI保险胶带,重塑包装防伪新标准

在酒类、物流、奢侈品、电子产品等领域&#xff0c;包装安全与防伪需求日益迫切。传统封箱胶带易被转移或重复利用&#xff0c;导致商品被仿冒的风险居高不下。 为此&#xff0c;超级码科技推出镂空型防揭AI数字身份保险封箱胶带——一款集结构防伪、信息追踪与增值服务于一体的…...

微软Exchange管理中心全球范围宕机

微软已确认Exchange管理中心&#xff08;Exchange Admin Center&#xff0c;EAC&#xff09;发生全球性服务中断&#xff0c;导致管理员无法访问关键管理工具。该故障被标记为关键服务事件&#xff08;编号EX1051697&#xff09;&#xff0c;对依赖Exchange Online的企业造成广…...

前端通信库fetch-event-source实现丰富的SSE

环境:SpringBoot3.4.0 + Vue3 1. 简介 SSE(Server-Sent Events)是一种基于HTTP的服务器向客户端单向推送实时数据的轻量级协议,配合浏览器原生EventSource API,可实现高效实时通信。前端通过创建EventSource对象订阅服务端流,自动处理连接、重试与数据解析;服务端设置C…...

JVM 中Minor GC、Major GC、Full GC 的区别?

Minor GC、Major GC 和 Full GC 是 Java 虚拟机 (JVM) 垃圾回收 (Garbage Collection) 中的不同类型的 GC 事件&#xff0c;它们在范围、触发条件、停顿时间等方面有所不同。 1. Minor GC (Young GC): 范围&#xff1a; 只针对新生代 (Young Generation) 进行垃圾回收。触发条…...

2747. 统计没有收到请求的服务器数目

文章目录 题意思路代码 题意 题目链接 思路 代码 class Solution { public:vector<int> countServers(int n, vector<vector<int>>& logs, int x, vector<int>& queries) {sort(logs.begin(), logs.end(), [](vector<int> &a, v…...

设计模式:抽象工厂 - 掌控多产品族的创建之道

一、什么是抽象工厂模式&#xff1f; 抽象工厂模式是一种创建型设计模式&#xff0c;提供一个接口&#xff0c;用于创建一系列相关或相互依赖的对象&#xff0c;而无需指定它们的具体类。 核心思想 1.定义多个产品的抽象接口&#xff0c;统一管理具体产品和工厂的创建逻辑。…...

图神经网络+多模态:视频动作分割的轻量高效新解法

一、引言 在智能监控、自动驾驶、人机交互等领域&#xff0c;准确理解视频中的动作序列至关重要。然而&#xff0c;传统方法依赖复杂的视觉模型&#xff0c;计算成本高且难以捕捉长时依赖。近期&#xff0c;一项名为 Semantic2Graph 的研究通过图神经网络&#xff08;GNN&am…...

技术与情感交织的一生 (五)

目录 初入“江湖” 分工 陌生 CraneOffice 内功 宝典 枪手 回到大二 通关 小聚 唱一首歌 初入“江湖” 分工 软件工作室是坐落在和平区宜昌道的一间民房&#xff0c;和我想象中的公司形象多少有些偏差。天津的道路有点凌乱&#xff0c;初次的时候不太好找&#xf…...

简单-快速-高效——模块化解析Pulid(实现不同风格下的人脸一致)

资源 论文&#xff1a;https://arxiv.org/abs/2404.16022 github&#xff1a;https://github.com/ToTheBeginning/PuLID?tabreadme-ov-file comfyui插件&#xff1a;https://github.com/sipie800/ComfyUI-PuLID-Flux-Enhanced 讲解参考 https://zhuanlan.zhihu.com/p/69684…...

XYZ to xyY 求解

免责声明&#xff1a;本文所提供的信息和内容仅供参考。作者对本文内容的准确性、完整性、及时性或适用性不作任何明示或暗示的保证。在任何情况下&#xff0c;作者不对因使用本文内容而导致的任何直接或间接损失承担责任&#xff0c;包括但不限于数据丢失、业务中断或其他经济…...

科技自然的协奏曲-深圳

故事背景 故事发生在中国广东深圳的现代城市环境&#xff0c;这里呈现出未来科技与自然生态共生的独特图景。没有具体的角色&#xff0c;却通过多样的场景描绘&#xff0c;展现出未来生活的活力与创新&#xff0c;反映出社会创新与人类情感的紧密结合。 故事内容 在未来的深…...

idea 创建 maven-scala项目

文章目录 idea 创建 maven-scala项目1、创建普通maven项目并且配置pom.xml文件2、修改项目结构1&#xff09;创建scala目录并标记成【源目录】2&#xff09;导入scala环境3&#xff09;测试环境 idea 创建 maven-scala项目 1、创建普通maven项目并且配置pom.xml文件 maven依赖…...

C++项目:高并发内存池_下

目录 8. thread cache回收内存 9. central cache回收内存 10. page cache回收内存 11. 大于256KB的内存申请和释放 11.1 申请 11.2 释放 12. 使用定长内存池脱离使用new 13. 释放对象时优化成不传对象大小 14. 多线程环境下对比malloc测试 15. 调试和复杂问题的调试技…...

【UE5】RTS游戏的框选功能+行军线效果实现

目录 效果 步骤 一、项目准备 二、框选NPC并移动到指定地点 三、框选效果 四、行军线效果 效果 步骤 一、项目准备 1. 新建一个俯视角游戏工程 2. 新建一个pawn、玩家控制器和游戏模式,这里分别命名为“MyPawn”、“MyController”和“MyGameMode” 3. 打开“MyGam…...

多图超详细:Docker安装知识库AI客服RAGFlow的详细步骤、使用教程及注意事项:

RAGFlow 介绍 RAGFlow 是一款基于深度文档理解的开源检索增强生成&#xff08;RAG&#xff09;引擎&#xff0c;通过结合信息检索与生成式 AI 技术&#xff0c;解决复杂场景下的数据处理和可信问答问题。其核心设计目标是提供透明化、可控化的文档处理流程&#xff0c;并通过多…...

docker compose安装智能体平台N8N

使用 docker volume create n8n_data 创建了一个名为 n8n_data 的数据卷。你通过 docker run 启动容器&#xff0c;映射了端口 5678&#xff0c;并挂载了 n8n_data 数据卷。 以下是对应的 docker-compose.yml 配置文件&#xff1a; version: "3.7"services:n8n:ima…...

FRP调用本地摄像头完成远程拍照

from flask import Flask, Response import cv2app Flask(__name__)# 基础文字回复 app.route(/) def hello_world():return <h1>你好啊世界</h1><img src"/camera" width"640" /># 摄像头拍照并返回图像 app.route(/camera) def captu…...

【Linux】39.一个基础的HTTP Web服务器

文章目录 1. 实现一个基础的HTTP Web服务器1.1 功能实现&#xff1a;1.2 Log.hpp-日志记录器1.3 HttpServer.hpp-网页服务器1.4 Socket.hpp-网络通信器1.5 HttpServer.cc-服务器启动器 1. 实现一个基础的HTTP Web服务器 1.1 功能实现&#xff1a; 总体功能&#xff1a; 提供We…...

蓝桥杯-小明的背包(动态规划-Java)

0/1背包问题介绍 0/1背包问题是经典的动态规划问题&#xff0c;具体描述如下&#xff1a; 解题思路&#xff1a; 输入数据 首先&#xff0c;程序通过 Scanner 从输入中读取数据&#xff1a; n 表示物品的数量。 v 表示背包的最大容量。 接着读取每个物品的重量和价值&#xff…...

(四十一)Dart 中的空安全与 `late` 关键字教程

Dart 中的空安全与 late 关键字教程 空安全简介 空安全&#xff08;Null Safety&#xff09;是 Dart 语言的一项重要特性&#xff0c;旨在帮助开发者避免空指针异常&#xff08;NullPointerException&#xff09;。空安全通过在编译时检查变量是否可能为 null&#xff0c;从而…...