[發明專利]基于區塊鏈的數據處理方法、裝置、設備及可讀存儲介質在審
| 申請號: | 202010192945.3 | 申請日: | 2020-03-18 |
| 公開(公告)號: | CN111368005A | 公開(公告)日: | 2020-07-03 |
| 發明(設計)人: | 劉攀 | 申請(專利權)人: | 財付通支付科技有限公司 |
| 主分類號: | G06F16/27 | 分類號: | G06F16/27;G06F16/901;H04L12/26;H04L29/08 |
| 代理公司: | 廣州三環專利商標代理有限公司 44202 | 代理人: | 熊永強;杜維 |
| 地址: | 518000 廣東省深圳市*** | 國省代碼: | 廣東;44 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 基于 區塊 數據處理 方法 裝置 設備 可讀 存儲 介質 | ||
1.一種基于區塊鏈的數據處理方法,其特征在于,包括:
第一節點在第一心跳周期中向至少兩個第二節點發送第一區塊高度,接收處于所述第一心跳周期中的所述至少兩個第二節點所發送的第二區塊高度;
若所述第一節點在同步檢測狀態下檢測到所述第一區塊高度和最大的第二區塊高度之間的差異不滿足共識條件,則進行區塊同步處理;
所述第一節點在第二心跳周期中向所述第二節點發送區塊同步后的第一區塊高度,接收處于所述第二心跳周期中的所述至少兩個第二節點發送的第三區塊高度;
若所述第一節點在所述同步檢測狀態下檢測到所述區塊同步后的第一區塊高度和所述最大的第二區塊高度之間的差異滿足共識條件,則根據所述第三區塊高度確定滿足所述共識條件的第二節點的數量,作為第一目標數量;
若所述第一目標數量大于數量閾值,則所述第一節點將所述同步檢測狀態切換為同步完成狀態,在所述同步完成狀態下進入共識業務流程。
2.根據權利要求1所述的方法,其特征在于,所述若所述第一節點在同步檢測狀態下檢測到所述第一區塊高度和最大的第二區塊高度之間的差異不滿足共識條件,則進行區塊同步處理,包括:
所述第一節點在所述同步檢測狀態下,確定所述第一區塊高度以及最大的第二區塊高度之間的第一高度差異參數;
若所述第一區塊高度小于所述最大的第二區塊高度,且所述第一高度差異參數大于參數閾值,則確定所述第一區塊高度和所述最大的第二區塊高度之間的差異不滿足共識條件,根據所述第一高度差異參數從目標第二節點拉取待同步區塊,進行區塊同步;所述目標第二節點為所述至少兩個第二節點中具有所述最大的第二區塊高度的第二節點。
3.根據權利要求1所述的方法,其特征在于,所述若所述第一節點在所述同步檢測狀態下檢測到所述區塊同步后的第一區塊高度和所述最大的第二區塊高度之間的差異滿足共識條件,則根據所述第三區塊高度確定滿足所述共識條件的第二節點的數量,作為第一目標數量,包括:
所述第一節點在所述同步檢測狀態下,確定所述區塊同步后的第一區塊高度以及所述最大的第二區塊高度之間的第二高度差異參數;
若所述第二高度差異參數小于或等于參數閾值,則確定所述區塊同步后的第一區塊高度和所述最大的第二區塊高度之間的差異滿足共識條件,觸發獲取所述第三區塊高度與所述最大的第二區塊高度之間的第三高度差異參數;
統計所述第三高度差異參數小于或等于所述參數閾值的第二節點的數量,作為第一目標數量。
4.根據權利要求1所述的方法,其特征在于,還包括:
所述第一節點在初始化狀態下進行節點初始化;
當完成節點初始化時,將所述初始化狀態切換為配置狀態,在所述配置狀態下從智能合約中獲取共識配置信息,根據所述共識配置信息進行配置處理;
當完成配置處理時,所述第一節點將所述配置狀態切換為心跳觸發狀態,在所述心跳觸發狀態下觸發心跳機制;所述心跳機制用于產生所述第一心跳周期和所述第二心跳周期。
5.根據權利要求1所述的方法,其特征在于,還包括:
在共識業務流程中,處于所述同步完成狀態的所述第一節點在第三心跳周期中向所述至少兩個第二節點發送第一共識消息;
接收處于所述第三心跳周期中的所述至少兩個第二節點所發送的第二共識消息;
所述第一節點根據所述第一共識消息以及所述第二共識消息,進行狀態切換檢測;
若狀態切換檢測出所述第一節點從所述同步完成狀態切換為所述同步檢測狀態,則暫停所述第一節點的共識業務流程;
若狀態切換檢測出所述第一節點保持所述同步完成狀態,則繼續進行共識業務流程。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于財付通支付科技有限公司,未經財付通支付科技有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202010192945.3/1.html,轉載請聲明來源鉆瓜專利網。





