CN109347901B - 区块链系统的共识机制实现方法、介质、装置及系统 - Google Patents
区块链系统的共识机制实现方法、介质、装置及系统 Download PDFInfo
- Publication number
- CN109347901B CN109347901B CN201810967398.4A CN201810967398A CN109347901B CN 109347901 B CN109347901 B CN 109347901B CN 201810967398 A CN201810967398 A CN 201810967398A CN 109347901 B CN109347901 B CN 109347901B
- Authority
- CN
- China
- Prior art keywords
- node
- address
- weight value
- production
- block chain
- 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
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/54—Presence management, e.g. monitoring or registration for receipt of user log-on information, or the connection status of the users
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/10—Active monitoring, e.g. heartbeat, ping or trace-route
-
- 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
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Health & Medical Sciences (AREA)
- Cardiology (AREA)
- General Health & Medical Sciences (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本发明提出了一种区块链系统的共识机制实现方法,该方法包括:在区块链系统初始化时,创建系统节点权重表;当区块链系统中的当前生产节点生产区块时,根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点;如果存在掉线节点,则将掉线节点的节点权重值减1,并更新系统节点权重表;当基于dpos共识机制产生生产节点时,根据每个节点的投票数和每个节点的节点权重值选取生产节点。由此,本发明将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,从而大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统高效运转。
Description
技术领域
本发明涉及信息处理技术领域,特别涉及一种区块链系统的共识机制实现方法、介质、装置及系统。
背景技术
区块链本质上是一种由交易驱动的确定性状态机,共识是商定确定性交易顺序和过滤无效交易的过程,DPOS(Delegated Proof of Stake,委任权益证明)引人注目的安全性来自于其选择区块生产者和验证节点质量的算法。现有DPOS共识机制下的区块链系统对于区块生产节点的选取是通过投票实现的,然而由于投票者无法时刻关注各节点的生产区块情况,从而导致没有及时投票,而默认按照前一次投票结果进行投票,或者出现给常常掉线的节点进行投票的情况。
发明内容
本发明旨在至少在一定程度上解决上述技术中的技术问题之一。为此,本发明的一个目的在于提出一种区块链系统的共识机制实现方法,能够将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,从而大大降低了常掉线的节点成为区块生产节点的可能性,保证区块链系统高效运转。
本发明的第二个目的在于提出一种计算机可读存储介质。
本发明的第三个目的在于提出一种区块链系统的共识机制实现装置。
本发明的第四个目的在于提出一种区块链系统。
为达到上述目的,本发明第一方面实施例提出了一种区块链系统的共识机制实现方法,包括以下步骤:在区块链系统初始化时,创建系统节点权重表,其中,所述系统节点权重表包括节点ip地址项和对应的节点权重值;当所述区块链系统中的当前生产节点生产区块时,根据所述系统节点权重表对每个节点的ip地址进行问询以判断所述区块链系统中是否存在掉线节点;如果存在掉线节点,则将所述掉线节点的节点权重值减1,并更新所述系统节点权重表;当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用所述系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点。
根据本发明实施例的区块链系统的共识机制实现方法,首先在区块链系统初始化时,创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值;接着当区块链系统中的当前生产节点生产区块时,根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点,如果存在掉线节点,则将掉线节点的节点权重值减1,并更新系统节点权重表;然后当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
另外,根据本发明上述实施例提出的区块链系统的共识机制实现方法还可以具有如下附加的技术特征:
可选地,当所述区块链系统中任意一个节点接收到新节点的连入请求时,该节点对所述新节点的ip地址进行广播,以便所述区块链系统中的生产节点接收到广播后将所述新节点的ip地址在所述系统节点权重表内检索以判断所述系统节点权重表中是否存在所述新节点的ip地址项,其中,如果存在,则保持所述新节点的ip地址项对应的节点权重值不变;如果未存在,则在所述系统节点权重表中创建所述新节点的ip地址项,并对所述新节点的ip地址项对应的节点权重值进行初始赋值。
可选地,对每个节点的ip地址进行问询时,向每个节点发送问询信息,并在预设时间后判断是否接收到应答信息,其中,如果接收到当前节点的应答信息,则判断当前节点在线;如果未接收到当前节点的应答信息,则判断当前节点掉线。
可选地,根据每个节点的投票数和每个节点的节点权重值选取生产节点,包括:将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
为达到上述目的,本发明第二方面实施例提出了一种计算机可读存储介质,其上存储有区块链系统的共识机制实现程序,该区块链系统的共识机制实现程序被处理器执行时实现如上述的区块链系统的共识机制实现方法。
根据本发明实施例的计算机可读存储介质,通过存储区块链系统的共识机制实现程序,这样区块链系统的共识机制实现程序被处理器执行时实现如上述的区块链系统的共识机制实现方法,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
为达到上述目的,本发明第三方面实施例提出了一种区块链系统的共识机制实现装置,包括创建模块,用于在区块链系统初始化时创建系统节点权重表,其中,所述系统节点权重表包括节点ip地址项和对应的节点权重值;问询模块,用于在所述区块链系统中的当前生产节点生产区块时根据所述系统节点权重表对每个节点的ip地址进行问询以判断所述区块链系统中是否存在掉线节点;赋值模块,用于在所述区块链系统中存在掉线节点时将所述掉线节点的节点权重值减1,并更新所述系统节点权重表;共识模块,用于在基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用所述系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点。
根据本发明实施例的区块链系统的共识机制实现装置,在区块链系统初始化时,通过创建模块创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值,并且在区块链系统中的当前生产节点生产区块时,问询模块根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点,如果存在掉线节点,则通过赋值模块将掉线节点的节点权重值减1,并更新系统节点权重表,这样共识模块在基于dpos共识机制产生生产节点时获取每个节点的投票数,并调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
另外,根据本发明上述实施例提出的区块链系统的共识机制实现装置还可以具有如下附加的技术特征:
可选地,所述赋值模块还用于,当所述区块链系统中任意一个节点接收到新节点的连入请求时,该节点对所述新节点的ip地址进行广播,以便所述区块链系统中的生产节点接收到广播后将所述新节点的ip地址在所述系统节点权重表内检索以判断所述系统节点权重表中是否存在所述新节点的ip地址项,其中,如果存在,则保持所述新节点的ip地址项对应的节点权重值不变;如果未存在,则在所述系统节点权重表中创建所述新节点的ip地址项,并对所述新节点的ip地址项对应的节点权重值进行初始赋值。
可选地,所述问询模块进一步用于,对每个节点的ip地址进行问询时,向每个节点发送问询信息,并在预设时间后判断是否接收到应答信息,其中,如果接收到当前节点的应答信息,则判断当前节点在线;如果未接收到当前节点的应答信息,则判断当前节点掉线。
可选地,所述共识模块根据每个节点的投票数和每个节点的节点权重值选取生产节点时,进一步用于,将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
为达到上述目的,本发明第四方面实施例提出了一种区块链系统,其包括如上述的区块链系统的共识机制实现装置。
根据本发明实施例的区块链系统,通过上述的区块链系统的共识机制实现装置,能够在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,从而大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
附图说明
图1为根据本发明实施例的区块链系统的共识机制实现方法的流程示意图;
图2为根据本发明另一实施例的区块链系统的共识机制实现方法的流程示意图;
图3为根据本发明实施例的区块链系统的共识机制实现装置的方框示意图。
具体实施方式
下面详细描述本发明的实施例,所述实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,旨在用于解释本发明,而不能理解为对本发明的限制。
现有DPOS共识机制下的区块链系统对于区块生产节点的选取是通过投票实现的,然而由于投票者无法时刻关注各节点的生产区块情况,从而导致没有及时投票,而默认按照前一次投票结果进行投票,或者出现给常常掉线的节点进行投票的情况。而本发明实施例提供的区块链系统的共识机制实现方法,在区块链系统初始化时,创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值;并当区块链系统中的当前生产节点生产区块时,根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点,如果存在掉线节点,则将掉线节点的节点权重值减1,并更新系统节点权重表;然后当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
为了更好的理解上述技术方案,下面将参照附图更详细地描述本发明的示例性实施例。虽然附图中显示了本发明的示例性实施例,然而应当理解,可以以各种形式实现本发明而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本发明,并且能够将本发明的范围完整的传达给本领域的技术人员。
为了更好的理解上述技术方案,下面将结合说明书附图以及具体的实施方式对上述技术方案进行详细的说明。
图1为本发明实施例提出的区块链系统的共识机制实现方法的流程示意图。如图1所示,该区块链系统的共识机制实现方法包括以下步骤:
步骤101,在区块链系统初始化时,创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值。
也就是说,在区块链系统初始化时,创建包括节点ip地址项和对应的节点权重值的系统节点权重表,如下表1所示。
表1系统节点权重表
节点ip | 节点权重值 |
ip1 | a |
ip2 | b |
…… | …… |
作为一个实施例,上述节点权重值的初始赋值设为10,本发明在此不做具体限制。
需要说明的是,当区块链系统中任意一个节点接收到新节点的连入请求时,该节点对新节点的ip地址进行广播,以便区块链系统中的生产节点接收到广播后将新节点的ip地址在系统节点权重表内检索以判断系统节点权重表中是否存在新节点的ip地址项,其中,如果存在,则保持新节点的ip地址项对应的节点权重值不变;如果未存在,则在系统节点权重表中创建新节点的ip地址项,并对新节点的ip地址项对应的节点权重值进行初始赋值。
步骤102,当区块链系统中的当前生产节点生产区块时,根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点。
作为一个实施例,根据系统节点权重表对每个节点的ip地址进行问询时,向每个节点发送问询信息,并在预设时间后判断是否接收到应答信息,其中,如果接收到当前节点的应答信息,则判断当前节点在线;如果未接收到当前节点的应答信息,则判断当前节点掉线。
需要说明的是,上述预设时间为发送问询信息后等待应答信息的时间,可设为30秒,本发明在此不做具体限制。
步骤103,如果存在掉线节点,则将掉线节点的节点权重值减1,并更新系统节点权重表。
也就是说,如果在预设时间内未接收到当前节点的应答信息,则将掉线节点的节点权重值减1,并更新系统节点权重表。
步骤104,当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点。
需要说明的是,根据每个节点的投票数和每个节点的节点权重值选取生产节点包括将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
也就是说,当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,根据每个节点的投票数和每个节点的节点权重值选取生产节点包括将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前N个节点为生产节点;其中N为预设值,表示系统指定的每次选取的生产节点数量。
根据本发明实施例的区块链系统的共识机制实现方法,首先在区块链系统初始化时,创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值;接着当区块链系统中的当前生产节点生产区块时,根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点,如果存在掉线节点,则将掉线节点的节点权重值减1,并更新系统节点权重表;然后当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
为了进一步理解上述技术方案,下面将通过图2对上述技术方案进行详细的说明。
图2为一个具体实施例的区块链系统的共识机制实现方法的流程示意图。
如图2所示,该区块链系统的共识机制实现方法包括以下步骤:
步骤201,在区块链系统初始化时,创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值。
作为一个实施例,上述节点权重值的初始赋值设为10,本发明在此不做具体限制。
需要说明的是,当区块链系统中任意一个节点接收到新节点的连入请求时,该节点对新节点的ip地址进行广播,以便区块链系统中的生产节点接收到广播后将新节点的ip地址在系统节点权重表内检索以判断系统节点权重表中是否存在新节点的ip地址项,其中,如果存在,则保持新节点的ip地址项对应的节点权重值不变;如果未存在,则在系统节点权重表中创建新节点的ip地址项,并对新节点的ip地址项对应的节点权重值进行初始赋值。
步骤202,当区块链系统中的当前生产节点生产区块时,根据系统节点权重表向每个节点发送问询信息。
步骤203,预设时间后判断是否接收到应答信息。如果是,则执行步骤204;如果否,则执行步骤205。
需要说明的是,上述预设时间为发送问询信息后等待应答信息的时间,可设为30秒,本发明在此不做具体限制。
步骤204,判断当前节点在线,不操作。之后执行步骤206。
也就是说,当判断当前节点在线时,则该在线节点的节点权重值不变。
步骤205,判断当前节点掉线,则将掉线节点的节点权重值减1,并更新系统节点权重表。
步骤206,当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值。
步骤207,将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数。
作为一个实施例,假设上表1中的节点ip1获得的投票数为q,则其加权得票数为a乘以q。
步骤208,根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
作为一个实施例,上述预设个节点表示系统指定的每次选取的生产节点数量。
根据本发明实施例的区块链系统的共识机制实现方法,首先在区块链系统初始化时,创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值;接着当区块链系统中的当前生产节点生产区块时,根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点,如果存在掉线节点,则将掉线节点的节点权重值减1,并更新系统节点权重表;然后当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
为了实现上述实施例,本发明实施例提出了一种计算机可读存储介质,其上存储有区块链系统的共识机制实现程序,该区块链系统的共识机制实现程序被处理器执行时实现如上述的区块链系统的共识机制实现方法。
根据本发明实施例的计算机可读存储介质,通过存储区块链系统的共识机制实现程序,这样区块链系统的共识机制实现程序被处理器执行时实现如上述的区块链系统的共识机制实现方法,由此,将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,从而大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
图3为根据本发明实施例提供的区块链系统的共识机制实现装置的方框结构示意图。如图3所示,该装置包括:创建模块301、问询模块302、赋值模块303、共识模块304。
其中,创建模块301,用于区块链系统初始化时创建系统节点权重表,该系统节点权重表包括节点ip地址项和对应的节点权重值。
问询模块302,用于在区块链系统中的当前生产节点生产区块时根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点。
赋值模块303,用于在区块链系统中存在掉线节点时将掉线节点的节点权重值减1,并更新系统节点权重表。
共识模块304,用于在基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点。
作为一个实施例,上述赋值模块还用于,当区块链系统中任意一个节点接收到新节点的连入请求时,该节点对新节点的ip地址进行广播,以便区块链系统中的生产节点接收到广播后将新节点的ip地址在系统节点权重表内检索以判断系统节点权重表中是否存在新节点的ip地址项,其中,如果存在,则保持新节点的ip地址项对应的节点权重值不变;如果未存在,则在系统节点权重表中创建新节点的ip地址项,并对新节点的ip地址项对应的节点权重值进行初始赋值。
作为一个实施例,上述问询模块进一步用于,对每个节点的ip地址进行问询时,向每个节点发送问询信息,并在预设时间后判断是否接收到应答信息,其中,如果接收到当前节点的应答信息,则判断当前节点在线;如果未接收到当前节点的应答信息,则判断当前节点掉线。
作为一个实施例,上述共识模块根据每个节点的投票数和每个节点的节点权重值选取生产节点时,进一步用于,将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
需要说明的是,前述对于区块链系统的共识机制实现方法的实施例的解释说明同样适用于本实施例的区块链系统的共识机制实现装置,此处不再赘述。
根据本发明实施例的区块链系统的共识机制实现装置,在区块链系统初始化时,通过创建模块创建系统节点权重表,其中,系统节点权重表包括节点ip地址项和对应的节点权重值,并且在区块链系统中的当前生产节点生产区块时,问询模块根据系统节点权重表对每个节点的ip地址进行问询以判断区块链系统中是否存在掉线节点,如果存在掉线节点,则通过赋值模块将掉线节点的节点权重值减1,并更新系统节点权重表,这样共识模块在基于dpos共识机制产生生产节点时获取每个节点的投票数,并调用系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点,从而在确定生产节点时将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
为实现上述实施例,本发明实施例提出了一种区块链系统,包括存储器、处理器及存储在存储器上并可在处理器上运行的区块链系统的共识机制实现程序,处理器执行区块链系统的共识机制实现程序时实现如上述的区块链系统的共识机制实现方法。
根据本发明实施例的区块链系统,通过存储器存储区块链系统的共识机制实现程序,这样区块链系统的共识机制实现的程序被处理器执行时实现如上述的区块链系统的共识机制实现方法,由此,本发明将节点离线时间与节点投票数统计权重进行挂钩,使得经常掉线的节点即使获得高票数,其投票数统计权重也不会太高,从而大大降低了常常掉线的节点成为区块生产节点的可能性,保证区块链系统的高效运转。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
应当注意的是,在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的部件或步骤。位于部件之前的单词“一”或“一个”不排除存在多个这样的部件。本发明可以借助于包括有若干不同部件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。
尽管已描述了本发明的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明范围的所有变更和修改。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。
在本发明的描述中,需要理解的是,术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括一个或者更多个该特征。在本发明的描述中,“多个”的含义是两个或两个以上,除非另有明确具体的限定。
在本发明中,除非另有明确的规定和限定,术语“安装”、“相连”、“连接”、“固定”等术语应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或成一体;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通或两个元件的相互作用关系。对于本领域的普通技术人员而言,可以根据具体情况理解上述术语在本发明中的具体含义。
在本发明中,除非另有明确的规定和限定,第一特征在第二特征“上”或“下”可以是第一和第二特征直接接触,或第一和第二特征通过中间媒介间接接触。而且,第一特征在第二特征“之上”、“上方”和“上面”可是第一特征在第二特征正上方或斜上方,或仅仅表示第一特征水平高度高于第二特征。第一特征在第二特征“之下”、“下方”和“下面”可以是第一特征在第二特征正下方或斜下方,或仅仅表示第一特征水平高度小于第二特征。
在本说明书的描述中,参考术语“一个实施例”、“一些实施例”、“示例”、“具体示例”、或“一些示例”等的描述意指结合该实施例或示例描述的具体特征、结构、材料或者特点包含于本发明的至少一个实施例或示例中。在本说明书中,对上述术语的示意性表述不应理解为必须针对的是相同的实施例或示例。而且,描述的具体特征、结构、材料或者特点可以在任一个或多个实施例或示例中以合适的方式结合。此外,在不相互矛盾的情况下,本领域的技术人员可以将本说明书中描述的不同实施例或示例以及不同实施例或示例的特征进行结合和组合。
尽管上面已经示出和描述了本发明的实施例,可以理解的是,上述实施例是示例性的,不能理解为对本发明的限制,本领域的普通技术人员在本发明的范围内可以对上述实施例进行变化、修改、替换和变型。
Claims (10)
1.一种区块链系统的共识机制实现方法,其特征在于,包括以下步骤:
在区块链系统初始化时,创建系统节点权重表,其中,所述系统节点权重表包括节点ip地址项和对应的节点权重值;
当所述区块链系统中的当前生产节点生产区块时,根据所述系统节点权重表对每个节点的ip地址进行问询以判断所述区块链系统中是否存在掉线节点;
如果存在掉线节点,则将所述掉线节点的节点权重值减1,并更新所述系统节点权重表;
当基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用所述系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点。
2.如权利要求1所述的区块链系统的共识机制实现方法,其特征在于,当所述区块链系统中任意一个节点接收到新节点的连入请求时,所述任意一个节点对所述新节点的ip地址进行广播,以便所述区块链系统中的生产节点接收到广播后将所述新节点的ip地址在所述系统节点权重表内检索以判断所述系统节点权重表中是否存在所述新节点的ip地址项,其中,
如果存在,则保持所述新节点的ip地址项对应的节点权重值不变;
如果未存在,则在所述系统节点权重表中创建所述新节点的ip地址项,并对所述新节点的ip地址项对应的节点权重值进行初始赋值。
3.如权利要求1或2所述的区块链系统的共识机制实现方法,其特征在于,对每个节点的ip地址进行问询时,向每个节点发送问询信息,并在预设时间后判断是否接收到应答信息,其中,
如果接收到当前节点的应答信息,则判断当前节点在线;
如果未接收到当前节点的应答信息,则判断当前节点掉线。
4.如权利要求1或2所述的区块链系统的共识机制实现方法,其特征在于,根据每个节点的投票数和每个节点的节点权重值选取生产节点,包括:
将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;
根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
5.一种计算机可读存储介质,其特征在于,其上存储有区块链系统的共识机制实现程序,该区块链系统的共识机制实现程序被处理器执行时实现如权利要求1-4中任一项所述的区块链系统的共识机制实现方法。
6.一种区块链系统的共识机制实现装置,其特征在于,包括:
创建模块,用于在区块链系统初始化时创建系统节点权重表,其中,所述系统节点权重表包括节点ip地址项和对应的节点权重值;
问询模块,用于在所述区块链系统中的当前生产节点生产区块时根据所述系统节点权重表对每个节点的ip地址进行问询以判断所述区块链系统中是否存在掉线节点;
赋值模块,用于在所述区块链系统中存在掉线节点时将所述掉线节点的节点权重值减1,并更新所述系统节点权重表;
共识模块,用于在基于dpos共识机制产生生产节点时,获取每个节点的投票数,并通过调用所述系统节点权重表以获取每个节点的节点权重值,以及根据每个节点的投票数和每个节点的节点权重值选取生产节点。
7.如权利要求6所述的区块链系统的共识机制实现装置,其特征在于,所述赋值模块还用于,当所述区块链系统中任意一个节点接收到新节点的连入请求时,所述任意一个节点对所述新节点的ip地址进行广播,以便所述区块链系统中的生产节点接收到广播后将所述新节点的ip地址在所述系统节点权重表内检索以判断所述系统节点权重表中是否存在所述新节点的ip地址项,其中,
如果存在,则保持所述新节点的ip地址项对应的节点权重值不变;
如果未存在,则在所述系统节点权重表中创建所述新节点的ip地址项,并对所述新节点的ip地址项对应的节点权重值进行初始赋值。
8.如权利要求6或7所述的区块链系统的共识机制实现装置,其特征在于,所述问询模块进一步用于,对每个节点的ip地址进行问询时,向每个节点发送问询信息,并在预设时间后判断是否接收到应答信息,其中,
如果接收到当前节点的应答信息,则判断当前节点在线;
如果未接收到当前节点的应答信息,则判断当前节点掉线。
9.如权利要求6或7所述的区块链系统的共识机制实现装置,其特征在于,所述共识模块根据每个节点的投票数和每个节点的节点权重值选取生产节点时,进一步用于,
将每个节点的投票数乘以对应的节点权重值以获得每个节点的加权得票数;
根据每个节点的加权得票数进行从大到小排序,以选取加权得票数最高的前预设个节点为生产节点。
10.一种区块链系统,其特征在于,包括如权利要求6-9中任一项所述的区块链系统的共识机制实现装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810967398.4A CN109347901B (zh) | 2018-08-23 | 2018-08-23 | 区块链系统的共识机制实现方法、介质、装置及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810967398.4A CN109347901B (zh) | 2018-08-23 | 2018-08-23 | 区块链系统的共识机制实现方法、介质、装置及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109347901A CN109347901A (zh) | 2019-02-15 |
CN109347901B true CN109347901B (zh) | 2020-12-15 |
Family
ID=65296676
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810967398.4A Active CN109347901B (zh) | 2018-08-23 | 2018-08-23 | 区块链系统的共识机制实现方法、介质、装置及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109347901B (zh) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109309671A (zh) * | 2018-09-14 | 2019-02-05 | 爱立信(中国)通信有限公司 | 一种基于区块链的通信设备数据管理方法和装置 |
CN110868337B (zh) * | 2019-11-15 | 2021-05-07 | 腾讯科技(深圳)有限公司 | 容错共识机制测试方法、装置、存储介质和计算机设备 |
CN113132126B (zh) * | 2019-12-30 | 2022-10-11 | 百度在线网络技术(北京)有限公司 | 投票权重确定方法及相关设备 |
CN111274314B (zh) * | 2020-01-14 | 2023-07-25 | 北京艾鸥科技有限公司 | 一种确定造块节点的方法、装置及电子设备 |
CN111539750B (zh) * | 2020-04-27 | 2023-05-05 | 中山大学 | 一种基于区块链和大数据技术的商品溯源系统 |
CN112436962B (zh) * | 2020-11-12 | 2023-04-18 | 迅鳐成都科技有限公司 | 区块链共识网络动态扩展方法、电子设备、系统及介质 |
CN113193992B (zh) * | 2021-04-16 | 2022-08-23 | 宁波图灵奇点智能科技有限公司 | 一种区块链平台、方法、装置、计算机设备及存储介质 |
CN113191780A (zh) * | 2021-05-31 | 2021-07-30 | 中国银行股份有限公司 | 基于区块链的高风险业务交易执行方法及装置 |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10304143B2 (en) * | 2016-05-05 | 2019-05-28 | Lance Timothy Kasper | Consensus system for manipulation resistant digital record keeping |
CA2992458A1 (en) * | 2015-07-14 | 2017-01-19 | Fmr Llc | Computationally efficient transfer processing, auditing, and search apparatuses, methods and systems |
US10230756B2 (en) * | 2015-11-25 | 2019-03-12 | International Business Machines Corporation | Resisting replay attacks efficiently in a permissioned and privacy-preserving blockchain network |
US10360191B2 (en) * | 2016-10-07 | 2019-07-23 | International Business Machines Corporation | Establishing overlay trust consensus for blockchain trust validation system |
CN107018125B (zh) * | 2017-02-17 | 2019-08-09 | 阿里巴巴集团控股有限公司 | 一种区块链系统、数据存储方法及装置 |
CN107146087A (zh) * | 2017-04-11 | 2017-09-08 | 广东网金控股股份有限公司 | 一种基于区块链联盟链的快速共识记账方法及系统 |
CN107341660B (zh) * | 2017-05-27 | 2021-06-29 | 唐盛(北京)物联技术有限公司 | 一种区块链底层共识机制以及基于该共识机制的区块链系统 |
CN108182635A (zh) * | 2017-12-18 | 2018-06-19 | 深圳前海微众银行股份有限公司 | 区块链共识方法、系统和计算机可读存储介质 |
CN108134706B (zh) * | 2018-01-02 | 2020-08-18 | 中国工商银行股份有限公司 | 区块链多活高可用系统、计算机设备以及方法 |
-
2018
- 2018-08-23 CN CN201810967398.4A patent/CN109347901B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN109347901A (zh) | 2019-02-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109347901B (zh) | 区块链系统的共识机制实现方法、介质、装置及系统 | |
EP3855702A1 (en) | Blockchain-based service processing method and system | |
CN105138371B (zh) | 软件升级方法及装置 | |
CN109218408B (zh) | 区块链系统的共识机制实现方法、介质、计算机设备及区块链系统 | |
CN109600305B (zh) | 提醒处理方法、设置方法及服务器、智能终端及介质 | |
CN107404541B (zh) | 一种对等网络传输邻居节点选择的方法及系统 | |
CN104156246B (zh) | 灰度升级的方法及装置 | |
CN110971485B (zh) | 业务指标的监控系统及方法 | |
CN111083179B (zh) | 物联网云平台、基于物联网云平台的设备交互方法及装置 | |
CN107623731B (zh) | 一种任务调度方法、客户端、服务集群及系统 | |
CN108965329B (zh) | 区块链系统的共识机制实现方法、介质、装置及系统 | |
CN110839061B (zh) | 数据分发方法、装置及存储介质 | |
CN113377817A (zh) | 数据处理方法、系统、设备及存储介质 | |
CN108768802B (zh) | 设备信息删除方法和装置、服务器及移动终端 | |
CN103428273B (zh) | 在异步式交互中进行响应询问的方法与装置 | |
CN115883391A (zh) | 单用户服务选择方法及装置 | |
CN107493308B (zh) | 一种发送消息的方法和装置及分布式设备集群系统 | |
CN113157249A (zh) | 标识号生成方法、装置、电子设备及存储介质 | |
CN106294721A (zh) | 一种集群数据统计及导出方法及装置 | |
CN107092526B (zh) | 任务处理方法及装置 | |
CN115242687B (zh) | 一种节点探活方法、装置、设备及介质 | |
CN111654527B (zh) | 一种消息收发的方法及装置 | |
CN113342859B (zh) | 一种信息处理方法、装置及电子设备 | |
CN112732414B (zh) | 一种oltp模式的分布式事务处理方法、系统及相关组件 | |
CN113067869B (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 | ||
CP03 | Change of name, title or address | ||
CP03 | Change of name, title or address |
Address after: 361000 B1F-065, Zone A, Huaxun Building, Software Park, Xiamen Torch Hi-tech Zone, Huli District, Xiamen City, Fujian Province Patentee after: Ke'an (Xiamen) Technology Co.,Ltd. Address before: B1f-065, zone a, Huaxun building, software park, torch hi tech Zone, Xiamen City, Fujian Province, 361000 Patentee before: TAILIAN (XIAMEN) TECHNOLOGY Co.,Ltd. |