浅谈中移链中插件的功能及使用

中移链是在满足我国信息化监管需求、合规可控的前提下,打造的中国移动区块链服务平台。它允许使用插件来扩展其功能,以适应各种不同的使用场景。

什么是中移链插件呢?如果把中移链比作一个操作系统,那么插件就类比于操作系统上的软件,软件通过安装、重启等方式来扩展操作系统的功能,类似的,中移链插件也是通过配置、加载来启用,扩展中移链功能。

01

功能介绍

中移链有哪些常用插件呢?我们以中移链一个版本为例,介绍一些插件及其具体功能:

1.chain插件:这个是链处理插件,它承载了链节点程序与区块链交互的基本功能,包括读取本地不可逆区块链基本信息、设置本地链检查点、设置本地链参数、设置可逆区块数据库参数、设置账户黑/白名单、设置智能合约黑/白名单、重载区块链初始状态文件,以及删除、重写、替换本地区块链数据 (包括开始、停止等动作) 。

2.chain_api插件:依赖于chain插件,它提供与外部调用链相关操作的接口服务。

3.net插件:这个是P2P网络插件,它承载了链系统的P2P网络中TCP/IP层相关功能,包括建立节点之间握手并互联;监听、发送、接收新交易请求;监听、发送、接收新区块请求;验证接收数据合法性。

4.net_api插件:依赖于net插件,它提供与外部调用及网络相关操作的接口服务。

5.http插件:这个是网络HTTP插件,它承载了链系统的P2P网络中HTTP层相关功能,包括监听、发送、接收新交易请求;验证接收数据合法性。

6.producer插件:这个是区块生产节点的功能插件,其中功能包括生产、打包新区块 数据;对新区块签名;对接收的区块进行验证,包括区块头合法性、签名合法性和交易合法性。

7.producer_api插件:依赖于producer插件,它提供与外部调用及区块生产节点相关功能的接口服务。

8.blockvault_client插件:该插件为当前版本新增,即从当前版本开始加入了blockvault功能,它主要使区块链能够实施行业标准的灾难恢复,以最大限度地延长生产者的正常运行时间。该插件允许块生产者将部署为单个逻辑生产者的两个或多个节点集群。如果其中一个节点出现故障,集群中的其他节点将继续运行,从而满足生产者在最小服务中断的情况下继续运行的某些保证。

9.http_client插件:定义了中移链网络HTTP层响应请求,并做相应的安全验证的客户端插件。

10.resource_monitor插件:用于监控节点的资源使用情况,并通过API接口提供资源使用情况的统计信息,方便开发者进行分析和调优。

11.history插件:定义了查询指定账户中指定公钥的所有历史交易记录的插件。

12.history_api插件:将history的功能暴露给由http插件管理的RPC API接口,提供对区块链数据的只读访问;因为该插件对服务器资源消耗较大,在当前版本已弃用,开发者可以采用state_history插件或者trace_api插件替代。

13.state_history插件:这个插件捕捉区块链状态的历史数据,又称为“状态历史插件”。

14.login插件:依赖于http插件,这个插件使用HTTP Basic Authentication  (HTTP  基 本认证) 来进行用户身份验证。

15.db_size_api插件:这个插件提供与外部调用及数据有关的接口服务。

16.trace_api插件:依赖于chain插件和http插件,这个插件提供了一些可以用来获取和分析节点操作的接口,比如获取区块链中的所有操作、获取交易的执行跟踪结果等等。

通过上面介绍,可以了解到中移链部分插件及其功能,开发者可以根据需要来选择插件,下面通过两个示例说明一下插件的开启和关闭。

02

使用说明

中移链插件开启很方便,在配置文件中以“cmeos.load(“插件名称”,{“相关参数”});”格式 配置插件,节点在启动时会读取配置文件进行初始化,在初始化过程中会加载已配置的插件,当初始化完成后,插件功能也正常开启。以下是一则开启插件的示例。

示例一,假设我们需要启动一个生产节点,开启http、net、chain、chain_api、producer和producer_api等6个插件,这些插件包含了网络、链处理及其接口服务、生产节点及其接口服务等功能,在配置文件中添加这些插件并配置相应的参数,然后启动节点。配置如下图:

如上图所示,在配置文件中,通过“cmeos.load(“插件名称”,{“相关参数”});”格式来启用http、net、chain、chain_api、producer、producer_api等插件,并设置插件相应的参数。

中移链插件关闭也方便,是在配置文件中移除插件的相关配置,并重启节点,因为重启会再次读取配置文件进行初始化,这样未配置的插件就不再被启用了。以下是一则关闭插件的示例。

