CN109462508A - 节点部署方法、装置和存储介质 - Google Patents
节点部署方法、装置和存储介质 Download PDFInfo
- Publication number
- CN109462508A CN109462508A CN201811458510.8A CN201811458510A CN109462508A CN 109462508 A CN109462508 A CN 109462508A CN 201811458510 A CN201811458510 A CN 201811458510A CN 109462508 A CN109462508 A CN 109462508A
- Authority
- CN
- China
- Prior art keywords
- disposed
- node
- working
- deployment
- working node
- 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.)
- Granted
Links
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/0893—Assignment of logical groups to network elements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/08—Network architectures or network communication protocols for network security for authentication of entities
- H04L63/0823—Network architectures or network communication protocols for network security for authentication of entities using certificates
-
- 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/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/4557—Distribution of virtual machine instances; Migration and load balancing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45595—Network integration; Enabling network access in virtual machine instances
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Computer Security & Cryptography (AREA)
- Computing Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本发明提供一种节点部署方法、装置和存储介质,该方法包括:根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机;在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点。本发明根据待部署的工作节点,预先获取部署工作节点的多个虚拟机构成的集群,且直接在集群中部署工作节点,一方面避免了节点准入要求高的问题,另一方面避免了节点加入区块链的流程复杂的问题。
Description
技术领域
本发明涉及通信技术领域,尤其涉及一种节点部署方法、装置和存储介质。
背景技术
区块链(Blockchain)是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法。区块链是比特币的底层技术,像一个数据库账本,记载所有的交易记录。
现有技术中,终端或服务器加入区块链,成为区块链中的节点的方式为:节点在区块链的管理平台注册和登陆,且上传第三方提供的CA证书,管理平台对该节点审核通过后,该节点可以通过API或者管理平台,建立或者加入已有区块链,但在该过程中需要对该节点再次审核,在审核通过后才可进行区块链信息的操作。
现有技术中的节点准入时需要具备一定的条件(如硬件、软件环境和权限等),且加入流程复杂。
发明内容
本发明提供一种节点部署方法、装置和存储介质,预先获取部署工作节点的多个虚拟机构成的集群,且直接在集群中部署工作节点,一方面避免了节点准入要求高的问题,另一方面避免了节点加入区块链的流程复杂的问题。
本发明的第一方面提供一种节点部署方法,包括:
根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机;
在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点。
可选的,所述至少两个待部署的工作节点的信息包括:所述待部署的工作节点的个数和所述至少两个待部署的工作节点对应的工作组织的个数,一个所述工作组织包括至少一个所述待部署的工作节点;
所述根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机,包括:
根据所述待部署的工作节点的个数和所述至少两个待部署的工作节点对应的工作组织的个数,确定部署至少两个所述待部署的工作节点的虚拟机的个数;
根据接收到的用户输入的运行环境的请求指令,以及,所述虚拟机的个数,确定所述多个虚拟机;所述请求指令用于指示所述用户对所述虚拟机的预设运行环境的需求,每个所述虚拟机具有相同的运行环境。
可选的,所述在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点之后,还包括:
根据所述至少两个待部署的工作节点对应的工作组织,以及,每个所述工作组织的访问权限范围,为每个所述工作组织中的工作节点配置访问权限,每个所述工作组织内的工作节点的访问权限相同。
可选的,为每个所述工作组织中的工作节点配置访问权限,包括:
为每个所述工作组织中的工作节点签发权限证书。
可选的,所述集群设置有与每个所述工作组织对应的数据库,所述数据库用于存储对应的工作组织中签发的所述权限证书。
可选的,所述在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点之后,还包括:
为至少两个所述待部署的工作节点的业务进行排序。
可选的,所述为至少两个所述待部署的工作节点的业务进行排序,包括:
在所述集群中部署排序消息处理组件;所述排序消息处理组件,用于在至少两个所述待部署的工作节点进行业务时,接收至少两个所述待部署的工作节点发送的排序请求消息;
在所述集群中部署排序组件;所述排序组件,用于对发送排序请求消息的工作节点对应的业务进行排序。
本发明的第二方面提供一种节点部署装置,包括:
确定模块,根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机;
部署模块,用于在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点。
可选的,所述至少两个待部署的工作节点的信息包括:所述待部署的工作节点的个数和所述至少两个待部署的工作节点对应的工作组织的个数,一个所述工作组织包括至少一个所述待部署的工作节点。
可选的,所述确定模块,具体用于根据所述待部署的工作节点的个数和所述至少两个待部署的工作节点对应的工作组织的个数,确定部署至少两个所述待部署的工作节点的虚拟机的个数;根据接收到的用户输入的运行环境的请求指令,以及,所述虚拟机的个数,确定所述多个虚拟机;所述请求指令用于指示所述用户对所述虚拟机的预设运行环境的需求,每个所述虚拟机具有相同的运行环境。
可选的,所述装置还包括:访问权限配置模块;
所述访问权限配置模块,用于根据所述至少两个待部署的工作节点对应的工作组织,以及,每个所述工作组织的访问权限范围,为每个所述工作组织中的工作节点配置访问权限,每个所述工作组织内的工作节点的访问权限相同。
可选的,所述访问权限配置模块,具体用于为每个所述工作组织中的工作节点签发权限证书。
可选的,所述集群设置有与每个所述工作组织对应的数据库,所述数据库用于存储对应的工作组织中签发的所述权限证书。
可选的,所述装置还包括:排序模块;
所述排序模块,用于为至少两个所述待部署的工作节点的业务进行排序。
所述排序模块,具体用于在所述集群中部署排序消息处理组件;所述排序消息处理组件,用于在至少两个所述待部署的工作节点进行业务时,接收至少两个所述待部署的工作节点发送的排序请求消息;在所述集群中部署排序组件;所述排序组件,用于对发送排序请求消息的工作节点对应的业务进行排序。
本发明的第三方面提供一种节点部署装置,包括:至少一个处理器和存储器;
所述存储器存储计算机执行指令;
所述至少一个处理器执行所述存储器存储的计算机执行指令,使得所述节点部署装置执行上述节点部署方法。
本发明的第四方面提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机执行指令,当所述计算机执行指令被处理器执行时,实现上述节点部署方法。
本发明提供一种节点部署方法、装置和存储介质,该方法包括:根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机;在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点。本发明根据待部署的工作节点,预先获取部署工作节点的多个虚拟机构成的集群,且直接在集群中部署工作节点,一方面避免了节点准入要求高的问题,另一方面避免了节点加入区块链的流程复杂的问题。
附图说明
图1为本发明提供的节点部署方法适用的场景示意图;
图2为本发明提供的节点部署方法的流程示意图一;
图3为本发明提供的节点部署方法的流程示意图二;
图4为本发明提供的节点部署装置的界面示意图;
图5为本发明提供的节点部署方法的流程示意图三;
图6为本发明提供的节点部署装置的结构示意图一;
图7为本发明提供的节点部署装置的结构示意图二;
图8为本发明提供的节点部署装置的结构示意图三。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合本发明的实施例,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
区块链即服务平台(BlockChain as a Service,BaaS)是一个定位于服务联盟链的组织、技术支持平台。超级账本(Hyperledger Fabirc,fabric),以下简称为fabric,是一个模块化的分布式账本解决方案支撑平台,提供高度的保密性、弹性、灵活性与可扩展性。它的目的是支持不同组件的可插入实现,并适应经济系统中存在的复杂性。fabric提出了一个独特的高弹性且可扩展的体系结构,此结构使fabric区别于其他区块链解决方案。在fabric对企业级区块链的未来规划中,它的架构允许被全面审查且开源。
目前,在BaaS平台上部署fabric网络分为两个部分,集中式管理平台的部署和区块链集群的部署。管理平台可以是一个Web系统,具备通常web应用系统的特性(多实例、容灾冗余、负载均衡等)。平台主要功能为:用户管理、区块链管理、集群管理。区块链集群的主要功能为:分布式记账、共识机制、智能合约。
现有技术中,终端或服务器加入区块链,成为区块链中的节点的方式为:
1)、节点在区块链的管理平台注册和登陆,且上传第三方提供的CA证书;
2)、管理平台对该节点审核通过后,该节点可以通过API或者管理平台,建立或者加入已有区块链,在该过程中需要对该节点再次审核;
3)、在审核通过后,管理平台为节点配置权限,建立或者加入已有区块链;
4)、节点建立或者加入已有区块链后,根据权限可以对区块链中的信息进行访问。
现有技术中的节点加入区块链中的方式需要节点具备一定的硬件、软件和权限条件,且新加盟的节点的接入过程较为复杂,需要进行上述4个流程。本发明就是为了解决上述问题,提供了一种fabric网络中的节点部署的方法;具体的,预先为节点构建对应的虚拟机的运行环境,该运行环境包括硬件环境和软件环境,避免了节点准入要求高的问题,另外,在虚拟机构成的集群中,直接部署节点,避免了现有技术中节点接入流程繁琐的问题。
图1为本发明提供的节点部署方法适用的场景示意图,如图1所示,本发明提供的节点部署方法适用的场景中包括:待部署的工作节点、节点部署装置和虚拟机。
其中,待部署的工作节点可以为想要加入fabric网络中的节点,如终端和服务器等设备。本发明中的节点部署装置可以为手机、个人数字助理(Personal DigitalAssistant,简称:PDA)、平板电脑、便携设备(例如,便携式计算机、袖珍式计算机或手持式计算机)等移动设备;也可以是台式计算机等固定设备。本发明中的虚拟机也可以是具有固定形态的服务器,图1中为了便于说明,将虚拟机的形式示为服务器进行示例说明。
具体的,节点部署装置将待部署的节点部署至虚拟机中的具体方式可以为:虚拟机构成的集群具有负载均衡的处理功能,根据负载均衡的要求,将待部署的节点部署在多个虚拟机中。
图2为本发明提供的节点部署方法的流程示意图一,图2所示方法流程的执行主体可以为节点部署装置,该节点部署装置可由任意的软件和/或硬件实现。如图2所示,本实施例提供的节点部署方法可以包括:
S201,根据至少两个待部署的工作节点的信息,确定部署至少两个待部署的工作节点的多个虚拟机。
本实施例中,节点部署装置可以预先获取至少两个待部署的工作节点的信息。可选的,待部署的工作节点想要加入或者构建区块链时,向该节点部署装置发送部署请求,具体的,该部署请求中包括待部署的工作节点的标识。
节点部署装置在接收到多个待部署的工作节点的部署请求之后,可以获取该多个部署请求的待部署的工作节点的信息,其中,待部署的工作节点的信息可以包括:待部署的工作节点的标识,本实施例中的节点部署装置可以对发送部署请求的工作节点的数量进行统计,获取待部署的工作节点的个数。
本实施例中的至少两个待部署的工作节点的信息可以为待部署的工作节点的个数,节点部署装置可以根据待部署的工作节点的个数,确定部署待部署的工作节点的多个虚拟机,具体的,本实施例中的虚拟机也可以为预先配置的服务器;每个服务器具有预设的运行环境,其中,该运行环境包括硬件环境和软件环境,示例性的,如部分服务器配置为4核64G,部分服务器配置为8核128G等。相应的,需要进行部署的工作节点的个数越多,则需要的虚拟机的个数也就越多,本实施例中可以预先设置待部署的工作节点的个数与虚拟机的运行环境、个数的对应关系,根据该对应关系可以快速确定部署待部署的工作节点的虚拟机的个数。
在确定虚拟机的个数后,根据每个虚拟机的预先配置的运行环境,可以确定多个虚拟机;示例性的,如需要10台4核64G的虚拟机,则在多个预先配置运行环境的虚拟机中确定10个虚拟机。
值得注意的是,本实施例中的至少两个待部署的工作节点可以对应有工作组织,示例性的,一个工作组织可以为一个企业,其中的待部署的工作节点可以为该企业中的多个服务器或者多个终端;或者一个区域对应为一个工作组织,其中的待部署的工作节点可以为该区域中的多个服务器或者多个终端;该示例仅作为一种说明,工作组织可以为区块链中的虚拟概念,无论工作组织怎样划分,一个工作组织中可以对应至少一个工作节点。
具体的,本实施例中在确定部署待部署的工作节点的多个虚拟机时,可以根据待部署的工作节点的个数和工作组织的个数,确定虚拟机的个数;相应的,本实施例中可以在节点部署装置中,预先设置待部署的工作节点的个数、工作组织的个数、与虚拟机个数的三者的对应关系;根据待部署的工作节点的个数和工作节点的个数,以及该对应关系,确定虚拟机的个数。
值得注意的是,本实施例中的节点部署装置对应的用户可以在节点部署装置中输入虚拟机的运行环境,示例性的,用户想要确定部署工作节点的每个服务器的运行环境为4核64G,则节点部署装置可以根据待部署的工作节点的个数、工作节点的个数,以及用户输入的虚拟机的运行环境,确定虚拟机的个数。
相应的,在确定虚拟机的个数之后,根据预先配置的多个虚拟机的运行环境,确定进行工作节点部署的多个虚拟机。本实施例中的每个虚拟机配置有作为区块链中的运行节点的最低配置,即具备作为区块链中的运行节点的最低硬件、软件和权限条件。
S202,在多个虚拟机构成的集群中,部署至少两个待部署的工作节点。
本实施例中,节点部署装置在确定部署工作节点的虚拟机后,可以将该对个虚拟机构建为一个集群,具体的,该集群为Kubernetes集群,其中Kubernetes集群为自动化容器操作的开源平台,可进行包括如部署,调度和节点集群间扩展等操作。
本实施例中,在多个虚拟机构成的集群中,部署至少两个待部署的工作节点,可以为根据Kubernetes集群自身的负载均衡特性,将至少两个待部署的工作节点部署在该集群中;示例性的,如根据每个服务器的负载,以及待部署的工作节点的个数和工作组织个数,将工作组织和其对应的工作节点部署在多个服务器中,且能够保证每个服务器的负载均衡,使得该Kubernetes集群正常运转。
本实施例提供一种节点部署方法、装置和存储介质,该方法包括:根据至少两个待部署的工作节点的信息,确定部署至少两个待部署的工作节点的多个虚拟机;在多个虚拟机构成的集群中,部署至少两个待部署的工作节点。本实施例根据待部署的工作节点,预先获取部署工作节点的多个虚拟机构成的集群,且直接在集群中部署工作节点,一方面避免了节点准入要求高的问题,另一方面避免了节点加入区块链的流程复杂的问题。
在上述实施例的基础上,下面结合图3对本发明提供的节点部署方法进行进一步说明,图3为本发明提供的节点部署方法的流程示意图二,如图3所示,本实施例提供的节点部署方法可以包括:
S301,根据待部署的工作节点的个数和待部署的工作节点对应的工作组织的个数,确定部署至少两个待部署的工作节点的虚拟机的个数。
本实施例中的至少两个待部署的工作节点的信息包括:待部署的工作节点的个数和待部署的工作节点对应的工作组织的个数;其中,一个工作组织可以包括至少一个待部署的工作节点。
相应的,工作组织的个数以及工作节点的个数越多,则虚拟机的个数也就越多,本实施例中可以预先存储有工作组织的个数、工作节点的个数、以及虚拟机的个数之间的对应关系,本实施例中的节点部署装置可以根据获取的待部署的工作节点的个数和待部署的工作节点对应的工作组织的个数,以及该对应关系,获取部署待部署的工作节点的虚拟机的个数。示例性的,该对应关系可如下表一所示:
表一
工作组织个数 | 工作节点个数 | 虚拟机个数 |
A | a | 5 |
B | b | 10 |
C | c | 15 |
D | d | 20 |
上述表一示例性的示出了该对应关系,其中,表一中示例性的将大写字母A、B、C、D代表对应的工作组织的个数,和小写字母a、b、c、d的代表工作节点个数。可以想到的是,本实施例中可以采用其他的方式进行该对应关系的表示。
S302,根据接收到的用户输入的运行环境的请求指令,以及,虚拟机的个数,确定多个虚拟机。
图4为本发明提供的节点部署装置的界面示意图,本实施例中,如图4所示,节点部署装置的界面上显示有用户可选择的虚拟机的运行环境,如该界面上示例性的示出虚拟机的硬件环境,如服务器的CPU以及内存为:4核64G、8核128G,服务器的类型为:普通型、计算优化型等。可以想到的是,也可在该接界面上显示有虚拟机的软件环境,该界面上未示出。
用户在选择对应的虚拟机的运行环境后,该显示界面上显示有确定控件,用户通过点击或者其他操作选择该控件,触发向节点部署装置发送运行环境的请求指令,具体的,该请求指令用于指示用户对虚拟机的预设运行环境的需求,如图4中的阴影所示,用户选择了虚拟机的硬件环境为4核64G。则节点部署装置根据虚拟机的个数以及虚拟机的运行环境,在预设的虚拟机中确定多个虚拟机,该多个虚拟机用于部署待部署的工作节点,其中,每个虚拟机具有相同的运行环境。
S303,在多个虚拟机构成的集群中,部署至少两个待部署的工作节点。
本实施例中的S401-S403具体可以参照上述实施例中的S301-S303中的相关描述。
S304,根据至少两个待部署的工作节点对应的工作组织,以及,每个工作组织的访问权限范围,为每个工作组织中的工作节点配置访问权限。
在该集群中的工作节点部署之前,还需要在集群中为每个工作组织配置权限装置。具体的,该权限装置包括:根签发组件和中间签发组件。
其中,在该集群中将工作节点部署完成后,会根据每个工作节点对应的工作组织,以及,每个工作组织的访问权限范围,为每个工作组织中的工作节点配置访问权限。
具体的,权限装置中的根签发组件,用于在该工作组织中,对中间签发组件签发权限证书;中间签发组件,用于对工作组织中的多个待部署的工作节点签发权限证书。
进一步的,本实施例中的集群中设置有与每个工作组织对应的数据库,数据库用于存储对应的工作组织中签发的权限证书。具体的,每个组织中配置有一个根签发数据库和一个中间签发数据库。
其中,根签发数据库,用于存储根签发组件签发的中间签发组件的信息,以及,对中间签发组件签发的权限证书;中间签发数据库,用于存储中间签发组件签发的多个待部署的工作节点的信息,以及,对工作组织中的多个待部署的工作节点签发的权限证书。
可选的,本实施例中的每个工作组织内的工作节点的访问权限可以相同。
本实施例中,将权限装置配置在工作节点所在的集群中,即权限装置托管于该集群中,避免了现有技术中需要第三方装置对待部署的工作节点在加入区块链之前签发权限证书的流程。本实施例中可以采用预先配置的权限装置对待部署的工作节点直接签发权限证书,减少了复杂的签发流程。
S305,为至少两个待部署的工作节点的业务进行排序。
本实施例中,在该集群中的工作节点部署之前,还需要在集群中为每个工作组织配置排序装置。具体的,该排序装置包括:排序消息处理组件和排序组件;即在该集群中部署排序消息处理组件和排序组件。
其中,在节点部署装置将至少两个待部署的工作节点部署在集群中后,工作节点可以在该集群中进行正常的交易、支付等业务,在每次业务进行之前,已经部署的工作节点向排序消息处理组件发送排序请求消息,该排序请求消息用于指示排序组件对所有进行业务排序请求的工作节点的业务进行排序。
其中,排序消息处理组件,用于在至少两个待部署的工作节点进行业务时,接收至少两个待部署的工作节点发送的排序请求消息;排序组件,用于对发送排序请求消息的工作节点对应的业务进行排序。其中,排序组件对工作节点对应的业务进行排序的具体方式可以与现有技术中的排序方式相同,在此不做限制。
本实施例中,在工作节点部署之前,在集群中配置权限装置和排序装置,可以对为每个工作组织中的工作节点签发权限证书,以及对工作节点对应的业务进行排序;本实施例中将权限装置和排序装置配置在工作节点所在的集群中,即权限装置和排序装置托管于该集群中,避免了现有技术中需要第三方装置对待部署的工作节点在加入区块链之前签发权限证书的流程,以及避免了采用第三方装置对工作节点的业务进行排序的流程。本实施例中权限装置和排序装置托管于该集群中,减少了复杂的节点处理流程。
在上述实施例的基础上,下面结合图5对本发明提供的节点部署方法进行进一步说明,图5为本发明提供的节点部署方法的流程示意图三,如图5所示,本实施例提供的节点部署方法可以包括:
S501,根据待部署的工作节点的个数和至少两个待部署的工作节点对应的工作组织的个数,确定部署至少两个待部署的工作节点的虚拟机的个数。
S502,根据接收到的用户输入的运行环境的请求指令,以及,虚拟机的个数,确定多个虚拟机。
S503,在多个虚拟机构成的集群中,部署至少两个待部署的工作节点。
S504,对集群中部署的至少两个待部署的工作节点的工作状态进行检测,确定是否部署成功;若是,执行S506,若否,执行S505。
本实施例中,节点部署装置在对至少两个工作节点部署完成后,可以对部署完成的工作节点的工作状态进行检测;示例性的,如检测工作节点是否能够正常的进行业务。
值得注意的是,本实施例中的对工作节点在集群中的部署为fabric网络在集群中的底层网络的部署,在该底层网络的部署完成后,可以进行信道的部署、链码的部署以及应用层的部署,使得整个fabric网络在集群中部署完成。
其中,示例性的,若检测已经部署完成的工作节点是不能够正常的进行业务,则确定工作节点的部署失败,则可以根据上述实施例中的工作节点的部署流程对待部署的工作节点进行重新部署。
S505,重新进行工作节点的部署。
具体可以参照上述实施例中的S301-S305中的相关描述,在此不做赘述。
S506,停止。
在完成本实施例中的待部署的工作节点的部署,即完成fabric网络在集群中的底层网络的部署;在该底层网络的部署完成后,可以进行信道的部署、链码的部署以及应用层的部署,使得整个fabric网络在集群中部署完成。
具体的,可以通过集群中预先配置的配置装置rproxy进行信道的部署,且在信道的部署完成后,对信道的部署状态进行检测;部署成功后,再通过集群中预先配置的rproxy进行链码的部署,且在链码的部署完成后,对链码的部署状态进行检测;部署成功后,再调用分布式dapp接口,根据反馈的dappId以及部署包的统一资源定位符URL连接,进行应用层的部署,以使得整个fabric网络在集群中部署完成。
本实施例中的S501-S503具体可以参照上述实施例中的S301-S303中的相关描述。
本实施例中,在工作节点部署在集群中后,对工作节点的工作状态进行检测,若工作节点运行正常,则确定工作节点部署成功,即进行下一步集群中信道的部署、链码的部署以及应用层的部署,使得整个fabric网络在集群中部署完成。
图6为本发明提供的节点部署装置的结构示意图一,如图6所示,该节点部署装置600包括:确定模块601和部署模块602。
确定模块601,用于根据待部署的工作节点的信息,确定部署至少两个待部署的工作节点的多个虚拟机。
部署模块602,用于在多个虚拟机构成的集群中,部署至少两个待部署的工作节点。
本实施例提供的节点部署装置与上述节点部署方法实现的原理和技术效果类似,在此不作赘述。
可选的,图7为本发明提供的节点部署装置的结构示意图二,如图7所示,该节点部署装置600还包括:访问权限配置模块603和排序模块604。
访问权限配置模块603,用于根据至少两个待部署的工作节点对应的工作组织,以及,每个工作组织的访问权限范围,为每个工作组织中的工作节点配置访问权限,每个工作组织内的工作节点的访问权限相同。
排序模块604,用于为至少两个待部署的工作节点的业务进行排序。
可选的,待部署的工作节点的信息包括:待部署的工作节点的个数和待至少两个部署的工作节点对应的工作组织的个数,一个工作组织包括至少一个待部署的工作节点。
可选的,确定模块601,具体用于根据待部署的工作节点的个数和至少两个待部署的工作节点对应的工作组织的个数,确定部署至少两个待部署的工作节点的虚拟机的个数;根据接收到的用户输入的运行环境的请求指令,以及,虚拟机的个数,确定多个虚拟机;请求指令用于指示用户对虚拟机的预设运行环境的需求,每个虚拟机具有相同的运行环境。
可选的,访问权限配置模块603,具体用于为每个工作组织中的工作节点签发权限证书。
可选的,集群设置有与每个工作组织对应的数据库,数据库用于存储对应的工作组织中签发的权限证书。
排序模块604,具体用于在集群中部署排序消息处理组件;排序消息处理组件,用于在至少两个待部署的工作节点进行业务时,接收待部署的工作节点发送的排序请求消息;在集群中部署排序组件;排序组件,用于对发送排序请求消息的工作节点对应的业务进行排序。
图8为本发明提供的节点部署装置的结构示意图三,该节点部署装置例如可以是终端设备,比如智能手机、平板电脑、计算机等。如图8所示,该节点部署装置800包括:存储器801和至少一个处理器802。
存储器801,用于存储程序指令。
处理器802,用于在程序指令被执行时实现本实施例中的节点部署方法,具体实现原理可参见上述实施例,本实施例此处不再赘述。
该节点部署装置800还可以包括及输入/输出接口803。
输入/输出接口803可以包括独立的输出接口和输入接口,也可以为集成输入和输出的集成接口。其中,输出接口用于输出数据,输入接口用于获取输入的数据,上述输出的数据为上述方法实施例中输出的统称,输入的数据为上述方法实施例中输入的统称。
本发明还提供一种可读存储介质,可读存储介质中存储有执行指令,当节点部署装置的至少一个处理器执行该执行指令时,当计算机执行指令被处理器执行时,实现上述实施例中的节点部署方法。
本发明还提供一种程序产品,该程序产品包括执行指令,该执行指令存储在可读存储介质中。节点部署装置的至少一个处理器可以从可读存储介质读取该执行指令,至少一个处理器执行该执行指令使得节点部署装置实施上述的各种实施方式提供的节点部署方法。
在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或处理器(英文:processor)执行本发明各个实施例所述方法的部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(英文:Read-Only Memory,简称:ROM)、随机存取存储器(英文:Random Access Memory,简称:RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
在上述网络设备或者终端设备的实施例中,应理解,处理器可以是中央处理单元(英文:Central Processing Unit,简称:CPU),还可以是其他通用处理器、数字信号处理器(英文:Digital Signal Processor,简称:DSP)、专用集成电路(英文:ApplicationSpecific Integrated Circuit,简称:ASIC)等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本申请所公开的方法的步骤可以直接体现为硬件处理器执行完成,或者用处理器中的硬件及软件模块组合执行完成。
最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。
Claims (10)
1.一种节点部署方法,其特征在于,包括:
根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机;
在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点。
2.根据权利要求1所述的方法,其特征在于,所述至少两个待部署的工作节点的信息包括:所述待部署的工作节点的个数和所述至少两个待部署的工作节点对应的工作组织的个数,一个所述工作组织包括至少一个所述待部署的工作节点;
所述根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机,包括:
根据所述待部署的工作节点的个数和所述至少两个待部署的工作节点对应的工作组织的个数,确定部署至少两个所述待部署的工作节点的虚拟机的个数;
根据接收到的用户输入的运行环境的请求指令,以及,所述虚拟机的个数,确定所述多个虚拟机;所述请求指令用于指示所述用户对所述虚拟机的预设运行环境的需求,每个所述虚拟机具有相同的运行环境。
3.根据权利要求2所述的方法,其特征在于,所述在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点之后,还包括:
根据所述待部署的工作节点对应的工作组织,以及,每个所述工作组织的访问权限范围,为每个所述工作组织中的工作节点配置访问权限,每个所述工作组织内的工作节点的访问权限相同。
4.根据权利要求3所述的方法,其特征在于,为每个所述工作组织中的工作节点配置访问权限,包括:
为每个所述工作组织中的工作节点签发权限证书。
5.根据权利要求4所述的方法,其特征在于,所述集群设置有与每个所述工作组织对应的数据库,所述数据库用于存储对应的工作组织中签发的所述权限证书。
6.根据权利要求2所述的方法,其特征在于,所述在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点之后,还包括:
为至少两个所述待部署的工作节点的业务进行排序。
7.根据权利要求6所述的方法,其特征在于,所述为至少两个所述待部署的工作节点的业务进行排序,包括:
在所述集群中部署排序消息处理组件;所述排序消息处理组件,用于在至少两个所述待部署的工作节点进行业务时,接收至少两个所述待部署的工作节点发送的排序请求消息;
在所述集群中部署排序组件;所述排序组件,用于对发送排序请求消息的工作节点对应的业务进行排序。
8.一种节点部署装置,其特征在于,包括:
确定模块,用于根据至少两个待部署的工作节点的信息,确定部署至少两个所述待部署的工作节点的多个虚拟机;
部署模块,用于在所述多个虚拟机构成的集群中,部署至少两个所述待部署的工作节点。
9.一种节点部署装置,其特征在于,包括:至少一个处理器和存储器;
所述存储器存储计算机执行指令;
所述至少一个处理器执行所述存储器存储的计算机执行指令,使得所述节点部署装置执行权利要求1-7任一项所述的方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机执行指令,当所述计算机执行指令被处理器执行时,实现权利要求1-7任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811458510.8A CN109462508B (zh) | 2018-11-30 | 2018-11-30 | 节点部署方法、装置和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811458510.8A CN109462508B (zh) | 2018-11-30 | 2018-11-30 | 节点部署方法、装置和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109462508A true CN109462508A (zh) | 2019-03-12 |
CN109462508B CN109462508B (zh) | 2021-06-01 |
Family
ID=65612177
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811458510.8A Active CN109462508B (zh) | 2018-11-30 | 2018-11-30 | 节点部署方法、装置和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109462508B (zh) |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110149376A (zh) * | 2019-04-30 | 2019-08-20 | 广州科创空间信息科技有限公司 | 提高hyperledger composer链码部署效率的方法 |
CN110650193A (zh) * | 2019-09-20 | 2020-01-03 | 腾讯科技(深圳)有限公司 | 节点管理方法、集群管理设备及存储介质 |
CN111124617A (zh) * | 2019-12-24 | 2020-05-08 | 腾讯科技(深圳)有限公司 | 区块链系统的创建方法和装置、存储介质及电子装置 |
CN111245910A (zh) * | 2019-12-31 | 2020-06-05 | 杭州趣链科技有限公司 | 一种区块链轻节点多副本的部署方法 |
WO2020233073A1 (zh) * | 2019-05-23 | 2020-11-26 | 深圳壹账通智能科技有限公司 | 区块链环境检测方法、设备、装置及存储介质 |
CN112073508A (zh) * | 2020-09-05 | 2020-12-11 | 蔡春梅 | 基于云计算和区块链服务的数据处理方法及人工智能平台 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102521014A (zh) * | 2011-12-06 | 2012-06-27 | 北京航空航天大学 | 虚拟机的部署方法及装置 |
CN103491144A (zh) * | 2013-09-09 | 2014-01-01 | 中国科学院计算技术研究所 | 一种广域网虚拟平台的构建方法 |
US20150356555A1 (en) * | 2014-06-04 | 2015-12-10 | Antti Pennanen | System and method for executing financial transactions |
CN107145380A (zh) * | 2017-03-27 | 2017-09-08 | 华为技术有限公司 | 虚拟资源编排方法及装置 |
CN108305072A (zh) * | 2018-01-04 | 2018-07-20 | 上海点融信息科技有限责任公司 | 部署区块链网络的方法、设备和计算机存储介质 |
CN108549580A (zh) * | 2018-03-30 | 2018-09-18 | 平安科技(深圳)有限公司 | 自动部署Kubernetes从节点的方法及终端设备 |
-
2018
- 2018-11-30 CN CN201811458510.8A patent/CN109462508B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102521014A (zh) * | 2011-12-06 | 2012-06-27 | 北京航空航天大学 | 虚拟机的部署方法及装置 |
CN103491144A (zh) * | 2013-09-09 | 2014-01-01 | 中国科学院计算技术研究所 | 一种广域网虚拟平台的构建方法 |
US20150356555A1 (en) * | 2014-06-04 | 2015-12-10 | Antti Pennanen | System and method for executing financial transactions |
CN107145380A (zh) * | 2017-03-27 | 2017-09-08 | 华为技术有限公司 | 虚拟资源编排方法及装置 |
CN108305072A (zh) * | 2018-01-04 | 2018-07-20 | 上海点融信息科技有限责任公司 | 部署区块链网络的方法、设备和计算机存储介质 |
CN108549580A (zh) * | 2018-03-30 | 2018-09-18 | 平安科技(深圳)有限公司 | 自动部署Kubernetes从节点的方法及终端设备 |
Non-Patent Citations (1)
Title |
---|
贺海武等: "基于区块链的智能合约技术与应用综述", 《计算机研究与发展》 * |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110149376A (zh) * | 2019-04-30 | 2019-08-20 | 广州科创空间信息科技有限公司 | 提高hyperledger composer链码部署效率的方法 |
CN110149376B (zh) * | 2019-04-30 | 2021-01-05 | 广州科创空间信息科技有限公司 | 提高hyperledger composer链码部署效率的方法 |
WO2020233073A1 (zh) * | 2019-05-23 | 2020-11-26 | 深圳壹账通智能科技有限公司 | 区块链环境检测方法、设备、装置及存储介质 |
CN110650193A (zh) * | 2019-09-20 | 2020-01-03 | 腾讯科技(深圳)有限公司 | 节点管理方法、集群管理设备及存储介质 |
CN110650193B (zh) * | 2019-09-20 | 2021-06-25 | 腾讯科技(深圳)有限公司 | 节点管理方法、集群管理设备及存储介质 |
CN111124617A (zh) * | 2019-12-24 | 2020-05-08 | 腾讯科技(深圳)有限公司 | 区块链系统的创建方法和装置、存储介质及电子装置 |
CN111124617B (zh) * | 2019-12-24 | 2021-03-16 | 腾讯科技(深圳)有限公司 | 区块链系统的创建方法和装置、存储介质及电子装置 |
CN111245910A (zh) * | 2019-12-31 | 2020-06-05 | 杭州趣链科技有限公司 | 一种区块链轻节点多副本的部署方法 |
CN112073508A (zh) * | 2020-09-05 | 2020-12-11 | 蔡春梅 | 基于云计算和区块链服务的数据处理方法及人工智能平台 |
CN112073508B (zh) * | 2020-09-05 | 2021-05-04 | 江苏端木软件技术有限公司 | 基于云计算和区块链服务的数据处理方法及人工智能平台 |
Also Published As
Publication number | Publication date |
---|---|
CN109462508B (zh) | 2021-06-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109462508A (zh) | 节点部署方法、装置和存储介质 | |
Wang et al. | Edge server placement in mobile edge computing | |
CN109522735B (zh) | 一种基于智能合约的数据权限验证方法及装置 | |
CN105024865B (zh) | 云联合即服务 | |
CN105408882B (zh) | 自动化桌面布置 | |
CN107580083A (zh) | 一种容器ip地址分配的方法和系统 | |
CN111182025B (zh) | 一种报文处理方法、装置、服务器及存储介质 | |
CN110417558A (zh) | 签名的验证方法和装置、存储介质及电子装置 | |
CN105940377A (zh) | 用于基于云的虚拟化编排器的方法、系统和计算机可读介质 | |
CN109600798A (zh) | 一种网络切片中多域资源分配方法及装置 | |
CN105531688A (zh) | 提供作为其它服务的资源的服务 | |
CN112702402A (zh) | 基于区块链技术实现政务信息资源共享和交换的系统、方法、装置、处理器及其存储介质 | |
CN109547530A (zh) | 区域共识方法、系统及设备 | |
CN106716968A (zh) | 账户管理方法、装置及账户管理系统 | |
CN109413125A (zh) | 动态调节分布式系统资源的方法和装置 | |
CN108563697A (zh) | 一种数据处理方法、装置和存储介质 | |
CN110070394A (zh) | 数据处理方法、系统、介质和计算设备 | |
Li et al. | Cross-cloud mapreduce for big data | |
CN107888663A (zh) | 一种分发文件的方法、设备及计算机可读介质 | |
CN104166581B (zh) | 一种面向增量制造设备的虚拟化方法 | |
CN113506100A (zh) | 联盟链数据处理方法、装置、计算机设备及存储介质 | |
CN107741994A (zh) | 一种数据更新方法及装置 | |
CN104517174A (zh) | 一种统一凭证平台及其处理方法 | |
CN105227781A (zh) | 一种移动终端配置的方法及系统 | |
CN107872483A (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 |