CN115017236B - 基于区块链的数据处理方法、装置、设备及存储介质 - Google Patents

基于区块链的数据处理方法、装置、设备及存储介质 Download PDF

Info

Publication number
CN115017236B
CN115017236B CN202210777683.6A CN202210777683A CN115017236B CN 115017236 B CN115017236 B CN 115017236B CN 202210777683 A CN202210777683 A CN 202210777683A CN 115017236 B CN115017236 B CN 115017236B
Authority
CN
China
Prior art keywords
storage
continuation
intelligent contract
contract
renewal
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
Application number
CN202210777683.6A
Other languages
English (en)
Other versions
CN115017236A (zh
Inventor
荆博
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Baidu Netcom Science and Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Beijing Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN202210777683.6A priority Critical patent/CN115017236B/zh
Publication of CN115017236A publication Critical patent/CN115017236A/zh
Application granted granted Critical
Publication of CN115017236B publication Critical patent/CN115017236B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2228Indexing structures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6218Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Computing Systems (AREA)
  • Health & Medical Sciences (AREA)
  • Bioethics (AREA)
  • General Health & Medical Sciences (AREA)
  • Computer Hardware Design (AREA)
  • Computer Security & Cryptography (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本公开提供了一种基于区块链的数据处理方法、装置、设备及存储介质,涉及计算机领域,尤其涉及区块链技术,可应用于云平台。该方法包括:确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。通过上述技术方案能够提高数据存储效率。

Description

基于区块链的数据处理方法、装置、设备及存储介质
技术领域
本公开涉及计算机领域,尤其涉及区块链技术,可应用于云平台,具体涉及一种基于区块链的数据处理方法、装置、设备及存储介质。
背景技术
随着技术的进步,海量隐私、高价值数据需要安全存储。数据拥有方面临巨大的存储压力,需要一种存储服务,利用闲置的存储资源,对数据拥有方所生成的数据进行存储。
如何对数据存储过程进行处理至关重要。
发明内容
本公开提供了一种基于区块链的数据处理方法、装置、设备以及存储介质。
根据本公开的一方面,提供了一种基于区块链的数据处理方法,该方法包括:
确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;
在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
根据本公开的一方面,提供了一种基于区块链的数据处理装置,该装置包括:
续约条件确定模块,用于确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;
第二智能合约模块,用于在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
续约指令模块,用于向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
根据本公开的另一方面,提供了一种电子设备,该电子设备包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行本公开任意实施例所述基于区块链的数据处理方法。
根据本公开的另一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使计算机执行本公开任意实施例所述的基于区块链的数据处理方法。
根据本公开的技术,能够提高数据存储效率。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1是根据本公开实施例提供的一种基于区块链的数据处理方法的流程图;
图2a是根据本公开实施例提供的另一种基于区块链的数据处理方法的流程图;
图2b是根据本公开实施例提供的一种存储阶段的示意图;
图3是根据本公开实施例提供的又一种基于区块链的数据处理方法的流程图;
图4是根据本公开实施例提供的又一种基于区块链的数据处理方法的流程图;
图5是根据本公开实施例提供的一种基于区块链的数据处理装置的结构示意图;
图6是用来实现本公开实施例的基于区块链的数据处理方法的电子设备的框图。
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
图1是根据本公开实施例提供的一种基于区块链的数据处理方法的流程图。该方法适用于对区块链中的存储智能合约进行续约的情况。该方法可以由基于区块链的数据处理装置来执行,该装置可以采用软件和/或硬件的方式实现,并可集成于区块链网络中的区块生成节点中。如图1所示,本实施例的基于区块链的数据处理方法可以包括:
S101,确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;
S102,在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
S103,向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
在本公开实施例中,第一智能合约、第二智能合约均为数据拥有方与数据存储方之间的存储智能合约。存储智能合约可包括目标文件的文件标识、存储期限、参与者信息,存储期限可包括开始存储时间、结束存储时间,参与者信息可包括数据拥有方的公钥、存储节点的节点标识、存储节点对应的数据分片等。具体的,在数据拥有方需要存储目标文件的情况下,可调用租赁智能合约,向区块链网络发起招募事务请求,从区块链网络中获取参与招募的节点,并从参与招募的节点中选择至少两个存储节点;还为至少两个存储节点分别分配目标文件的数据分片,得到数据分片和存储节点之间的存储关系。
在本公开实施例中,目标文件可具有一个存储周期,也可具有至少两个存储周期,各存储周期的存储时长相同,以单个存储周期对应9000个区块高度为例,两个存储周期对应18000个区块高度。第一智能合约为目标文件在第一存储周期中的存储智能合约,第二智能合约为目标文件在第二存储周期中的存储智能合约。第一智能合约还包括续约参数,用于判断第一智能合约是否满足续约条件。示例性的,续约参数可为续约功能所处的状态、保证金、续约次数上限等。
具体的,在第一存储周期中,可根据第一智能合约中的续约参数确定第一智能合约是否满足续约条件,在不满足续约条件的情况下,在第一存储周期结束后,可结束数据分片和存储节点之间的存储关系,并删除存储节点中的数据分片。在第一存储周期结束后,如果数据拥有方需要继续存储目标文件,则重新招募存储节点,重新招募的存储节点重新拉取并存储数据分片。
其中,续约存储节点为续约的存储节点。在满足续约条件的情况下,根据至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;并且,向续约存储节点发送续约指令,用于指示续约存储节点将对应数据分片的存储期限延长至第二存储周期。也就是说,在满足续约条件的情况下,续约存储节点与数据分片之间的对应关系保持不变,续约存储节点不仅在第一存储周期存储对应的数据分片,还在第二存储周期存储对应的数据分片,避免了在第一存储周期结束后,续约存储节点销毁数据分片,数据拥有方重新招募存储节点。通过续约处理,实现了续约存储节点的数据续存,能够避免重新招募节点导致的性能开销和通信开销,从而提高数据存储效率。需要说明的是,第二智能合约不仅可复用第一智能合约中续约存储节点的存储关系,还可复用第一智能合约中存储费用、续约功能所处的状态等。
在生成第二智能合约过程中,还可扣除数据拥有方的部分保证金,作为第二存储周期的押金,在第二存储周期结束后,押金将自动分配给成功完成存储任务的存储节点;并且,还更新目标文件的历史续约次数,示例性的,在第一智能合约的历史续约次数为N的情况下,第二智能合约的历史续约次数为N+1,其中,N为自然数。第一存储周期可为任意存储周期。
本公开实施例的技术方案,在第一存储周期中的第一智能合约满足续约条件的情况下,根据续约存储节点生成第二存储周期的第二智能合约,且向续约存储节点发送续约指令,使续约存储节点在第一存储周期结束后继续存储对应的数据分片,能够避免续约存储节点销毁数据分片导致的性能开销和通信开销,从而提高数据存储效率。
图2a是根据本公开实施例提供的另一种基于区块链的数据处理方法的流程图。本实施例是在上述实施例的基础上提出的一种可选方案。参见图2a,本实施例的基于区块链的数据处理方法可以包括:
S201,检测第一存储周期的第一智能合约是否具有续约需求;
S202,在具有续约需求的情况下,根据第一智能合约的续约参数确定所述第一智能合约是否满足续约条件;
S203,在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
S204,向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
在本公开实施例中,区块生成节点在第一存储周期中,可检测第一智能合约是否具有续约需求,例如是否检测到第一智能合约的续约触发器,在检测到具有续约需求的情况下,还从第一智能合约中提取续约功能所处的状态、续约次数上限、保证金等续约参数,并根据续约参数确定第一智能合约是否满足续约条件。通过结合续约需求、续约参数判断第一智能合约是否满足续约条件,能够准确地定位需要续约的存储智能合约,提高续约处理、数据续存的准确性。
在一种可选实施方式中,所述检测第一存储周期的第一智能合约是否具有续约需求,包括:从所述第一智能合约获取第一存储周期的续约更新区块高度;在当前区块高度达到所述续约更新区块高度的情况下,确定所述第一智能合约具有续约需求。
在本公开实施例中,可将存储智能合约的存储周期划分成多个阶段。参考图2b,第一存储周期、第二存储周期均可包括合约开放期、续约更新期和续约结果发布期三个阶段,其中,合约开放期早于续约更新期,续约更新期早于续约结果发布期。仍以单个存储周期对应9000个区块高度为例,可将前3000个区块作为合约开放期,可将后3000个区块作为续约结果发布期,可从中间3000个区块中选择续约更新区块高度,例如可将第一存储周期中第5000个区块高度作为续约更新区块高度。需要说明的是,存储周期的阶段划分可根据数据拥有方的需求进行调整。
具体的,在当前区块高度达到第一存储周期的续约更新区块高度的情况下,确定第一智能合约处于第一存储周期的续约更新期,即第一智能合约具有续约需求。通过为第一存储周期设置续约更新区块高度,只有当前区块高度达到续约更新区块高度的情况下,才进一步判断第一智能合约是否满足续约条件,相比于在每个区块中均判断第一智能合约是否满足续约条件,能够减少当前区块下续约条件的判断量,从而节省资源。
在一种可选实施方式中,所述根据第一智能合约的续约参数确定所述第一智能合约是否满足续约条件,包括如下至少一项:确定第一智能合约的续约功能是否处于开启状态;确定第一智能合约的历史续约次数是否小于第一智能合约的续约次数上限;确定第一智能合约的保证金是否大于第二存储周期的存储费用。
其中,第一智能合约的续约功能可处于开启状态,也可处于关闭状态。第一智能合约的历史续约次数为目标文件在存储过程中的历史续约次数,第一智能合约的保证金由数据拥有方提供,也就是说,由数据拥有方账户转移到第一智能合约账户。
具体的,在第一智能合约的续约功能处于开启状态、第一智能合约的历史续约次数小于第一智能合约的续约次数上限且第一智能合约的保证金大于第二存储周期的存储费用的情况下,确定第一智能合约满足续约条件;否则,确定第一智能合约不满足续约条件,结束存储节点和数据分片之间的存储关系。通过结合第一智能合约的续约功能是否开启、历史续约次数是否达到续约次数上限、是否有足够的保证金,确定第一智能合约是否满足续约条件,能够提高续约处理的可靠性,还能够提高续约控制的灵活性。
本公开实施例的技术方案,通过结合续约需求检测、续约条件判断,能够准确地从区块链中定位出满足续约条件的存储智能合约,能够提高续约处理的可靠性,还能够提高续约控制的灵活性。
图3是根据本公开实施例提供的又一种基于区块链的数据处理方法的流程图。本实施例是在上述实施例的基础上提出的一种可选方案。参见图3,本实施例的基于区块链的数据处理方法可以包括:
S301,响应于数据拥有方对续约参数的更新请求,确定第一智能合约是否处于第一存储周期的合约开放期;
S302,在处于第一存储周期的合约开放期的情况下,从所述更新请求中提取续约参数的新参数内容,并将所述续约参数的新参数内容更新到所述第一智能合约中;
所述续约参数为续约功能所处的状态、保证金或续约次数上限;
S303,确定第一存储周期的第一智能合约是否满足续约条件;
其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;
S304,在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
S305,向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
在本公开实施例中,合约开放期是指允许更新续约参数的阶段。数据拥有方可根据更新需求,调用租赁智能合约发起对续约参数的更新请求,例如数据拥有方可判断第一智能合约的保证金是否足够支付第二存储周期的存储费用,如果不够,可追加保证金;还可判断第一智能合约的历史续约次数是否达到续约次数上限,如果已达到,无可用的续约次数,则可追加续约次数上限。
具体的,在第一存储周期中,获取数据拥有方对第一智能合约中续约参数的更新请求,响应于更新请求,确定是否处于第一存储周期的合约开放期;若是,则从更新请求中提取续约功能所处的新状态、追加的保证金、追加的续约次数上限等,作为续约参数的新参数内容,并将续约参数的新参数内容更新到第一智能合约中。如果未处于第一存储周期的合约开放期,则不影响第一智能合约的续约处理,例如可拒绝更新请求。通过为第一存储周期划分合约开放期,便于灵活地调控第一智能合约的续约参数,从而提高存储智能合约的续约灵活性。并且,合约开放期早于续约更新期,能够避免续约参数的更新与第一智能合约的续约过程冲突,例如在续约过程中续约功能由开启状态切换到关闭状态。通过在第一存储周期的合约开放期支持更新续约参数,能够灵活地更新续约参数,从而提高续约的灵活性。
在一种可选实施方式中,所述方法还包括:统计区块链网络中的平均存储费用;向所述数据拥有方发送所述平均存储费用,用于指示所述数据拥有方根据所述平均存储费用确定是否调整第二存储周期的存储费用或所述保证金。
具体的,区块生成节点可追踪第一存储周期中的各存储智能合约,统计各存储智能合约的平均存储费用,并向数据拥有方发送平均存储费用,使数据拥有方可根据平均存储费用确定是否对第二存储周期的存储费用进行调整,或者可根据平均存储费用确定保证金是否需要追加。通过实时统计各存储智能合约的平均存储费用,并向数据拥有方发送平均存储费用,便于数据拥有方灵活地调控第二存储周期的存储费用,也便于数据拥有方判断保证金是否足够支付第二存储周期的押金,从而进一步提高续约处理的灵活性与成功率。
在一种可选实施方式中,所述方法还包括:在所述更新请求为解约请求,且未处于第一存储周期的合约开放期的情况下,确定所述第二智能合约的续约功能为关闭状态。
在数据拥有方需要解约的情况下,如果处于第一存储周期的合约开放期,可将第一智能合约的续约功能设置为关闭状态,关闭自动续约功能,从而在第一存储周期结束后,结束存储节点和数据分片之间的存储关系。如果未处于第一存储周期的合约开放期,也就是说处于第一存储周期的续约更新期或续约结果发布期,则确定所述第二智能合约的续约功能为关闭状态。如果第二智能合约已生成,可将第二智能合约的续约功能设置为关闭状态;如果第二智能合约尚未生成,可先记录第二智能合约的续约功能为关闭状态,在生成第二智能合约后,将第二智能合约的续约功能设置为关闭状态,使第一存储周期结束后通过第二存储周期继续存储,在第二存储周期结束后,结束存储关系,实现解约。针对非续约开放期的解约请求,通过确定第二智能合约的续约功能为关闭状态,即使在第二智能合约尚未生成的情况下,也能够在第二存储周期结束后,停止存储,能够提高解约成功率。
在第一存储周期中,数据拥有方可确定自身是否希望续约,在希望续约的情况下,确定第一智能合约的保证金是否足够第二存储周期的存储费用,在保证金不够的情况下,可追加保证金;还可确定第一智能合约的历史续约次数是否达到续约次数上限,在达到的情况下,追加续约次数上限。具体的,可在第一存储周期的续约开放期,将追加的保证金、追加的续约次数上限写入第一智能合约。
在不希望续约的情况下,确定是否处于第一存储周期的续约开放期,若是,则将第一智能合约的续约功能设置为关闭状态,在第一存储周期结束后停止存储目标文件的数据分片;否则,确定所述第二智能合约的续约功能为关闭状态,为目标文件生成第二智能合约,使第二存储周期继续存储目标文件,且在第二存储周期结束后停止存储目标文件的数据分片。
本公开实施例的技术方案,通过根据数据拥有方对续约参数的更新请求,更新第一智能合约中的续约参数,或者确定第二智能合约中续约功能所处的状态,便于数据拥有方对存储智能合约进行灵活地调控,从而提高数据存储的灵活性。
图4是根据本公开实施例提供的又一种基于区块链的数据处理方法的流程图。本实施例是在上述实施例的基础上提出的一种可选方案。参见图4,本实施例的基于区块链的数据处理方法可以包括:
S401,确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;
在所述第一智能合约满足续约条件的情况下,继续执行S402-S406;否则,结束操作。
S402,根据所述至少两个存储节点的历史存储完成情况和/或历史心跳情况,确定所述存储节点的健康度;
S403,分别向所述至少两个存储节点发送续约请求,用于指示所述存储节点反馈续约响应信息;
S404,根据所述健康度和/或所述续约响应信息,从所述至少两个存储节点中确定续约存储节点;
S405,根据所述续约存储节点生成第二存储周期的第二智能合约;
S406,向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
其中,健康度用于表征存储节点稳定性的一种指标。健康度可以以分值的形式呈现;也可以以类别等其他形式呈现,例如健康度由低到高,可分为红色、黄色和绿色三个类别。历史存储完成情况用于表征存储节点对存储任务的完成率,可为成功完成的存储任务数量占分配到的总存储任务数量之间的比值。历史心跳情况为存储节点为证明其存活性所发送的心跳情况,可以包括存储节点在历史存储周期的心跳次数。进一步的,历史存储完成情况和历史心跳情况可存储于第一智能合约中。
具体的,可根据存储节点的历史存储完成情况,确定存储节点的任务成功完成比例;根据存储节点的历史心跳情况和期望心跳数据,确定存储节点的心跳比例;根据存储节点的任务成功完成比例和/或心跳比例,确定存储节点的健康度。还可分别向至少两个存储节点发送续约请求,由各存储节点选择是否接受续约,例如是否接受第二存储周期的存储报价。通过根据健康度、续约响应信息,从至少两个存储节点中选择稳定性满足要求,且接受续约的节点作为续约存储节点,将稳定性不满足要求或不接受续约的节点作为解约存储节点。通过结合健康度、续约响应信息确定续约存储节点,能够进一步提高续约的稳定性。
本公开实施例的技术方案,通过根据存储节点的健康度、续约响应信息确定续约存储节点,不仅能够提高数据存储的稳定性,还能够提高存储关系的灵活性。
在一种可选实施方式中,所述根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约,包括:在所述至少两个存储节点中存在解约存储节点的情况下,为所述解约存储节点选择新存储节点,且将所述解约节点对应的数据分片分配给所述新存储节点;根据所述续约存储节点对应的数据分片和新存储节点对应的数据分片,生成第二存储周期的第二智能合约。
其中,解决存储节点为至少两个存储节点中除续约存储节点之外的其他存储节点。区块生成节点可调用租赁智能合约,发起新的招募请求,招募新存储节点替换解约存储节点。将解约存储节点对应的数据分片分配给新存储节点,得到新存储节点对应的数据分片;并根据续约存储节点对应的数据分片和新存储节点对应的数据分片,生成第二存储周期的第二智能合约,在第一存储周期的续约结果发布期向区块链网络发布第二智能合约,将第二智能合约写入区块链中。相应地,续约存储节点继续存储对应的数据分片,新存储节点从数据拥有方拉取对应的数据分片,并存储对应的数据分片。
其中,第二智能合约中续约存储节点和新存储节点的开始存储时间不同,但是结束存储时间相同,并且,在第二存储周期中续约存储节点和新存储节点的阶段划分相同,也就是说,第二智能合约中各存储节点的合约开放期、续约更新期、续约结果发布期相同。另外,如果在第一存储周期的续约结果发布期结束前未招募到足够的新存储节点,则续约失败。第二智能合约通过复用续约存储节点的存储关系,并招募新存储节点代替解约存储节点,将解约存储节点对应的数据分片分配给新存储节点,能够提高保持第二存储周期的性能,并降低数据分片的通信开销。
图5是根据本公开实施例提供的一种基于区块链的数据处理装置的结构示意图。本实施例适用于对区块链中的存储智能合约进行续约的情况。该装置可以采用软件和/或硬件的方式实现,并可集成于区块链网络中的区块生成节点中。如图5所示,本实施例的基于区块链的数据处理装置500可以包括:
续约条件确定模块510,用于确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;
第二智能合约模块520,用于在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
续约指令模块530,用于向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
在一种可选实施方式中,所述续约条件确定模块510包括:
续约需求检测单元,用于检测第一存储周期的第一智能合约是否具有续约需求;
续约条件确定单元,用于在具有续约需求的情况下,根据第一智能合约的续约参数确定所述第一智能合约是否满足续约条件。
在一种可选实施方式中,所述续约需求检测单元具体用于:
从所述第一智能合约获取第一存储周期的续约更新区块高度;
在当前区块高度达到所述续约更新区块高度的情况下,确定所述第一智能合约具有续约需求。
在一种可选实施方式中,所述续约条件确定单元具体用于执行如下至少一项:
确定第一智能合约的续约功能是否处于开启状态;
确定第一智能合约的历史续约次数是否小于第一智能合约的续约次数上限;
确定第一智能合约的保证金是否大于第二存储周期的存储费用。
在一种可选实施方式中,该基于区块链的数据处理装置500还包括续约参数更新模块,所述续约参数更新模块包括:
合约开放期单元,用于响应于数据拥有方对续约参数的更新请求,确定第一智能合约是否处于第一存储周期的合约开放期;
续约参数更新单元,用于在处于第一存储周期的合约开放期的情况下,从所述更新请求中提取续约参数的新参数内容,并将所述续约参数的新参数内容更新到所述第一智能合约中;所述续约参数为续约功能所处的状态、保证金或续约次数上限。
在一种可选实施方式中,所述续约参数更新模块还包括存储费用处理单元,具体用于:
统计区块链网络中的平均存储费用;
向所述数据拥有方发送所述平均存储费用,用于指示所述数据拥有方根据所述平均存储费用确定是否调整第二存储周期的存储费用或所述保证金。
在一种可选实施方式中,所述续约参数更新模块还包括:
续约关闭单元,用于在所述更新请求为解约请求,且未处于第一存储周期的合约开放期的情况下,确定所述第二智能合约的续约功能为关闭状态。
在一种可选实施方式中,该基于区块链的数据处理装置500还包括续约节点确定模块,所述续约节点确定模块包括:
健康度单元,用于根据所述至少两个存储节点的历史存储完成情况和/或历史心跳情况,确定所述存储节点的健康度;
响应信息单元,用于分别向所述至少两个存储节点发送续约请求,用于指示所述存储节点反馈续约响应信息;
存储节点确定单元,用于根据所述健康度和/或所述续约响应信息,从所述至少两个存储节点中确定续约存储节点。
在一种可选实施方式中,所述第二智能合约模块520包括:
新节点单元,用于在所述至少两个存储节点中存在解约存储节点的情况下,为所述解约存储节点选择新存储节点,且将所述解约节点对应的数据分片分配给所述新存储节点;
第二智能合约单元,用于根据所述续约存储节点对应的数据分片和新存储节点对应的数据分片,生成第二存储周期的第二智能合约。
本公开实施例的技术方案,在第一存储周期中确定第一智能合约是否满足续约条件,在满足续约条件的情况下,结合存储节点的健康度、响应信息确定续约存储节点和解约存储节点,并重新招募新存储节点代替解约存储节点,根据续约存储节点对应的数据分片和新存储节点对应的数据分片生成第二智能合约,使续约存储节点在第二存储周期中继续存储对应的数据分片,实现了数据分片的续存,提高了数据存储的灵活性和稳定性。
本公开的技术方案中,所涉及的用户个人信息的获取,存储和应用等,均符合相关法律法规的规定,且不违背公序良俗。
根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
图6是用来实现本公开实施例的基于区块链的数据处理方法的电子设备的框图。图6示出了可以用来实施本公开的实施例的示例电子设备600的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图6所示,电子设备600包括计算单元601,其可以根据存储在只读存储器(ROM)602中的计算机程序或者从存储单元608加载到随机访问存储器(RAM)603中的计算机程序,来执行各种适当的动作和处理。在RAM 603中,还可存储电子设备600操作所需的各种程序和数据。计算单元601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
电子设备600中的多个部件连接至I/O接口605,包括:输入单元606,例如键盘、鼠标等;输出单元607,例如各种类型的显示器、扬声器等;存储单元608,例如磁盘、光盘等;以及通信单元609,例如网卡、调制解调器、无线通信收发机等。通信单元609允许电子设备600通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元601可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元601的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。计算单元601执行上文所描述的各个方法和处理,例如基于区块链的数据处理方法。例如,在一些实施例中,基于区块链的数据处理方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元608。在一些实施例中,计算机程序的部分或者全部可以经由ROM 602和/或通信单元609而被载入和/或安装到电子设备600上。当计算机程序加载到RAM 603并由计算单元601执行时,可以执行上文描述的基于区块链的数据处理方法的一个或多个步骤。备选地,在其他实施例中,计算单元601可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行基于区块链的数据处理方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、复杂可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,也可以为分布式系统的服务器,或者是结合了区块链的服务器。
人工智能是研究使计算机来模拟人的某些思维过程和智能行为(如学习、推理、思考、规划等)的学科,既有硬件层面的技术也有软件层面的技术。人工智能硬件技术一般包括如传感器、专用人工智能芯片、云计算、分布式存储、大数据处理等技术;人工智能软件技术主要包括计算机视觉技术、语音识别技术、自然语言处理技术及机器学习/深度学习技术、大数据处理技术、知识图谱技术等几大方向。
云计算(cloud computing),指的是通过网络接入弹性可扩展的共享物理或虚拟资源池,资源可以包括服务器、操作系统、网络、软件、应用和存储设备等,并可以按需、自服务的方式对资源进行部署和管理的技术体系。通过云计算技术,可以为人工智能、区块链等技术应用、模型训练提供高效强大的数据处理能力。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。

Claims (20)

1.基于区块链的数据处理方法,包括:
确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;所述存储关系在数据拥有方需要存储所述目标文件的情况下,调用租赁智能合约,从区块链网络中选择所述至少两个存储节点,并为所述至少两个存储节点分配目标文件的数据分片得到;
在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
2.根据权利要求1所述的方法,其中,所述确定第一存储周期的第一智能合约是否满足续约条件,包括:
检测第一存储周期的第一智能合约是否具有续约需求;
在具有续约需求的情况下,根据第一智能合约的续约参数确定所述第一智能合约是否满足续约条件。
3.根据权利要求2所述的方法,其中,所述检测第一存储周期的第一智能合约是否具有续约需求,包括:
从所述第一智能合约获取第一存储周期的续约更新区块高度;
在当前区块高度达到所述续约更新区块高度的情况下,确定所述第一智能合约具有续约需求。
4.根据权利要求2所述的方法,其中,所述根据第一智能合约的续约参数确定所述第一智能合约是否满足续约条件,包括如下至少一项:
确定第一智能合约的续约功能是否处于开启状态;
确定第一智能合约的历史续约次数是否小于第一智能合约的续约次数上限;
确定第一智能合约的保证金是否大于第二存储周期的存储费用。
5.根据权利要求1-4中任一项所述的方法,所述方法还包括:
响应于数据拥有方对续约参数的更新请求,确定第一智能合约是否处于第一存储周期的合约开放期;
在处于第一存储周期的合约开放期的情况下,从所述更新请求中提取续约参数的新参数内容,并将所述续约参数的新参数内容更新到所述第一智能合约中;所述续约参数为续约功能所处的状态、保证金或续约次数上限。
6.根据权利要求5所述的方法,所述方法还包括:
统计区块链网络中的平均存储费用;
向所述数据拥有方发送所述平均存储费用,用于指示所述数据拥有方根据所述平均存储费用确定是否调整第二存储周期的存储费用或所述保证金。
7.根据权利要求5所述的方法,所述方法还包括:
在所述更新请求为解约请求,且未处于第一存储周期的合约开放期的情况下,确定所述第二智能合约的续约功能为关闭状态。
8.根据权利要求1-4中任一项所述的方法,其中,所述续约存储节点通过如下方式确定:
根据所述至少两个存储节点的历史存储完成情况和/或历史心跳情况,确定所述存储节点的健康度;
分别向所述至少两个存储节点发送续约请求,用于指示所述存储节点反馈续约响应信息;
根据所述健康度和/或所述续约响应信息,从所述至少两个存储节点中确定续约存储节点。
9.根据权利要求1-4中任一项所述的方法,其中,所述根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约,包括:
在所述至少两个存储节点中存在解约存储节点的情况下,为所述解约存储节点选择新存储节点,且将所述解约节点对应的数据分片分配给所述新存储节点;
根据所述续约存储节点对应的数据分片和新存储节点对应的数据分片,生成第二存储周期的第二智能合约。
10.基于区块链的数据处理装置,包括:
续约条件确定模块,用于确定第一存储周期的第一智能合约是否满足续约条件;其中,所述第一智能合约包括目标文件的数据分片和至少两个存储节点之间的存储关系;所述存储关系在数据拥有方需要存储所述目标文件的情况下,调用租赁智能合约,从区块链网络中选择所述至少两个存储节点,并为所述至少两个存储节点分配目标文件的数据分片得到;
第二智能合约模块,用于在所述第一智能合约满足续约条件的情况下,根据所述至少两个存储节点中的续约存储节点生成第二存储周期的第二智能合约;
续约指令模块,用于向所述续约存储节点发送续约指令,用于指示所述续约存储节点将对应数据分片的存储期限延长至所述第二存储周期。
11.根据权利要求10所述的装置,其中,所述续约条件确定模块包括:
续约需求检测单元,用于检测第一存储周期的第一智能合约是否具有续约需求;
续约条件确定单元,用于在具有续约需求的情况下,根据第一智能合约的续约参数确定所述第一智能合约是否满足续约条件。
12.根据权利要求11所述的装置,其中,所述续约需求检测单元具体用于:
从所述第一智能合约获取第一存储周期的续约更新区块高度;
在当前区块高度达到所述续约更新区块高度的情况下,确定所述第一智能合约具有续约需求。
13.根据权利要求11所述的装置,其中,所述续约条件确定单元具体用于执行如下至少一项:
确定第一智能合约的续约功能是否处于开启状态;
确定第一智能合约的历史续约次数是否小于第一智能合约的续约次数上限;
确定第一智能合约的保证金是否大于第二存储周期的存储费用。
14.根据权利要求10-13中任一项所述的装置,所述装置还包括续约参数更新模块,所述续约参数更新模块包括:
合约开放期单元,用于响应于数据拥有方对续约参数的更新请求,确定第一智能合约是否处于第一存储周期的合约开放期;
续约参数更新单元,用于在处于第一存储周期的合约开放期的情况下,从所述更新请求中提取续约参数的新参数内容,并将所述续约参数的新参数内容更新到所述第一智能合约中;所述续约参数为续约功能所处的状态、保证金或续约次数上限。
15.根据权利要求14所述的装置,所述续约参数更新模块还包括存储费用处理单元,具体用于:
统计区块链网络中的平均存储费用;
向所述数据拥有方发送所述平均存储费用,用于指示所述数据拥有方根据所述平均存储费用确定是否调整第二存储周期的存储费用或所述保证金。
16.根据权利要求14所述的装置,所述续约参数更新模块还包括:
续约关闭单元,用于在所述更新请求为解约请求,且未处于第一存储周期的合约开放期的情况下,确定所述第二智能合约的续约功能为关闭状态。
17.根据权利要求10-13中任一项所述的装置,其中,所述装置还包括续约节点确定模块,所述续约节点确定模块包括:
健康度单元,用于根据所述至少两个存储节点的历史存储完成情况和/或历史心跳情况,确定所述存储节点的健康度;
响应信息单元,用于分别向所述至少两个存储节点发送续约请求,用于指示所述存储节点反馈续约响应信息;
存储节点确定单元,用于根据所述健康度和/或所述续约响应信息,从所述至少两个存储节点中确定续约存储节点。
18.根据权利要求10-13中任一项所述的装置,其中,所述第二智能合约模块包括:
新节点单元,用于在所述至少两个存储节点中存在解约存储节点的情况下,为所述解约存储节点选择新存储节点,且将所述解约节点对应的数据分片分配给所述新存储节点;
第二智能合约单元,用于根据所述续约存储节点对应的数据分片和新存储节点对应的数据分片,生成第二存储周期的第二智能合约。
19. 一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-9中任一项所述的基于区块链的数据处理方法。
20.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使计算机执行根据权利要求1-9中任一项所述的基于区块链的数据处理方法。
CN202210777683.6A 2022-07-04 2022-07-04 基于区块链的数据处理方法、装置、设备及存储介质 Active CN115017236B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210777683.6A CN115017236B (zh) 2022-07-04 2022-07-04 基于区块链的数据处理方法、装置、设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210777683.6A CN115017236B (zh) 2022-07-04 2022-07-04 基于区块链的数据处理方法、装置、设备及存储介质

Publications (2)

Publication Number Publication Date
CN115017236A CN115017236A (zh) 2022-09-06
CN115017236B true CN115017236B (zh) 2023-03-21

Family

ID=83078644

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210777683.6A Active CN115017236B (zh) 2022-07-04 2022-07-04 基于区块链的数据处理方法、装置、设备及存储介质

Country Status (1)

Country Link
CN (1) CN115017236B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115509465B (zh) * 2022-11-21 2023-03-28 杭州字节方舟科技有限公司 一种扇区管理方法、装置、电子设备及存储介质

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108681943A (zh) * 2018-05-18 2018-10-19 百度在线网络技术(北京)有限公司 一种区块链网络的数据处理方法、装置、设备及存储介质
CN113900598A (zh) * 2021-12-10 2022-01-07 北京百度网讯科技有限公司 基于区块链的数据存储方法、装置、设备以及存储介质

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110175208A (zh) * 2019-04-10 2019-08-27 阿里巴巴集团控股有限公司 基于区块链的租赁方法和装置

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108681943A (zh) * 2018-05-18 2018-10-19 百度在线网络技术(北京)有限公司 一种区块链网络的数据处理方法、装置、设备及存储介质
CN113900598A (zh) * 2021-12-10 2022-01-07 北京百度网讯科技有限公司 基于区块链的数据存储方法、装置、设备以及存储介质

Also Published As

Publication number Publication date
CN115017236A (zh) 2022-09-06

Similar Documents

Publication Publication Date Title
CN112559182B (zh) 资源分配方法、装置、设备及存储介质
CN115017236B (zh) 基于区块链的数据处理方法、装置、设备及存储介质
CN114879948B (zh) 基于WebAssembly的智能合约处理方法、装置、设备及存储介质
CN112905314A (zh) 异步处理方法、装置、电子设备、存储介质、及路侧设备
CN115658311A (zh) 一种资源的调度方法、装置、设备和介质
CN114968967A (zh) 文件管理方法、装置、设备和存储介质
CN114924745A (zh) 深度学习编译器的运行方法、装置及电子设备
CN114416357A (zh) 容器组的创建方法、装置、电子设备和介质
EP4235424A1 (en) Resource control method for function computing, device, and medium
CN115328621B (zh) 基于区块链的事务处理方法、装置、设备及存储介质
CN115827265A (zh) 事务处理方法、装置、设备和存储介质
CN114051057A (zh) 云设备排队时长的确定方法、装置、电子设备和介质
CN114327392A (zh) 一种数据处理方法、装置及电子设备
CN115293126A (zh) 大规模文本数据的去重方法及装置、电子设备和存储介质
CN115495151A (zh) 规则引擎的迁移方法、装置、设备、存储介质及程序产品
CN115934178A (zh) 一种代码运行方法、装置、电子设备及存储介质
CN114185661A (zh) 一种任务处理方法、装置、设备以及存储介质
CN114090247A (zh) 用于处理数据的方法、装置、设备以及存储介质
CN117579597A (zh) 网络协议地址的分配方法及装置、电子设备和存储介质
CN115129266B (zh) 基于区块链的数据存储方法、装置、设备及存储介质
CN115357346B (zh) 基于区块链的事务处理方法、装置、电子设备及介质
CN115379000B (zh) 服务平台的扩容方法、装置、电子设备以及存储介质
CN117575467A (zh) 虚拟设备管理方法及装置、系统、电子设备和存储介质
CN117198040A (zh) 路口通行信息的获取方法、装置、电子设备与可读存储介质
CN115269112A (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