示例二,假设eosio不再作为生产者进行出块,此时我们可以将eosio生产节点改造为 同步节点(即仅从其它生产节点同步区块,本身不生产区块) ,即在配置文件中移除producer和producer_api插件,然后重启节点即可,如下图所示:

如上图所示,此配置文件中,移除了producer和producer_api插件及其相关参数,重启节点后,节点不再具有生产区块的功能。

03

结尾

本文介绍了一些常见的插件功能,并提供了两个示例配置演示如何开启和关闭插件。

可见,中移链插件机制的灵活性为开发者提供了非常高的自由度,开发者可以选择和组合不同的插件,来适用不同的场景。

04

参考资料

[1]BSN开放联盟链:

https://opb.bsnbase.com/main/index

[2]EOSIO的GitHub源代码仓库:

https://github.com/EOSIO/eos/tree/v2.1.0/plugins

-END-

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

工作流引擎Flowable

这里写目录标题 1.Flowable基础1.1 入门学习 2.流程图设计器2.1 FlowableUI2.1.1 绘制流程图 1.Flowable基础 官方手册 1.1 入门学习 一、依赖 <dependencies><dependency><groupId>org.flowable</groupId><artifactId>flowable-engine</…

Android系统安全 — 6.2 Ethernet安卓架构

1. Android Ethernet架构介绍 整个Ethernet系统架构如下图所示&#xff1a; 以太网服务&#xff08;EthernetService&#xff09;的启动与注册流程&#xff1b;应用层调用使能ethernet功能的方法流程来分析&#xff0c;从应用层如何将指令一步一步传到底层kernel&#xff1b;…

阿里巴巴开源的Spring Cloud Alibaba手册在GitHub上火了

“微服务架构经验你有吗&#xff1f;” 前段时间一个朋友去面试&#xff0c;阿里面试官一句话问倒了他。实际上&#xff0c;不在BAT这样的大厂工作&#xff0c;是很难接触到支撑千亿级流量微服务架构项目的。但也正是这种难得&#xff0c;让各个大厂都抢着要这样的人才&#x…

docker-harbor私有仓库

一、Harbor概述 1、Harbor的概念 • Harbor是VMware公司开源的企业级Docker Registry项目&#xff0c;其目标是帮助用户迅速搭建一个企业级的Docker Registry服务 • Harbor以 Docker 公司开源的Registry 为基础&#xff0c;提供了图形管理UI、基于角色的访问控制(Role Base…

华为流程体系:IPD流程框架(限制版)

目录 前言 详细内容 专栏列表 CSDN学院课程地址 前言 今天主要来谈谈 IPD 体系的主体框架所涉及的一些相关内容。 其实关于 IPD 体系&#xff0c;我在之前的文章或课程中都有过不同程度的讲解。 但是&#xff0c;由于这个体系所涉及的面是非常广泛的。 这个时候就必须通…

sql总理论加实践

一、基础查询 DQL语法 SELECT 字段列表 1.设置别名 SELECT 字段1[别名],字段二[别名]......FROM 表名 WHERE 条件列表; 2.查询多个字段 SELECT 字段1,字段2,字段3......FROM 表名; SELECT * FROM 表名; 3.去除重复记录 DISTANT FROM 表明列表 WHERE 条件列表(条件…

利用etcd实现分布式锁

python etcd3模块的lock使用 观察lock的加解锁影响 在python中已经自带了分布式锁的实现方式&#xff0c;下面我们尝试一下加锁与解锁的流程 在运行该demo同时也对lock对应的key进行watch&#xff0c;观察其变化&#xff0c;注意python-etcd3在实现分布式锁的时候&#xff0…

【Python爬虫开发基础⑤】HTML概述与基本标签详解

专栏&#xff1a;python网络爬虫从基础到实战 欢迎订阅&#xff01;近期还会不断更新~ 往期推荐&#xff1a; 【Python爬虫开发基础①】Python基础&#xff08;变量及其命名规范&#xff09; 【Python爬虫开发基础②】Python基础&#xff08;正则表达式&#xff09; 【Python爬…

探秘华为交换机:端口类型全解析

在下列情况下&#xff0c;判断的一般方法是什么&#xff1f; 1.交换机某个端口下的用户丢包。 2.交换机下的所有用户都在丢失数据包。 3、用户反映网速缓慢 检查网络电缆&#xff0c;重做水晶头&#xff0c;检查用户的计算机网卡&#xff0c;并重新启动交换机。 这几种做法都能…

Flink 学习五 Flink 时间语义

Flink 学习五 Flink 时间语义 1.时间语义 在流式计算中.时间是一个影响计算结果非常重要的因素! (窗口函数,定时器等) Flink 可以根据不同的时间概念处理数据。 处理时间: process time System.currentTimeMillis()是指执行相应操作的机器系统时间&#xff08;也称为纪元时间…

Docker安全

一、Docker 容器与虚拟机的区别 1、隔离与共享 • 虚拟机通过添加 Hypervisor 层&#xff0c;虚拟出网卡、内存、CPU 等虚拟硬件&#xff0c;再在其上建立虚拟机&#xff0c;每个虚拟机都有自己的系统内核 • Docker容器则是通过隔离的方式&#xff0c;将文件系统、进程、设…

Redis入门 - Lua脚本

原文首更地址&#xff0c;阅读效果更佳&#xff01; Redis入门 - Lua脚本 | CoderMast编程桅杆https://www.codermast.com/database/redis/redis-scription.html Redis 脚本使用 Lua 解释器来执行脚本。 Redis 2.6 版本通过内嵌支持 Lua 环境。执行脚本的常用命令为 EVAL。 …

Spark01-Spark快速上手、运行模式、运行框架、核心概念

1 概述 Spark和Hadoop Hadoop HDFS(GFS:TheGoogleFileSystem)MapReduce总结&#xff1a;性能横向扩展变得容易&#xff0c;横向拓展:增加更多的计算节点来扩展系统的处理能力Hbase&#xff1a;分布式数据库 Spark Spark CoreSpark SQLSQL 方言&#xff08;HQL)Spark Streamin…

光伏电池局部遮阴下三种不同的工况对比MATLAB仿真模型

光伏电池局部遮阴下三种不同的工况对比MATLAB仿真模型及程序资源-CSDN文库https://download.csdn.net/download/weixin_56691527/87910311 模型简介&#xff1a; 建议使用MATLAB21b及以上版本打开&#xff01; 光伏阵列表面被局部遮挡时会产生热斑效应。为了防止太阳电池因热…

【Matter】Matter学习笔记1

文章目录 前言Matter协议架构1.Matter Over IPV62.Matter协议架构3.Matter标准协议架构 Matter网络拓扑结构Mesh组网1.单一网络拓扑2.星形网络拓扑 设备数据模型&#xff08;Date Model&#xff09;1.设备和端点&#xff08;Node、Endpoint&#xff09;2.节点角色&#xff08;N…

ADAudit Plus:保护企业内部IT安全的强大解决方案

随着企业数字化的推进&#xff0c;IT系统和数据安全变得比以往任何时候都更加重要。为了保护企业的机密信息和敏感数据&#xff0c;企业需要一种可靠的IT安全解决方案。在众多选项中&#xff0c;ADAudit Plus是一款备受赞誉的软件&#xff0c;为企业内部的IT安全提供了强大的支…

工业机器人运动学与Matlab正逆解算法学习笔记(用心总结一文全会)(二)

文章目录 机器人逆运动学※ 代数解、几何解&#xff0c;解析解&#xff08;封闭解&#xff09;、数值解的含义与联系○ 代数解求 θ 1 \theta_1 θ1​、 θ 2 \theta_2 θ2​、 θ 3 \theta_3 θ3​※参考资料 求解 θ 1 \theta_1 θ1​ 求解 θ 3 \theta_3 θ3​ 求解 θ 2 \t…

Unity核心7——2D动画

一、序列帧动画 &#xff08;一&#xff09;什么是序列帧动画 ​ 我们最常见的序列帧动画就是我们看的日本动画片&#xff0c;以固定时间间隔按序列切换图片&#xff0c;就是序列帧动画的本质 ​ 当固定时间间隔足够短时&#xff0c;我们肉眼就会认为图片是连续动态的&#…

【Java基础学习打卡11】Path环境变量的配置

目录 前言一、为什么配置环境变量二、如何配置环境变量三、JDK11的环境变量配置总结 前言 本文我们要知道为什么配置环境变量&#xff0c;自己思考不配置环境变量可以吗&#xff1f;JDK 11 如何配置环境变量。 一、为什么配置环境变量 原因很简单&#xff0c;就是方便命令的查…

1.5 掌握Scala内建控制结构(一)

一、条件表达式 &#xff08;一&#xff09;语法格式 if (条件) 值1 else 值2 &#xff08;二&#xff09;执行情况 条件为真&#xff0c;结果是值1&#xff1b;条件为假&#xff0c;结果是值2。如果if和else的返回结果同为某种类型&#xff0c;那么条件表达式结果也是那种…