CN116010118A - 一种区块链节点的部署方法、装置及终端设备 - Google Patents
一种区块链节点的部署方法、装置及终端设备 Download PDFInfo
- Publication number
- CN116010118A CN116010118A CN202211548630.3A CN202211548630A CN116010118A CN 116010118 A CN116010118 A CN 116010118A CN 202211548630 A CN202211548630 A CN 202211548630A CN 116010118 A CN116010118 A CN 116010118A
- Authority
- CN
- China
- Prior art keywords
- main process
- upper layer
- information
- environment
- layer application
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Classifications
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Stored Programmes (AREA)
- Computer And Data Communications (AREA)
Abstract
本申请提供了一种区块链节点的部署方法、装置及终端设备,适用于数据处理技术领域,该方法包括:创建区块链节点对应的运行环境的主机驱动;调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程;其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。该方法通过该标准接口能够满足区块链节点在不同运行环境上进行部署,以及,该方法将运行环境从上层应用中分离,具有便于维护,具有较强的兼容性、适配性;该方法具有实用性及易用性。
Description
技术领域
本申请属于数据处理技术领域,尤其涉及区块链节点的部署方法、装置及终端设备。
背景技术
区块链作为一种基础设施,将区块链部署在不同的资源环境中,通常需要调整区块链底层从而适配不同的主机类型。在现有技术中,区块链业务代码与环境技术代码相互糅杂,耦合度高,开发人员进行排查定位复杂。
发明内容
有鉴于此,本申请实施例提供了一种区块链节点的部署方法、装置及终端设备,可以解决区块链业务与环境耦合度高、难以定位排查、适配性差的问题。
本申请实施例的第一方面提供了一种区块链节点的部署方法,包括:
创建区块链节点对应的运行环境的主机驱动;
调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;
调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程;
其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。
在第一方面的一种可能的实现方式中,在所述创建所述运行环境的主进程之后,所述方法还包括:
基于上层应用的设置指令,生成所述主进程的属性信息;所述属性信息用于指示所述上层应用执行业务操作。
在第一方面的一种可能的实现方式中,所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
接收所述上层应用调用所述标准接口输入的所述设置指令;
基于所述设置指令生成所述属性信息。
在第一方面的一种可能的实现方式中,所述属性信息包括网络路由信息;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
基于上层应用通过网络路由端口设置所述标准接口输入的所述设置指令,设置所述主进程的所述网络路由信息中的请求网络路由端口。
在第一方面的一种可能的实现方式中,在所述设置所述主进程的所述网络路由信息中的请求网络路由端口之前,所述方法包括:
通过所述主机驱动检测所述请求网络路由端口是否为占用状态;
若是,则输出报错信息;
若否,则输出所述请求网络路由端口的内部路由信息和外部路由信息;其中,所述网络路由信息包括所述内部路由信息和所述外部路由信息。
在第一方面的一种可能的实现方式中,所述属性信息包括环境变量;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的环境变量,并通过所述主机驱动将所述环境变量信息保存至本地。
在第一方面的一种可能的实现方式中,所述属性信息包括文件预下载信息;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的所述文件预下载信息;
通过所述主进程对与所述文件预下载信息对应的文件进行预下载,得到预下载文件;
通过所述主机驱动将所述预下载文件保存至本地的存储中,所述预下载文件包括证书和凭证。
在第一方面的一种可能的实现方式中,所述属性信息包括工作路径;在所述创建所述运行环境的主进程之后,所述方法包括:
基于上层应用调用所述标准接口输入的启动请求指令,按照所述工作路径将文件保存至本地;
在对应于所述工作路径的所述本地的存储中,基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的环境变量;
基于所述上层应用调用所述标准接口输入的启动指令,启动所述运行环境的主进程。
本申请实施例的第二方面提供了一种区块链节点的部署装置,包括:
第一处理模块,用于创建区块链节点对应的运行环境的主机驱动;
第二处理模块,用于调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;
第三处理模块,用于调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程;其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。
本申请实施例的第三方面提供了一种终端设备,所述终端设备包括存储器、处理器,所述存储器上存储有可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面中任一项所述区块链节点的部署方法的步骤。
本申请实施例的第四方面提供了一种计算机可读存储介质,包括:存储有计算机程序,所述计算机程序被处理器执行时实现如上述第一方面中任一项所述区块链节点的部署方法的步骤。
本申请实施例的第五方面提供了一种计算机程序产品,当计算机程序产品在终端设备上运行时,使得终端设备执行上述第一方面中任一项所述区块链节点的部署方法。
本申请实施例与现有技术相比存在的有益效果是:终端设备通过创建区块链节点对应的运行环境的主机驱动;调用主机驱动中的创建逻辑主机命令,创建与运行环境对应的进程间通信服务进程;调用进程间通信服务进程的启动接口,创建运行环境的主进程;其中,进程间通信服务进程包括运行环境的主进程对应的标准接口。通过该标准接口能够满足区块链节点在不同运行环境上进行部署,以及,该方法将运行环境从上层应用中分离,具有便于维护,具有较强的兼容性、适配性;该方法具有实用性及易用性。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的区块链节点的部署方法的实现流程示意图;
图2是本申请实施例提供的区块链节点的部署方法的实现流程示意图;
图3是本申请实施例提供的区块链节点的部署装置的结构示意图;
图4是本申请实施例提供的终端设备的示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定***结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的***、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
为了说明本申请所述的技术方案,下面通过具体实施例来进行说明。
图1及图2示出了本申请实施例一提供的区块链节点的部署方法的实现流程图,详述如下:一种区块链节点的部署方法,所述方法包括:
步骤S101,创建区块链节点对应的运行环境的主机驱动。
示例性地,所述运行环境为运行资源环境;具体地,所述运行环境可以为物理机、应用容器引擎(docker)、容器集群管理***Kubernetes(k8s)、云环境。相应地,所述主机驱动为对应于所述运行环境的主机驱动;具体地,所述主机驱动为物理机驱动、应用容器引擎驱动、k8s驱动。其中,所述主机驱动可以编译成可执行文件,所述可执行文件包括有对应于不同运行环境的适配实现方法,从而适配不同的运行环境。在上述步骤中,在不同的运行环境中,分别开发对应于运行环境的主机驱动;通过不同的主机驱动适配不同的运行环境,从而使区块链节点适配不同的运行环境。
示例性地,在区块链节点启动前,创建所述区块链节点对应的运行环境的主机驱动。具体地,所述区块链节点可以为区块链单节点。该步骤能够针对不同的区块链节点在不同运行环境上进行对应的主机驱动部署,以便后续区块链节点进行启动、使用。
步骤S102,调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程。
示例性地,所述主机驱动中包括有对应于所述运行环境的适配实现方法,其中,所述对应于所述运行环境的适配实现方法包括有所述创建逻辑主机命令。通过调用对应于所述运行环境的适配实现方法,然后执行所述创建逻辑主机命令,从而创建与所述运行环境对应的进程间通信服务进程。在上述步骤中,通过创建逻辑主机以及创建与运行环境对应的进程间通信服务进程,从而通过逻辑主机的进程间通信服务进程适配不同的运行环境。
具体地,所述进程间通信服务进程(RPC进程,Remote Procedure Call进程)为所述逻辑主机上的代理进程(Agent进程)。在上述步骤中,由于进程间通信服务进程为逻辑主机的进程,以及,结合步骤S101中主机驱动为对应于不同运行环境的主机驱动,主机驱动的逻辑主机能够根据不同运行环境的差异化创建进程间通信服务进程;具体实现时,无需改变上层应用、运行环境的整体代码,该方法具有较好的适配性。
步骤S103,调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程。
其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。示例性地,所述标准接口为标准通信接口。
示例性地,终端设备接收上层应用调用标准通信接口输入的设置指令。基于所述设置指令生成所述主进程的属性信息。其中,该属性信息包括启动参数。基于该启动参数,启动区块链。
具体地,接收上层应用调用标准接口输入的设置指令,基于所述设置指令生成所述主进程的属性信息。基于所述主进程的属性信息,为每个区块链节点分别设置预下载文件,所述预下载文件包括证书和凭证。示例性地,所述凭证为网络凭证,所述凭证包括账户信息和密码信息;所述证书为网络安全证书,比如,安全传输层协议(TLS,Transport LayerSecurity)证书、成员服务提供商(MSP,Membership Service Provider)证书。
调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。基于所述主进程的属性信息,通过调用标准接口的设置指令在每个区块链节点中分别生成启动文件。其中,所述启动文件可以包括网络配置文件和节点启动配置文件。根据所述启动文件和区块链节点对应的运行环境,分配互联网协议地址(IP,Internet ProtocolAddress)和网络路由端口。分别在每个区块链节点的运行环境中,根据所述启动文件,启动区块链节点,以生成区块链网络。
在步骤S103中,通过所述标准接口,能够实现创建主进程、对主进程的环境变量进行设置、对主进程的网络信息进行设置等操作。上层应用能够通过不同运行环境中的标准接口实现区块链节点的多环境部署。
在上述步骤中,该方法将运行环境的代码从上层应用的代码中分离,因而,当需要实现在不同运行环境中部署区块链节点时,不再需要针对不同的运行环境对上层应用进行编写差异化代码,不再需要编写不同物理环境的实现方法。通过该方法,上层应用能够通过获取待下载的程序包、启动主进程的启动命令,配置主进程运行所需的环境变量,以及,调用启动接口启动进程。该方法节省上层应用的开发成本,能够实现区块链节点的部署适配不同的运行环境。
在上述步骤中,步骤S101至步骤S103,创建区块链节点对应的运行环境的主机驱动;调用主机驱动中的创建逻辑主机命令,创建与运行环境对应的进程间通信服务进程;调用进程间通信服务进程的启动接口,创建运行环境的主进程;其中,进程间通信服务进程包括运行环境的主进程对应的标准接口。该方法通过进程间通信服务进程的标准接口,以实现区块链节点在不同运行环境上部署,满足不同的物理环境需求,后续能够通过该标准接口实现在不同运行环境中进行上层应用的正常执行。该方法将运行环境从上层应用中分离,便于使用者对上层应用的业务代码、运行环境的技术代码进行分离,便于使用者对执行中的异常进行定位排查。
在一种实施例中,在所述创建所述运行环境的主进程之后,所述方法包括:通过主机驱动的核心层(core),判断所述主进程是否存在。具体地,通过所述核心层的接口函数,判断所述主进程是否存在。其中,所述核心层的接口函数可以为应用程序编程接口(API,Application Programming Interface)。在上述实施例中,通过核心层对主进程的存在性进行校验,能够进一步保证上层应用在不同运行环境中实现的稳定性,减少异常的发生。
在一种实施例中,在所述创建所述运行环境的主进程之后,所述方法还包括:基于上层应用的设置指令,生成所述主进程的属性信息;所述属性信息用于指示所述上层应用执行业务操作。
示例性地,所述属性信息包括:主程序信息、环境变量、网络路由信息、工作路径、文件预下载信息、资源限制信息、健康检查配置信息、标签信息、日志信息。通过上层应用的设置指令,对主进程的属性信息进行配置,以便主进程适配不同运行环境。
在本实施例中,通过创建运行环境的主进程,以满足区块链节点在不同的运行环境中的部署需求,使上层应用的代码逻辑简洁、清晰。以及,基于上层应用的设置指令,生成主进程的属性信息;通过设置属性信息使主进程满足不同运行环境的需求,提高适配性。另外,上层应用可以对主进程进行操作,使主进程适配不同运行环境,便于对主进程进行配置、维护,具有较强的兼容性和适配性。
在一种实施例中,所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
步骤S201,接收所述上层应用调用所述标准接口输入的所述设置指令。示例性地,上层应用获取程序包;根据程序包,上层应用调用标准接口输入设置指令,其中,所述程序包有程序设置信息。具体地,所述标准接口可以是应用程序编程接口(API,ApplicationProgramming Interface)。所述设置指令可以是主进程的标签设置指令、主进程的环境变量设置指令、主进程的网络路由端口设置指令、主进程的文件存储目录设置指令、主进程的文件下载地址设置指令、主进程的资源限制设置指令、主进程的健康检查规则设置指令、主进程的日志设置指令。
步骤S202,基于所述设置指令生成所述属性信息。示例性地,可以根据程序包中的程序设置信息,基于设置指令,生成主进程的属性信息。所述属性信息包括:主程序信息、环境变量、网络路由信息、工作路径、文件预下载信息、资源限制信息、健康检查配置信息、标签信息、日志信息。通过上层应用的设置指令,对主进程的属性信息进行配置,以便主进程适配不同运行环境。
具体地,基于主进程的标签设置指令生成标签信息。具体地,基于主进程的环境变量设置指令生成主进程的环境变量。具体地,基于主进程的网络路由端口设置指令生成网络路由信息。具体地,基于主进程的文件下载地址设置指令生成文件预下载信息。具体地,基于主进程的资源限制设置指令生成资源限制信息。具体地,基于主进程的健康检查规则设置指令生成健康检查配置信息。具体地,基于主进程的日志设置指令生成日志信息。具体地,基于主进程的文件存储目录设置指令设置工作路径。在上述步骤中,步骤S201及步骤S202通过标准接口能够实现对主程序的属性信息进行设置。
在一种实施例中,所述属性信息包括网络路由信息;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:基于上层应用通过网络路由端口设置所述标准接口输入的所述设置指令,设置所述主进程的所述网络路由信息中的请求网络路由端口。
示例性地,所述上层应用获取程序包;根据程序包的程序设置信息,上层应用调用标准接口输入设置指令;通过设置指令对主进程的属性信息进行设置。具体地,通过设置指令对主进程的网络路由信息进行设置,并且,通过设置指令对主进程的网络路由信息中的请求网络路由端口进行设置。示例性地,所述网络路由端口可以为端口21、端口22、端口23、端口111。具体地,所述端口21为文件传输协议(FTP,File Transfer Protocol)服务端口,实现文件的上传与下载。具体地,所述端口22为安全外壳协议(SSH,Secure ShellProtocol)端口,用于远程连接Linux云服务器。具体地,所述端口23为远程登录(Telnet)服务端口,用于远程登录服务器。具体地,所述端口111为远程过程调用(RPC,RemoteProcedure Call)服务端口,用于进行内部进程通信。在上述步骤中,上层应用通过标准接口输入设置指令,设置不同运行环境中主进程的网络路由信息,以便后续上层应用对不同运行环境中的主进程进行控制,便于不同运行环境的主进程与上层应用进行数据交互。
在一种实施例中,在所述设置所述主进程的所述网络路由信息中的请求网络路由端口之前,所述方法包括:
步骤S301,检测所述请求网络路由端口是否为占用状态。
示例性地,通过主机驱动检测所述请求网络路由端口是否为占用状态。具体地,可以通过主机驱动获取所述请求网络路由端口的状态。当所述请求网络路由端口为关闭状态(Closing)或等待连接状态(Time Wait)或连接状态(Established)时,所述请求网络路由端口为占用状态。当所述请求网络路由端口为监听状态(Listening)时,所述请求网络路由端口不为占用状态。
步骤S302,若是,则输出报错信息。示例性地,所述报错信息用于指示所述请求网络路由端口为占用状态,从而对主进程的请求网络路由端口进行配置时减少异常发生。
步骤S303,若否,则输出所述请求网络路由端口的内部路由信息和外部路由信息。
示例性地,所述内部路由信息可以包括:内部路由的目的地址、内部路由的网络掩码、内部路由的优先级、内部路由的下一跳互联网协议地址(IP,Internet ProtocolAddress)、内部路由的输出接口、内部路由的开销。所述外部路由信息可以包括:外部路由的目的地址、外部路由的网络掩码、外部路由的优先级、外部路由的下一跳互联网协议地址、外部路由的输出接口、外部路由的开销。
在上述步骤中,步骤S301至S303,在对主进程进行网络路由信息设置之前,对请求网络路由端口的占用状态进行验证,从而保证对主进程进行网络路由信息设置的顺利完成,减少异常。
在一种实施例中,所述属性信息包括环境变量;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的环境变量,并通过所述主机驱动将所述环境变量信息保存至本地。
示例性地,所述环境变量为对应所述运行环境的参数,具体地,所述环境变量可以包括***变量、用户变量。所述环境变量信息包括所述环境变量以及对应于所述环境变量的目录路径。在本实施例中,所述设置指令为环境变量设置指令。示例性地,所述上层应用获取程序包;根据程序包的程序设置信息,上层应用调用标准接口输入环境变量设置指令;通过对主进程的环境变量进行设置;根据预设目标路径,通过主机驱动将环境变量信息保存至本地的存储目录中。
在上述实施例中,通过标准接口对主进程的环境变量配置,以使主进程能够不同的运行环境中执行相应的操作;以及,将环境变量信息进行本地保存,实现对不同运行环境下的主进程的环境变量信息进行备份,以便后续维护。
在一种实施例中,所述属性信息包括文件预下载信息;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
步骤S401,基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的所述文件预下载信息。示例性地,所述设置指令为文件下载地址设置指令。接收由所述上层应用获取的程序包,其中,所述程序包包括程序设置信息;接收所述上层应用调用标准接口输入的文件下载地址设置指令。根据所述程序设置信息中的文件下载地址,设置所述主进程的所述文件预下载信息。
步骤S402,通过所述主进程对与所述文件预下载信息对应的文件进行预下载,得到预下载文件。示例性地,根据所述程序设置信息中的文件下载地址,通过所述主进程将与所述文件预下载信息对应的文件进行预下载,从而将预下载文件下载至文件下载地址对应的目录中。
步骤S403,通过所述主机驱动将所述预下载文件保存至本地,所述预下载文件包括证书和凭证。示例性地,所述凭证为网络凭证,所述凭证包括账户信息和密码信息。示例性地,所述证书为网络安全证书。示例性地,通过主机驱动根据文件下载地址将所述预下载文件保存至本地。
在上述步骤中,步骤S401至S403,通过标准接口实现将对主进程的文件预下载信息进行配置,能够将与所述文件预下载信息对应的文件按照文件下载地址进行预下载,实现运行环境与本地之间的数据交互;以及,将预下载文件保存至本地的存储目录中,以便备份保证数据安全。
在一种实施例中,所述属性信息包括工作路径;在所述创建所述运行环境的主进程之后,所述方法包括:
步骤S501,基于上层应用调用所述标准接口输入的启动请求指令,按照所述工作路径将文件保存至本地。示例性的,接收由所述上层应用输入的启动请求指令;获取启动请求指令指向的文件,将文件按照主进程的工作路径保存至本地。
步骤S502,在对应于所述工作路径的所述本地的存储中,基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的环境变量。示例性地,所述设置指令为主进程的环境变量设置指令。在工作路径对应的本地的存储目录中,基于上层应用调用所述标准接口输入的环境变量设置指令,设置主进程的环境变量。
步骤S503,基于所述上层应用调用所述标准接口输入的启动指令,启动所述运行环境的主进程。示例性地,接收由所述上层应用输入的启动指令;启动运行环境的主进程。如此,可以在不同的运行环境中,启动对应的主进程;以及,能够在同一个运行环境中,启动多个主进程,以提高后续进行数据通信、数据交互的效率。
在上述步骤中,通过步骤S501至步骤S503,在启动主进程之前,将文件进行本地保存,以实现数据备份,保证数据安全;以及,在启动主进程之前,对环境变量进行设置,以使主进程在运行环境中能够正常运行,减少异常发生。
在一种实施例中,在所述创建所述运行环境的主进程之后,所述方法包括:基于上层应用的管理操作指令,管理所述运行环境的主进程。
示例性地,所述管理操作指令包括启动指令、停止指令、删除指令、更新指令。相应地,基于上层应用的启动指令,启动所述运行环境的主进程。基于上层应用的停止指令,停止所述运行环境的主进程。基于上层应用的删除指令,删除所述运行环境的主进程。基于上层应用的更新指令,更新所述运行环境的主进程。在本实施例中,通过上层应用调用管理操作指令,能够实现对主进程的生命周期进行管理,便于使用者对主进程的生命周期进行维护。
示例性地,接收上层应用调用标准接口输入的管理操作指令,管理所述运行环境的主进程。在本实施例中,通过上层应用调用标准接口的管理操作指令,能够实现对主进程的生命周期进行管理,便于使用者对主进程的生命周期进行维护。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
对应于上文实施例的方法,图3示出了本申请实施例提供的区块链节点的部署装置的结构框图,为了便于说明,仅示出了与本申请实施例相关的部分。图3示例的区块链节点的部署装置可以是前述实施例一提供的区块链节点的部署方法的执行主体。
参照图3,该区块链节点的部署装置30包括:
第一处理模块31,用于创建区块链节点对应的运行环境的主机驱动;
第二处理模块32,用于调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;
第三处理模块33,用于调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程;其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。
本申请实施例提供的区块链节点的部署装置中各模块实现各自功能的过程,具体可参考前述图1所示实施例一的描述,此处不再赘述。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。还应理解的是,虽然术语“第一”、“第二”等在文本中在一些本申请实施例中用来描述各种元素,但是这些元素不应该受到这些术语的限制。这些术语只是用来将一个元素与另一元素区分开。例如,第一表格可以被命名为第二表格,并且类似地,第二表格可以被命名为第一表格,而不背离各种所描述的实施例的范围。第一表格和第二表格都是表格,但是它们不是同一表格。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
图4是本申请一实施例提供的终端设备的结构示意图。如图4所示,该实施例的终端设备40包括:至少一个处理器41(图4中仅示出一个)、存储器42,所述存储器42中存储有可在所述处理器41上运行的计算机程序43。所述处理器41执行所述计算机程序43时实现上述各个区块链节点的部署方法实施例中的步骤,例如图1所示的步骤S101至S103。或者,所述处理器41执行所述计算机程序43时实现上述各装置实施例中各模块/单元的功能,例如图3所示模块31至33的功能。
所述终端设备40可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述终端设备40可包括,但不仅限于,处理器41、存储器42。本领域技术人员可以理解,图4仅仅是终端设备40的示例,并不构成对终端设备40的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述终端设备还可以包括输入发送设备、网络接入设备、总线等。
所称处理器41可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器42在一些实施例中可以是所述终端设备40的内部存储单元,例如终端设备40的硬盘或内存。所述存储器42也可以是所述终端设备40的外部存储设备,例如所述终端设备40上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(SecureDigital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器42还可以既包括所述终端设备40的内部存储单元也包括外部存储设备。所述存储器42用于存储操作***、应用程序、引导装载程序(Boot Loader)、数据以及其他程序等,例如所述计算机程序的程序代码等。所述存储器42还可以用于暂时地存储已经发送或者将要发送的数据。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
本申请实施例还提供了一种终端设备,所述终端设备包括至少一个存储器、至少一个处理器以及存储在所述至少一个存储器中并可在所述至少一个处理器上运行的计算机程序,所述处理器执行所述计算机程序时,使所述终端设备实现上述任意各个方法实施例中的步骤。
本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现可实现上述各个方法实施例中的步骤。
本申请实施例提供了一种计算机程序产品,当计算机程序产品在终端设备上运行时,使得终端设备执行时实现可实现上述各个方法实施例中的步骤。
所述集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(Read-Only Memory,ROM)、随机存取存储器(RandomAccess Memory,RAM)、电载波信号、电信信号以及软件分发介质等。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使对应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (11)
1.一种区块链节点的部署方法,其特征在于,所述方法包括:
创建区块链节点对应的运行环境的主机驱动;
调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;
调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程;
其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。
2.如权利要求1所述的方法,其特征在于,在所述创建所述运行环境的主进程之后,所述方法还包括:
基于上层应用的设置指令,生成所述主进程的属性信息;所述属性信息用于指示所述上层应用执行业务操作。
3.如权利要求2所述的方法,其特征在于,所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
接收所述上层应用调用所述标准接口输入的所述设置指令;
基于所述设置指令生成所述属性信息。
4.如权利要求3所述的方法,其特征在于,所述属性信息包括网络路由信息;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
基于上层应用通过网络路由端口设置所述标准接口输入的所述设置指令,设置所述主进程的所述网络路由信息中的请求网络路由端口。
5.如权利要求4所述的方法,其特征在于,在所述设置所述主进程的所述网络路由信息中的请求网络路由端口之前,所述方法包括:
通过所述主机驱动检测所述请求网络路由端口是否为占用状态;
若是,则输出报错信息;
若否,则输出所述请求网络路由端口的内部路由信息和外部路由信息;其中,所述网络路由信息包括所述内部路由信息和所述外部路由信息。
6.如权利要求3所述的方法,其特征在于,所述属性信息包括环境变量;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的环境变量,并通过所述主机驱动将所述环境变量信息保存至本地。
7.如权利要求2所述的方法,其特征在于,所述属性信息包括文件预下载信息;所述基于上层应用的设置指令,生成所述主进程的属性信息,包括:
基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的所述文件预下载信息;
通过所述主进程对与所述文件预下载信息对应的文件进行预下载,得到预下载文件;
通过所述主机驱动将所述预下载文件保存至本地,所述预下载文件包括证书和凭证。
8.如权利要求2或3所述的方法,其特征在于,所述属性信息包括工作路径;在所述创建所述运行环境的主进程之后,所述方法包括:
基于上层应用调用所述标准接口输入的启动请求指令,按照所述工作路径将文件保存至本地;
在对应于所述工作路径的所述本地的存储中,基于上层应用调用所述标准接口输入的所述设置指令,设置所述主进程的环境变量;
基于所述上层应用调用所述标准接口输入的启动指令,启动所述运行环境的主进程。
9.一种区块链节点的部署装置,其特征在于,包括:
第一处理模块,用于创建区块链节点对应的运行环境的主机驱动;
第二处理模块,用于调用所述主机驱动中的创建逻辑主机命令,创建与所述运行环境对应的进程间通信服务进程;
第三处理模块,用于调用所述进程间通信服务进程的启动接口,创建所述运行环境的主进程;其中,所述进程间通信服务进程包括所述运行环境的所述主进程对应的标准接口。
10.一种终端设备,其特征在于,所述终端设备包括存储器、处理器,所述存储器上存储有可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如权利要求1至8任一项所述方法的步骤。
11.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至8任一项所述方法的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211548630.3A CN116010118A (zh) | 2022-12-05 | 2022-12-05 | 一种区块链节点的部署方法、装置及终端设备 |
PCT/CN2023/111563 WO2024119861A1 (zh) | 2022-12-05 | 2023-08-07 | 一种区块链节点的部署方法、装置及终端设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211548630.3A CN116010118A (zh) | 2022-12-05 | 2022-12-05 | 一种区块链节点的部署方法、装置及终端设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116010118A true CN116010118A (zh) | 2023-04-25 |
Family
ID=86022051
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211548630.3A Pending CN116010118A (zh) | 2022-12-05 | 2022-12-05 | 一种区块链节点的部署方法、装置及终端设备 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN116010118A (zh) |
WO (1) | WO2024119861A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024119861A1 (zh) * | 2022-12-05 | 2024-06-13 | 杭州趣链科技有限公司 | 一种区块链节点的部署方法、装置及终端设备 |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111045690B (zh) * | 2018-10-12 | 2023-04-28 | 阿里巴巴集团控股有限公司 | 区块链节点服务部署方法、装置、***、计算设备及介质 |
CN109889386A (zh) * | 2019-03-05 | 2019-06-14 | 众安信息技术服务有限公司 | 区块链部署方法与*** |
CN110324174B (zh) * | 2019-05-23 | 2022-04-22 | 深圳壹账通智能科技有限公司 | 区块链环境检测方法、设备、装置及存储介质 |
CN112631728A (zh) * | 2020-12-28 | 2021-04-09 | 杭州趣链科技有限公司 | 联盟链的链码容器管理方法、装置、设备及存储介质 |
CN112732677B (zh) * | 2021-01-12 | 2023-10-13 | 库珀科技集团有限公司 | 区块链节点部署方法、装置、设备及存储介质 |
CN112445865B (zh) * | 2021-01-29 | 2021-05-18 | 支付宝(杭州)信息技术有限公司 | 自动化部署区块链网络的方法、装置及云计算平台 |
US11762644B2 (en) * | 2021-05-10 | 2023-09-19 | International Business Machines Corporation | Agentless installation for building deployments |
CN115412552A (zh) * | 2022-07-14 | 2022-11-29 | 中软航科数据科技(珠海横琴)有限公司 | 一种用于区块链部署配置的方法及*** |
CN116010118A (zh) * | 2022-12-05 | 2023-04-25 | 杭州趣链科技有限公司 | 一种区块链节点的部署方法、装置及终端设备 |
-
2022
- 2022-12-05 CN CN202211548630.3A patent/CN116010118A/zh active Pending
-
2023
- 2023-08-07 WO PCT/CN2023/111563 patent/WO2024119861A1/zh unknown
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024119861A1 (zh) * | 2022-12-05 | 2024-06-13 | 杭州趣链科技有限公司 | 一种区块链节点的部署方法、装置及终端设备 |
Also Published As
Publication number | Publication date |
---|---|
WO2024119861A1 (zh) | 2024-06-13 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11575714B2 (en) | Dividing a data processing device into separate security domains | |
EP1571805B1 (en) | Protocol stack with modification facility | |
CN107959582B (zh) | 一种切片实例的管理方法及装置 | |
US20130339949A1 (en) | Provisioning of a Virtual Machine by Using a Secured Zone of a Cloud Environment | |
CN112202615B (zh) | 一种多cni协同工作***与方法 | |
EP3095214A1 (en) | An entity handle registry to support traffic policy enforcement | |
JP2023507027A (ja) | アップグレード方法および装置 | |
EP4364388A1 (en) | Dynamic proxy response to application container | |
US20220214931A1 (en) | System and method for exposing features of integration platform adapters as first-class actions in an orchestration template | |
CN113709810A (zh) | 一种网络服务质量的配置方法、设备和介质 | |
WO2024119861A1 (zh) | 一种区块链节点的部署方法、装置及终端设备 | |
CN113574845A (zh) | 内部和外部调试 | |
CN112688794A (zh) | Yang模型的管理方法、装置、***、设备及存储介质 | |
CN112748962B (zh) | 应用加载方法、装置、电子设备和计算机可读介质 | |
US9588947B1 (en) | Integrated administrative interface for open network programming applications | |
Dobaj et al. | Dependable mesh networking patterns | |
CN113783914A (zh) | 数据处理方法、装置及设备 | |
WO2022199324A1 (en) | Run-time communications protocol parameter adjustment in containerized applications | |
US11522759B2 (en) | Method and device manager for controlling program components in a network device | |
CN108886493B (zh) | 一种具有可插拔流管理协议的基于拓扑结构的虚拟交换模型 | |
KR101943936B1 (ko) | 웹 표준 애플리케이션 개발을 위한 통합 외부 연동 시스템 및 방법 | |
US11307912B1 (en) | Forward message compatibility safety in producer-consumer systems | |
US11449581B2 (en) | Flexible license sourcing at customer sites | |
CN114546683A (zh) | 业务处理方法、装置、电子设备和存储介质 | |
van Gurp et al. | Service grid variability realization |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |