CN112636981B - 区块链主机及其代理方法、装置及存储介质 - Google Patents
区块链主机及其代理方法、装置及存储介质 Download PDFInfo
- Publication number
- CN112636981B CN112636981B CN202011580118.8A CN202011580118A CN112636981B CN 112636981 B CN112636981 B CN 112636981B CN 202011580118 A CN202011580118 A CN 202011580118A CN 112636981 B CN112636981 B CN 112636981B
- Authority
- CN
- China
- Prior art keywords
- block chain
- host
- data
- target block
- credential
- 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.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/084—Configuration by using pre-existing information, e.g. using templates or copying from other elements
- H04L41/0846—Configuration by using pre-existing information, e.g. using templates or copying from other elements based on copy from other elements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/14—Session management
- H04L67/141—Setup of application sessions
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/56—Provisioning of proxy services
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请适用于区块链技术领域,尤其涉及一种区块链主机及其代理方法、装置及存储介质。该方法通过代理平台发送的凭证数据,使得代理平台与目标区块链主机建立连接,并依次获取代理平台发送的组件数据源和节点部署指令,根据组件数据源和节点部署指令,在目标区块链主机中部署节点,再根据获取的代理平台发送的节点配置参数,开放和配置目标区块链主机中部署的节点,实现通过代理平台在目标区块链主机中部署节点的代理服务,以实现区块链的构建,本申请的方法可以在不同类型的区块链主机上进行节点部署,具备较好的通用性,降低了一定的开发成本。
Description
技术领域
本申请属于区块链技术领域,尤其涉及一种区块链主机及其代理方法、装置及存储介质。
背景技术
目前,代理平台(例如,区块链即服务(Blockchain as a Service,BaaS)平台)需要依靠在区块链主机中安装的代理软件来实现在区块链主机中部署节点的功能,但是针对不同类型的区块链主机,需要配备不同的代理软件。因此,现有的代理软件不具备通用性,无法实现不同类型的区块链主机的代理服务。
发明内容
本申请实施例提供了一种区块链主机及其代理方法、装置及存储介质,可以解决现有的代理软件无法用一致且低成本的方式实现不同类型的区块链主机的代理服务的问题。
第一方面,本申请实施例提供了一种区块链主机的代理方法,所述代理方法运行于N种类型的区块链主机中,N为大于零的整数,所述代理方法包括:
获取代理平台发送的凭证数据;
根据所述凭证数据,将所述代理平台与目标区块链主机建立连接,所述目标区块链主机是指所述N种类型的区块链主机中与所述凭证数据对应的区块链主机;
获取所述代理平台发送的节点部署数据;
根据所述节点部署数据,在所述目标区块链主机中部署节点;
获取所述代理平台发送的节点配置参数;
根据所述节点配置参数,开放和配置所述目标区块链主机中部署的节点。
第二方面,本申请实施例提供了一种区块链主机的代理装置,所述代理装置运行于N种类型的区块链主机中,N为大于零的整数,所述代理装置包括凭证接口、部署接口和资源接口;
所述凭证接口,用于获取代理平台发送的凭证数据,并根据所述凭证数据,将所述代理平台与目标区块链主机建立连接,所述目标区块链主机是指所述N种类型的区块链主机中与所述凭证数据对应的区块链主机;
所述部署接口,用于获取所述代理平台发送的节点部署数据,并根据所述节点部署数据,在所述目标区块链主机中部署节点;
所述资源接口,用于获取所述代理平台发送的节点配置参数,并根据所述节点配置参数,开放和配置所述目标区块链主机中部署的节点。
第三方面,本申请实施例提供了一种区块链主机,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如第一方面所述的代理方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如第一方面所述的代理方法。
第五方面,本申请实施例提供了一种计算机程序产品,当计算机程序产品在区块链主机上运行时,使得区块链主机执行上述第一方面所述的代理方法。
本申请实施例与现有技术相比存在的有益效果是:本申请通过代理平台发送的凭证数据,使得代理平台与目标区块链主机建立连接,并依次获取代理平台发送的组件数据源和节点部署指令,根据组件数据源和节点部署指令,在目标区块链主机中部署节点,再根据获取的代理平台发送的节点配置参数,开放和配置目标区块链主机中部署的节点,实现通过代理平台在目标区块链主机中部署节点的代理服务,以实现区块链的构建,本申请的方法可以在不同类型的区块链主机上进行节点部署,具备较好的通用性,降低了一定的开发成本。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例一的提供的一种区块链主机的代理方法的流程示意图;
图2是本申请实施例二的提供的一种区块链主机的代理方法的流程示意图;
图3是本申请实施例三提供的一种区块链主机的代理装置的结构示意图;
图4是本申请实施例四提供的一种区块链主机的结构示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
本申请实施例提供的一种区块链主机的代理方法可以应用于掌上电脑、桌上型计算机、笔记本电脑、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本、云端服务器、个人数字助理(personal digital assistant,PDA)等区块链主机上,本申请实施例对区块链主机的具体类型不作任何限制。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
为了说明本申请的技术方案,下面通过具体实施例来进行说明。
参见图1,是本申请实施例一提供的一种区块链主机的代理方法的流程示意图,该代理方法运行于N种类型的区块链主机中,N为大于零的整数,如图1所示,该代理方法可以包括以下步骤:
步骤S101,获取代理平台发送的凭证数据。
其中,代理平台可以是指用于提供实现部署各种类型节点功能的代理服务的平台,用户通过该代理平台可以在与该代理平台连接的N种类型的区块链主机中部署节点,将部署的节点开放即可实现区块链网络的构建;区块链主机可以是指能够部署节点的主机,例如,物理机、云主机、Docker容器主机、虚拟机等。
该凭证数据可以是指代理平台向区块链主机提供远程访问的凭证,以保证远程操作的安全性。凭证数据具体可以为一组字符串,但是对于不同类型的区块链主机,凭证数据的具体形式或者格式是可以不同,例如,针对区块链主机为物理机时,凭证数据可以采用用户名和密码的形式,针对区块链主机为云主机时,凭证数据可以采用TOKEN的形式。
步骤S102,根据凭证数据,将代理平台与目标区块链主机建立连接。
其中,目标区块链主机是指N种类型的区块链主机中与凭证数据对应的区块链主机。
对凭证数据进行分析,例如,对凭证数据中字符串进行解析,确定凭证数据的形式,根据凭证数据的形式,确定凭证数据对应的区块链主机的类型,N种类型的区块链主机中对应该类型的区块链主机即为目标区块链主机。
将代理平台与目标区块链主机建立连接可以是指代理平台对目标区块链主机进行操作,例如,在目标区块链主机中部署节点的操作,又如,向目标区块链主机写入数据的操作。
步骤S103,获取代理平台发送的节点部署数据。
其中,节点部署数据为在区块链主机中部署节点所需的数据,例如,组件数据和部署指令,组件数据可以是指为在区块链主机中部署节点提供所需环境支持的数据,部署指令可以用于指示区块链主机执行相应步骤以实现节点的部署。
节点部署数据需要与区块链主机的类型相匹配,就目标区块链主机而言,节点部署数据中组件数据的开发需要依据目标区块链主机的类型,使得该组件数据可以适配该目标区块链主机,即可以为在目标区块链主机中部署节点提供所需环境支持,节点部署数据中部署指令的开发需要依据目标区块链主机的类型,使得部署指令能够被目标区块链主机的指令驱动解析并执行,即可以在目标区块链主机中执行该部署指令以实现节点的部署。
步骤S104,根据节点部署数据,在目标区块链主机中部署节点。
其中,代理平台与目标区块链主机相连接,代理平台发送节点部署数据至目标区块链主机,在目标区块链主机中写入、解析并执行节点部署数据即可实现节点的部署。
可选的是,节点部署数据包括组件数据源和节点部署指令;
相应地,根据节点部署数据,在目标区块链主机中部署节点包括:
将组件数据源写入目标区块链主机;
对节点部署指令进行解析,确定解析结果;
根据解析结果和组件数据源,在目标区块链主机中部署节点。
其中,组件数据源可以是指组件的字节流,也可以是指组件的下载链接,该下载链接对应有该组件的安装包,节点部署指令可以是指用于指示区块链主机执行部署节点的指令或命令。
写入组件数据源可以是指在目标区块链主机中安装对应的组件,为部署节点提供所需环境,解析节点部署指令可以是指将节点部署指令解析为目标区块链主机所能执行的操作指令(即解析结果),使得目标区块链主机能够执行操作指令实现节点的部署。
可选的是,将组件数据源写入目标区块链主机包括:
获取组件数据源的数据源类型;
若数据源类型为字节流类型,则将组件数据源写入目标区块链主机;
若数据源类型为下载链接,则访问下载链接,并下载该下载链接对应的组件至目标区块链主机。
其中,组件数据源中带有数据源类型的信息,当数据源类型为字节流时,可以直接将该字节流写入目标区块链主机,例如,利用目标区块链主机的文件操作模块将字节流写入到目标区块链主机的磁盘中,此时的目标区块链主机可以为物理机;当数据源类型为下载链接时,目标区块链主机通过超文本传送协议(hypertext transport protocol,http)请求的方式,访问下载链接以获得对应的组件,例如,下载链接对应一个镜像文件,该镜像文件即为组件,此时的目标区块链主机可以是Docker容器主机。在目标区块链主机中写入或下载的组件,需要赋予足够的读写权限,以便于后续部署节点时使用。
可选的是,对节点部署指令进行解析,确定解析结果包括:
获取节点部署指令的指令类型;
根据指令类型,调用对应的指令驱动对节点部署指令进行解析,确定解析结果。
其中,指令类型可以是指节点部署指令所使用的编写语言,例如,Shell语言编写的指令、Docker命令语言编写的指令等,不同的指令类型对应的指令驱动不同,即解析的方式不同,针对Shell语言编写的节点部署指令,需要调用能够解析Shell语言的指令驱动,以确定解析结果。
代理平台可以向目标区块链主机发送至少一次节点部署指令,目标区块链主机按照代理平台发送节点部署指令的逻辑,依次对发送的节点部署指令进行解析并执行。
代理平台可以实现部署各种类型区块链的功能,不同类型区块链的部署流程不同,即在区块链主机中部署节点的流程不同,因此,为了在不同类型的区块链主机中部署节点,代理平台上需要集成多种类型区块链部署流程,每种类型区块链的部署流程均对应自身的节点部署指令集,该节点部署指令集中包括至少一个节点部署指令。
代理平台中部署流程可以由控制语句和功能语句(即节点部署指令)组成,其中,控制语句用于控制节点部署指令的顺序,并对节点部署指令的执行条件进行判断,功能语句用于实现部署功能的一个步骤。
步骤S105,获取代理平台发送的节点配置参数。
其中,由于在目标区块链主机中部署节点后还需要调用该区块链主机的资源(即部署的节点),来实现区块链网络的构建,因此,需要对上述在目标区块链主机中部署的节点进行配置,节点配置参数为根据需求设置的参数,用于操作目标区块链主机开放或配置该目标区块链主机资源。
步骤S106,根据节点配置参数,开放和配置目标区块链主机中部署的节点。
其中,开放目标区块链主机中部署的节点可以是指将节点作为开放的节点,以对外提供该目标区块链主机的资源,并与其他开放的节点构成区块链网络,例如,节点配置参数中包括开放端口数据,根据该开放端口数据开放目标区块链主机中节点的端口,该端口为开放端口数据对应的端口。
配置目标区块链主机中部署的节点可以是指将节点的权限或者对外提供资源的范围进行限定,例如,配置目标区块链主机中节点的防火墙、安全组等。
可选的是,根据节点配置参数,开放和配置目标区块链主机中部署的节点包括:
获取节点配置参数中的开放端口数据和网络配置数据;
根据开放端口数据,开放目标区块链主机中部署的节点的开放端口;
根据网络配置数据,配置目标区块链主机中部署的节点的网络参数。
其中,开放端口数据中可以根据需求设置端口名称等内容,从而根据开放端口数据可以开放对应的开放端口,例如,远程过程调用端口(Remote Procedure Calls,RPC),网络配置数据可以是指根据需求设置的网络参数,用于设置目标区块链主机中节点的网络参数,例如,防火墙和安全组等。
本申请实施例通过代理平台发送的凭证数据,使得代理平台与目标区块链主机建立连接,并依次获取代理平台发送的组件数据源和节点部署指令,根据组件数据源和节点部署指令,在目标区块链主机中部署节点,再根据获取的代理平台发送的节点配置参数,开放和配置目标区块链主机中部署的节点,实现通过代理平台在目标区块链主机中部署节点的代理服务,以实现区块链的构建,本申请的方法可以在不同类型的区块链主机上进行节点部署,具备较好的通用性。
参见图2,是本申请实施例二提供的一种区块链主机的代理方法的流程示意图,该区块链主机的代理方法可用于N种类型的区块链主机,如图2所示,该代理方法可以包括以下步骤:
步骤S201,获取代理平台发送的凭证数据。
其中,步骤S201与上述步骤S101的内容相同,可以参考步骤S101的描述,在此不再赘述。
步骤S202,根据凭证数据,确定凭证数据的凭证类型。
其中,凭证数据中包含有凭证类型的信息,凭证类型可以是指凭证数据的具体形式或者格式的标识,凭证类型与区块链主机的类型一一对应,不同类型的区块链主机需要适配不同凭证类型的凭证数据。凭证数据具体可以为一组字符串,该字符串中可以包括凭证类型的字段,根据该凭证类型的字段即可确定凭证数据的凭证类型。
步骤S203,确定N种类型的区块链主机中与凭证类型对应的区块链主机为目标区块链主机。
其中,从N种类型的区块链主机中匹配到与凭证类型对应的区块链主机,该凭证数据能够与该凭证类型对应的区块链主机进行适配,例如,凭证数据的凭证类型为用户名和密码的形式时,该凭证类型对应的区块链主机的类型为物理机,该凭证数据可以与物理机进行适配,又如,凭证数据的凭证类型为TOKEN的形式时,该凭证类型对应的区块链主机的类型为云主机,该凭证数据可以与云主机进行适配。
步骤S204,将代理平台与目标区块链主机建立连接。
其中,步骤S204与上述步骤S102的内容相同,可以参考步骤S102的描述,在此不再赘述。
可选的是,在根据凭证数据,确定凭证数据的凭证类型之后,还包括:
根据凭证类型,调用对应的凭证认证插件对凭证数据进行认证;
相应地,将代理平台与目标区块链主机建立连接包括:
若凭证数据被认证通过,则将代理平台与目标区块链主机建立连接。
其中,对凭证数据进行认证可以用于判断代理平台是否具有对目标区块链主机进行操作的权限,在凭证数据被认证通过后,将代理平台与目标区块链主机建立连接。在对凭证数据进行认证时还需要根据凭证类型调用对应的凭证认证插件,该凭证认证插件为预先开发的插件,例如,软件开发工具包(Software Development Kit,SDK)插件,用于对凭证数据进行认证,由于不同的凭证类型的凭证数据的形式和内容等均不相同,因此,凭证认证插件需要与凭证类型相对应,本申请中含有多种类型的凭证认证插件,以供不同凭证类型的凭证数据认证。
步骤S205,获取代理平台发送的节点部署数据。
步骤S206,根据节点部署数据,在目标区块链主机中部署节点。
步骤S207,获取代理平台发送的节点配置参数。
步骤S208,根据节点配置参数,开放和配置目标区块链主机中部署的节点。
其中,步骤S205至步骤S208与上述步骤S103至步骤S106的内容相同,可以参考步骤S103至步骤S106的描述,在此不再赘述。
本实施例以代理平台为BaaS平台为例,分别在1台Centos7.5物理机上部署2个节点,在1台Docker容器主机上部署2个节点,这4个节点形成Hyperchain区块链网络,示例过程如下:
1)在物理机和Docker容器主机上安装运行本实施例的区块链主机的代理方法。
2)BaaS平台将用户名和密码形式的凭证数据和TOKEN形式的凭证数据发送给物理机、Docker容器主机,以获取物理机和Docker容器主机的操作权限。
3)BaaS平台与物理机、Docker容器主机建立连接。
4)BaaS平台将区块链安装包、证书生成工具等必要组件的字节流发送给物理机,物理机将该字节流写入磁盘中;BaaS平台将下载链接发送给Docker容器主机,Docker容器主机访问下载链接,下载该下载链接对应的镜像文件(包括区块链安装包、证书生成工具等必要组件)。
5)BaaS平台上存储有Hyperchain区块链的部署流程,BaaS平台按照部署流程将Shell脚本指令集有序的发送给物理机,物理机接收Shell脚本指令集之后调用对应的指令驱动解析并执行指令,实现在物理机上部署2个节点;BaaS平台按照部署流程将Docker命令指令集有序的发送给Docker容器主机,Docker容器主机接收Docker命令指令集之后调用对应的指令驱动解析并执行指令,实现在Docker容器主机上部署2个节点。
6)BaaS平台发送节点配置参数至物理机和Docker容器主机,根据节点配置参数开放物理机、Docker容器主机上节点的RPC端口,并设置防火墙和安全组,即完成Hyperchain区块链网络的构建。
本申请实施例根据凭证数据中的凭证类型,确定目标区块链主机,进而建立代理平台与目标区块链主机的连接,以实现区块链的构建,本申请的方法可以在不同类型的区块链主机上进行节点部署,具备较好的通用性。
对应于上文实施例的区块链主机的代理方法,图3示出了本申请实施例三提供的区块链主机的代理装置的结构框图,为了便于说明,仅示出了与本申请实施例相关的部分。
参见图3,该代理装置运行于N种类型的区块链主机中,N为大于零的整数,代理装置包括凭证接口31、部署接口32和资源接口33;
凭证接口31,用于获取代理平台发送的凭证数据,并根据凭证数据,将代理平台与目标区块链主机建立连接,目标区块链主机是指N种类型的区块链主机中与凭证数据对应的区块链主机;
部署接口32,用于获取代理平台发送的节点部署数据,并根据节点部署数据,在目标区块链主机中部署节点;
资源接口33,用于获取代理平台发送的节点配置参数,并根据节点配置参数,开放和配置目标区块链主机中部署的节点。
可选的是,部署接口32包括安装子接口和指令子接口,节点部署数据包括组件数据源和节点部署指令;
安装子接口,用于获取代理平台发送的组件数据源,并将组件数据源写入目标区块链主机;
指令子接口,用于获取代理平台发送的节点部署指令,对节点部署指令进行解析,确定解析结果,并根据解析结果和组件数据源,在目标区块链主机中部署节点。
可选的是,凭证接口31包括:
凭证类型确定模块,用于根据凭证数据,确定凭证数据的凭证类型;
目标主机确定模块,用于确定N种类型的区块链主机中与凭证类型对应的区块链主机为目标区块链主机;
连接模块,用于将代理平台与目标区块链主机建立连接。
可选的是,该代理装置还包括:
认证模块,用于根据凭证类型,调用对应的凭证认证插件对凭证数据进行认证;
相应地,该连接模块具体用于:
若凭证数据被认证通过,则将代理平台与目标区块链主机建立连接。
可选的是,该安装子接口包括:
数据类型确定模块,用于获取组件数据源的数据源类型;
写入模块,用于若数据源类型为字节流类型,则将组件数据源写入目标区块链主机;
下载模块,用于若数据源类型为下载链接,则访问下载链接,并下载该下载链接对应的组件至目标区块链主机。
可选的是,该指令子接口包括:
指令类型获取模块,用于获取节点部署指令的指令类型;
解析模块,用于根据指令类型,调用对应的指令驱动对节点部署指令进行解析,确定解析结果。
可选的是,该资源接口33包括:
数据获取模块,用于获取节点配置参数中的开放端口数据和网络配置数据;
开放端口模块,用于根据开放端口数据,开放目标区块链主机中部署的节点的开放端口;
参数配置模块,用于根据网络配置数据,配置目标区块链主机中部署的节点的网络参数。
需要说明的是,上述模块之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
图4为本申请实施例四提供的一种区块链主机的结构示意图。如图4所示,该实施例的区块链主机4包括:至少一个处理器40(图4中仅示出一个)处理器、存储器41以及存储在存储器41中并可在至少一个处理器40上运行的计算机程序42,处理器40执行计算机程序42时实现上述任意各个实施例中的步骤。
该区块链主机可包括,但不仅限于,处理器40、存储器41。本领域技术人员可以理解,图4仅仅是区块链主机4的举例,并不构成对区块链主机4的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如还可以包括输入输出设备、网络接入设备等。
所称处理器40可以是中央处理单元(Central Processing Unit,CPU),该处理器40还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
存储器41在一些实施例中可以是区块链主机4的内部存储单元,例如区块链主机4的硬盘或内存。存储器41在另一些实施例中也可以是区块链主机4的外部存储设备,例如区块链主机4上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(SecureDigital,SD)卡,闪存卡(Flash Card)等。进一步地,存储器41还可以既包括区块链主机4的内部存储单元也包括外部存储设备。存储器41用于存储操作系统、应用程序、引导装载程序(BootLoader)、数据以及其他程序等,例如计算机程序的程序代码等。存储器41还可以用于暂时地存储已经输出或者将要输出的数据。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述装置中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述方法实施例的步骤。其中,计算机程序包括计算机程序代码,计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。计算机可读介质至少可以包括:能够携带计算机程序代码的任何实体或装置、记录介质、计算机存储器、只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、电载波信号、电信信号以及软件分发介质。例如U盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读介质不可以是电载波信号和电信信号。
本申请实现上述实施例方法中的全部或部分流程,也可以通过一种计算机程序产品来完成,当计算机程序产品在区块链主机上运行时,使得区块链主机执行时实现可实现上述方法实施例中的步骤。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/区块链主机和方法,可以通过其它的方式实现。例如,以上所描述的装置/区块链主机实施例仅仅是示意性的,例如,模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
以上实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (10)
1.一种区块链主机的代理方法,其特征在于,所述代理方法运行于N种类型的区块链主机中,N为大于零的整数,所述代理方法包括:
获取代理平台发送的凭证数据;
根据所述凭证数据,将所述代理平台与目标区块链主机建立连接,所述目标区块链主机是指所述N种类型的区块链主机中与所述凭证数据对应的区块链主机;
获取所述代理平台发送的节点部署数据;其中,所述节点部署数据为在区块链主机中部署节点所需的数据;
根据所述节点部署数据,在所述目标区块链主机中部署节点;
获取所述代理平台发送的节点配置参数;
根据所述节点配置参数,开放和配置所述目标区块链主机中部署的节点。
2.如权利要求1所述的代理方法,其特征在于,所述节点部署数据包括组件数据源和节点部署指令;
相应地,所述根据所述节点部署数据,在所述目标区块链主机中部署节点包括:
将所述组件数据源写入所述目标区块链主机;
对所述节点部署指令进行解析,确定解析结果;
根据所述解析结果和所述组件数据源,在所述目标区块链主机中部署节点。
3.如权利要求1所述的代理方法,其特征在于,所述根据所述凭证数据,将所述代理平台与目标区块链主机建立连接包括:
根据所述凭证数据,确定所述凭证数据的凭证类型;
确定所述N种类型的区块链主机中与所述凭证类型对应的区块链主机为所述目标区块链主机;
将所述代理平台与所述目标区块链主机建立连接。
4.如权利要求3所述的代理方法,其特征在于,在所述根据所述凭证数据,确定所述凭证数据的凭证类型之后,还包括:
根据所述凭证类型,调用对应的凭证认证插件对所述凭证数据进行认证;
相应地,所述将所述代理平台与所述目标区块链主机建立连接包括:
若所述凭证数据被认证通过,则将所述代理平台与所述目标区块链主机建立连接。
5.如权利要求2所述的代理方法,其特征在于,所述将所述组件数据源写入所述目标区块链主机包括:
获取所述组件数据源的数据源类型;
若所述数据源类型为字节流类型,则将所述组件数据源写入所述目标区块链主机;
若所述数据源类型为下载链接,则访问所述下载链接,并下载所述下载链接对应的组件至所述目标区块链主机。
6.如权利要求2所述的代理方法,其特征在于,所述对所述节点部署指令进行解析,确定解析结果包括:
获取所述节点部署指令的指令类型;
根据所述指令类型,调用对应的指令驱动对所述节点部署指令进行解析,确定所述解析结果。
7.如权利要求1至6任一项所述的代理方法,其特征在于,所述根据所述节点配置参数,开放和配置所述目标区块链主机中部署的节点包括:
获取所述节点配置参数中的开放端口数据和网络配置数据;
根据所述开放端口数据,开放所述目标区块链主机中部署的节点的开放端口;
根据所述网络配置数据,配置所述目标区块链主机中部署的节点的网络参数。
8.一种区块链主机的代理装置,其特征在于,所述代理装置运行于N种类型的区块链主机中,N为大于零的整数,所述代理装置包括凭证接口、部署接口和资源接口;
所述凭证接口,用于获取代理平台发送的凭证数据,并根据所述凭证数据,将所述代理平台与目标区块链主机建立连接,所述目标区块链主机是指所述N种类型的区块链主机中与所述凭证数据对应的区块链主机;
所述部署接口,用于获取所述代理平台发送的节点部署数据,并根据所述节点部署数据,在所述目标区块链主机中部署节点;其中,所述节点部署数据为在区块链主机中部署节点所需的数据;
所述资源接口,用于获取所述代理平台发送的节点配置参数,并根据所述节点配置参数,开放和配置所述目标区块链主机中部署的节点。
9.一种区块链主机,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至7任一项所述的代理方法。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的代理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011580118.8A CN112636981B (zh) | 2020-12-28 | 2020-12-28 | 区块链主机及其代理方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011580118.8A CN112636981B (zh) | 2020-12-28 | 2020-12-28 | 区块链主机及其代理方法、装置及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112636981A CN112636981A (zh) | 2021-04-09 |
CN112636981B true CN112636981B (zh) | 2023-02-17 |
Family
ID=75325513
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011580118.8A Active CN112636981B (zh) | 2020-12-28 | 2020-12-28 | 区块链主机及其代理方法、装置及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112636981B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113438287B (zh) * | 2021-06-17 | 2022-07-01 | 杭州宇链科技有限公司 | 一种区块链部署系统及方法 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107911421A (zh) * | 2017-10-30 | 2018-04-13 | 上海点融信息科技有限责任公司 | 用于配置区块链中跨网络通信的方法、设备和计算机存储介质 |
CN110138586A (zh) * | 2019-04-04 | 2019-08-16 | 平安科技(深圳)有限公司 | 区块链节点管理方法、电子装置、系统及可读存储介质 |
CN110516007A (zh) * | 2019-08-30 | 2019-11-29 | 北京百度网讯科技有限公司 | 一种区块链网络的部署控制方法、装置、设备和介质 |
WO2019228564A2 (en) * | 2019-09-11 | 2019-12-05 | Alibaba Group Holding Limited | System and method for digital asset transfer |
CN110855791A (zh) * | 2019-11-18 | 2020-02-28 | 腾讯科技(深圳)有限公司 | 一种区块链节点部署方法及相关设备 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107392619B (zh) * | 2017-07-31 | 2020-12-29 | 众安信息技术服务有限公司 | 智能合约处理方法及装置 |
CN111740966B (zh) * | 2020-06-10 | 2021-10-15 | 腾讯科技(深圳)有限公司 | 一种基于区块链网络的数据处理方法及相关设备 |
-
2020
- 2020-12-28 CN CN202011580118.8A patent/CN112636981B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107911421A (zh) * | 2017-10-30 | 2018-04-13 | 上海点融信息科技有限责任公司 | 用于配置区块链中跨网络通信的方法、设备和计算机存储介质 |
CN110138586A (zh) * | 2019-04-04 | 2019-08-16 | 平安科技(深圳)有限公司 | 区块链节点管理方法、电子装置、系统及可读存储介质 |
CN110516007A (zh) * | 2019-08-30 | 2019-11-29 | 北京百度网讯科技有限公司 | 一种区块链网络的部署控制方法、装置、设备和介质 |
WO2019228564A2 (en) * | 2019-09-11 | 2019-12-05 | Alibaba Group Holding Limited | System and method for digital asset transfer |
CN110855791A (zh) * | 2019-11-18 | 2020-02-28 | 腾讯科技(深圳)有限公司 | 一种区块链节点部署方法及相关设备 |
Also Published As
Publication number | Publication date |
---|---|
CN112636981A (zh) | 2021-04-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20210144213A1 (en) | Application Customization | |
Nie et al. | Free-fall: Hacking tesla from wireless to can bus | |
US8230415B1 (en) | On-demand advertising of software packages | |
EP2973147B1 (en) | Policy-based secure web boot | |
US20140109078A1 (en) | Application wrapping for application management framework | |
US11316683B2 (en) | Systems and methods for providing IoT security service using hardware security module | |
CN108351923B (zh) | 与统一可扩展固件接口系统可执行的脚本有关的阈值 | |
EP2143019A1 (en) | Scriptable object model for network based services | |
CN112636981B (zh) | 区块链主机及其代理方法、装置及存储介质 | |
CN113672403B (zh) | 信息系统中的接口调用方法及接口调用装置、管理信息系统 | |
CN109818972B (zh) | 一种工业控制系统信息安全管理方法、装置及电子设备 | |
CN113158195B (zh) | 一种基于poc脚本的分布式漏洞扫描方法及系统 | |
CN107066888B (zh) | 可扩展的可信用户接口、方法和电子设备 | |
US11392700B1 (en) | System and method for supporting cross-platform data verification | |
WO2024032209A1 (zh) | 区块链交易验证方法、装置、存储介质及电子设备 | |
CN106648770B (zh) | 一种应用程序安装包的生成方法、加载方法及装置 | |
CN111984963B (zh) | 绕过自签证书校验的方法和装置 | |
CN115695400A (zh) | 一种Web页面与本地应用交互的方法及终端 | |
WO2022065525A1 (ko) | 메소드 후킹을 이용한 네트워크 통신 모니터링 방법 및 시스템 | |
Veeraraghava | Security analysis of vehicle to vehicle arada locomate on board unit | |
WO2022220881A1 (en) | Generating a software application | |
WO2022220880A1 (en) | Managing a software application | |
CN109714371B (zh) | 一种工控网络安全检测系统 | |
CN109933990B (zh) | 基于多模式匹配的安全漏洞发现方法、装置及电子设备 | |
CN114095498A (zh) | 集群环境的部署方法、系统、计算机设备及存储介质 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |