CN112565448A - 基于区块链的电子存证节点选择方法和电子设备 - Google Patents

基于区块链的电子存证节点选择方法和电子设备 Download PDF

Info

Publication number
CN112565448A
CN112565448A CN202011493720.8A CN202011493720A CN112565448A CN 112565448 A CN112565448 A CN 112565448A CN 202011493720 A CN202011493720 A CN 202011493720A CN 112565448 A CN112565448 A CN 112565448A
Authority
CN
China
Prior art keywords
storage
node
storage node
electronic file
nodes
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.)
Withdrawn
Application number
CN202011493720.8A
Other languages
English (en)
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.)
Ningbo Yunlin Information Technology Co ltd
Original Assignee
Ningbo Yunlin Information 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 Ningbo Yunlin Information Technology Co ltd filed Critical Ningbo Yunlin Information Technology Co ltd
Priority to CN202011493720.8A priority Critical patent/CN112565448A/zh
Publication of CN112565448A publication Critical patent/CN112565448A/zh
Withdrawn legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1097Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/104Peer-to-peer [P2P] networks
    • H04L67/1074Peer-to-peer [P2P] networks for supporting data block transmission mechanisms
    • H04L67/1078Resource delivery mechanisms
    • H04L67/108Resource delivery mechanisms characterised by resources being split in blocks or fragments
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/50Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using hash chains, e.g. blockchains or hash trees

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本公开的实施例公开了基于区块链的电子存证节点选择方法和电子设备。该方法的一具体实施方式包括:获取待存储的电子文件;对电子文件进行分片处理,以得到电子文件分片集合;基于存储节点集合,生成存储节点序列;将电子文件分片集合中的第一数目个电子文件分片,分别存储到存储节点序列中的前第一数目个存储节点中;根据电子文件分片集合和存储节点序列的对应关系,生成存储记录表;基于存储记录表,更新区块链。这种方法对待存储的电子文件进行分片处理,得到具有冗余度的电子文件分片集合。对存储节点集合进行排序,选择最佳节点存储电子文件,从而能够将电子文件存储在性能最优的存储节点中,提高电子文件的存储和查询效率。

Description

基于区块链的电子存证节点选择方法和电子设备
技术领域
本公开实施例涉及区块链和电子存证领域,具体涉及一种基于区块链的电子存证数据存储方法、电子设备。
背景技术
随着区块链技术的不断发展,基于区块链平台设计和集成了大量的功能模块,衍生出了存证系统、溯源系统、金融交易系统等多种区块链应用技术综合性平台。电子文件是信息通信的产物,电子文件是一种便于浏览、举证、鉴定和保存的系统结构。依托于去中心化的区块链,电子存证技术得以快速发展,实现电子文件的高效存储、共享和验证,并能在电子文件分享过程中保证数据安全性。
然而,当采用上述方法在区块链中进行电子文件存储时,仍会面临以下技术问题:
第一,作为电子文件存储和查询共享系统,基于区块链的电子文件存证系统依靠多个存储节点来完成对电子文件的存储和校对。随机选择的存储节点存在存储性能差、网络速度慢等问题,导致电子文件查询和存储的速率不能满足实时业务的要求。
第二,由于电子存证业务的特殊性,系统中的电子文件存在被恶意攻击或篡改的风险,一旦电子文件遭到破坏,电子文件将无法用于电子存证业务。
发明内容
本公开的内容部分用于以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。本公开的内容部分并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。
本公开的一些实施例提出了基于区块链的电子存证节点选择方法和电子设备,来解决以上背景技术部分提到的技术问题中的一项或多项。
第一方面,本公开的一些实施例提供了一种基于区块链的电子存证节点选择方法,该方法包括:获取待存储的电子文件;对电子文件进行分片处理,以得到电子文件分片集合;基于存储节点集合,生成存储节点序列;将电子文件分片集合中的第一数目个电子文件分片,分别存储到存储节点序列中的前第一数目个存储节点中;根据电子文件分片集合和存储节点序列的对应关系,生成存储记录表;基于存储记录表,更新区块链。
第二方面,本公开的一些实施例提供了一种电子设备,包括:一个或多个处理器;存储装置,其上存储有一个或多个程序,当一个或多个程序被一个或多个处理器执行,使得一个或多个处理器实现如第一方面中任一的方法。
第三方面,本公开的一些实施例提供了一种计算机可读存储介质,其上存储有计算机程序,其中,程序被处理器执行时实现如第一方面中任一的方法。
本公开的上述各个实施例具有如下有益效果:首先,将获取的电子文件进行直接切分以得到过程电子文件数据块集合,利用编码矩阵去乘过程电子文件数据块集合,得到电子文件分片集合。电子文件分片集合具有冗余度,在存在文件破坏的情况下能够根据电子文件分片集合恢复出原始的电子文件。其次,对区块链中的存储节点进行性能排序。根据存储节点集合中性能较有的上限节点集合和性能较差的下限节点集合,计算得到存储节点的距离指标,以得到距离指标集合。根据距离指标集合得到存储节点序列。然后,将电子文件分片集合存储在存储节点序列的前第一数目个存储节点中,以得到存储记录表。最后,将存储记录表记录到区块链中。利用区块链的去中心化、可追溯特点,实现基于区块链的电子文件存储。这种方法借助区块链技术实现电子文件的可靠存储。对待存储的电子文件进行分片处理,得到具有冗余度的电子文件分片集合,以保证在出现文件破坏或丢失情况下能够有足够的信息恢复电子文件。对存储节点集合进行排序,选择最佳节点存储电子文件,从而能够将电子文件存储在性能最优的存储节点中,提高电子文件的存储和查询效率。
附图说明
结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,原件和元素不一定按照比例绘制。
图1是本公开的一些实施例可以应用于其中的示例性系统的架构图;
图2是根据本公开的一些实施例的基于区块链的电子存证节点选择方法的一些实施例的流程图;
图3是根据本公开的一些实施例的基于区块链的电子存证节点选择方法的一个应用场景的示意图;
图4是适于用来实现本公开的一些实施例的电子设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例。相反,提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。在不冲突的情况下,本公开中的实施例及实施例中的特征可以相互组合。
需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
下面将参考附图并结合实施例来详细说明本公开。
图1示出了可以应用本公开的基于区块链的电子存证节点选择方法的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如文件存储应用、数据分析应用、自然语言处理应用等。
终端设备101、102、103可以是硬件,也可以是软件。当终端设备101、102、103为硬件时,可以是具有显示屏的各种终端设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。当终端设备101、102、103为软件时,可以安装在上述所列举的终端设备中。其可以实现成多个软件或软件模块(例如用来提供电子文件输入等),也可以实现成单个软件或软件模块。在此不做具体限定。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103输入的目标电子文件进行存储的服务器等。服务器可以对接收到的电子文件进行切分以及分发、存储等处理,并将处理结果(例如存储记录表)反馈给终端设备。
需要说明的是,本公开实施例所提供的基于区块链的电子存证节点选择方法可以由服务器105,也可以由终端设备执行。
需要指出的是,服务器105的本地也可以直接存储电子文件,此时,示例性系统架构100可以不包括终端设备101、102、103和网络104。
还需要指出的是,终端设备101、102、103中也可以安装有存储类应用,此时,切分处理方法也可以由终端设备101、102、103执行。此时,示例性系统架构100也可以不包括服务器105和网络104。
需要说明的是,服务器105可以是硬件,也可以是软件。当服务器105为硬件时,可以实现成多个服务器组成的分布式服务器集群,也可以实现成单个服务器。当服务器为软件时,可以实现成多个软件或软件模块(例如用来提供存储服务),也可以实现成单个软件或软件模块。在此不做具体限定。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本公开的基于区块链的电子存证节点选择方法的一些实施例的流程200。该基于区块链的电子存证节点选择方法,包括以下步骤:
步骤201,获取待存储的电子文件。
在一些实施例中,基于区块链的电子存证节点选择方法的执行主体(例如图1所示的电子设备)可以直接获取待存储的电子文件。可选的,电子文件是信息通讯的产物,可以包括但不限于以下之一:文件、通知、合同、交易凭证、技术和商业秘密。
步骤202,对电子文件进行分片处理,以得到电子文件分片集合。
在一些实施例中,上述执行主体对电子文件进行分片处理,以得到电子文件分片集合。具体的,电子文件分片集合包括第一数目个电子文件分片。
可选的,上述执行主体将电子文件切分为第二数目个数据块,生成过程电子文件数据块集合。利用下式,生成编码矩阵:
G=[In×n;Bm×n],
其中,n为第二数目,I为单位对角矩阵,I包括n行和n列。B为各列为几何级数的矩阵,B包括m行和n列,m=n+δ,δ为冗余位数值,δ可以是任何整数。编码矩阵中有δ位的冗余位数。待存储的电子文件包括n个数据块,编码矩阵中的B包括的是n+δ个行。
利用编码矩阵G去乘过程电子文件数据块集合,得到电子文件分片集合。
上述步骤202中的可选内容,即:“生成编码矩阵进行电子文件分片集合处理的技术内容”作为本公开的实施例的一个发明点,解决了背景技术提及的技术问题二“由于电子存证业务的特殊性,系统中的电子文件存在被恶意攻击或篡改的风险,一旦电子文件遭到破坏,电子文件将无法用于电子存证业务。”。导致电子文件存在被破坏风险的因素往往如下:现有的区块链加密方案无法实现对被破坏的电子文件进行恢复的效果。如果解决了上述因素,就能达到恢复被破坏的电子文件的效果。为了达到这一效果,本公开引入了编码矩阵对电子文件进行加密。首先,将电子文件进行直接切分,生成切分后的电子文件块,以得到过程电子文件数据块集合。其次,生成具有冗余度为δ的编码矩阵。然后,利用编码矩阵G去乘过程电子文件数据块集合,得到电子文件分片集合。利用具有冗余度的编码矩阵去成过程电子文件数据块集合,能够使得到的电子文件分片集合具有δ位的冗余信息。δ个电子分片文件可以用于恢复被破坏或篡改、丢失的电子文件中的数据。通过上述处理步骤,能够得到具有冗余度的电子文件分片集合,以保证在出现文件破坏或丢失情况下能够有足够的信息恢复电子文件,从而解决了技术问题二。
步骤203,基于存储节点集合,生成存储节点序列。
在一些实施例中,上述执行主体基于存储节点集合,生成存储节点序列。具体的,存储节点集合包括第三数目个存储节点。存储节点用于存储电子文件分片。
可选的,基于存储节点集合,确定上限节点集合和下限节点集合。利用下式,基于存储节点集合确定上限节点,以得到上限节点集合:
Figure BDA0002841442050000071
其中,max{}表示取最大值操作,s表示存储节点,k为序号,k的取值为1或2。上限节点集合包括2个上限节点,Δ为上限节点标记符号,
Figure BDA0002841442050000072
表示第k个上限节点,sk表示第k个性能指标。响应于k=1,sk表征网络性能指标。响应于k=2,sk表征存储性能指标。n为存储节点集合中的存储节点数目。
Figure BDA0002841442050000073
表示第一个存储节点的第k个性能指标,
Figure BDA0002841442050000074
表示第二个存储节点的第k个性能指标,
Figure BDA0002841442050000075
表示第n个存储节点的第k个性能指标。具体的,上限节点可以是根据网络性和存储性能同时计算得到的。
利用下式,基于存储节点集合确定下限节点,以得到下限节点集合:
Figure BDA0002841442050000076
其中,min{}表示取最小值操作,s表示存储节点,k为序号,k的取值为1或2。下限节点集合包括2个下限节点,
Figure BDA0002841442050000077
为下限节点标记符号。
Figure BDA0002841442050000078
表示第k个下限节点,sk表示第k个性能指标。响应于k=1,sk表征网络性能指标。响应于k=2,sk表征存储性能指标。n为存储节点集合中的存储节点数目。
Figure BDA0002841442050000079
表示第一个存储节点的第k个性能指标,
Figure BDA00028414420500000710
表示第二个存储节点的第k个性能指标,
Figure BDA00028414420500000711
表示第n个存储节点的第k个性能指标。具体的,下限节点可以是根据网络性和存储性能同时计算得到的。
可选的,基于上限节点集合和下限节点集合,生成距离指标集合。其中,距离指标对应存储节点。对于存储节点集合中的每个存储节点,利用下式,基于上限节点集合,计算该存储节点的最优距离,以得到最优距离集合:
Figure BDA00028414420500000712
其中,s表示存储节点,k为序号,k的取值为1或2。上限节点集合包括2个上限节点,Δ为上限节点标记符号。
Figure BDA00028414420500000713
表示第k个上限节点,sk表示第k个性能指标。响应于k=1,sk表征网络性能指标。响应于k=2,sk表征存储性能指标。i表示存储节点计数序号,
Figure BDA00028414420500000714
表示第i个存储节点的第k个性能指标,
Figure BDA00028414420500000715
表示第i个存储节点的最优距离。
对于存储节点集合中的每个存储节点,利用下式,基于下限节点集合,计算该存储节点的最差距离,以得到最差距离集合:
Figure BDA0002841442050000081
其中,s表示存储节点,k为序号,k的取值为1或2。下限节点集合包括2个下限节点,
Figure BDA0002841442050000082
为下限节点标记符号。
Figure BDA0002841442050000083
表示第k个下限节点,sk表示第k个性能指标。响应于k=1,sk表征网络性能指标。响应于k=2,sk表征存储性能指标。i表示存储节点计数序号,
Figure BDA0002841442050000084
表示第i个存储节点的第k个性能指标,
Figure BDA0002841442050000085
表示第i个存储节点的最差距离。
对于存储节点集合中的每个存储节点,基于最优距离集合和所述最差距离集合,利用下式计算该存储节点的距离指标,以得到距离指标集合:
Figure BDA0002841442050000086
其中,i表示存储节点计数序号。
Figure BDA0002841442050000087
表示第i个存储节点的最差距离,
Figure BDA0002841442050000088
表示第i个存储节点的最优距离。mi表示第i个存储节点的距离指标。
对距离指标集合中的每个距离指标,按照数值从小到大重新排序,生成距离指标序列。基于所述距离指标序列对存储节点集合进行排序,以得到存储节点序列。具体的,将序号为t的距离指标对应的存储节点放置在存储节点序列中的第t个位置。
上述步骤203中的可选内容,即:“根据距离指标生成存储节点序列的技术内容”作为本公开的实施例的一个发明点,解决了背景技术提及的技术问题一“作为电子文件存储和查询共享系统,基于区块链的电子文件存证系统依靠多个存储节点来完成对电子文件的存储和校对。随机选择的存储节点存在存储性能差、网络速度慢等问题,导致电子文件查询和存储的速率不能满足实时业务的要求。”。导致电子文件查询和存储的速率较差的因素往往如下:区块链中存储节点性能差异较大,存储和网络性能的存储节点难以满足高效的查询和存储效率要求。如果解决了上述因素,就能达到提升电子文件查询和存储的速率的效果。为了达到这一效果,本公开引入了根据评价指标对存储节点排序的方法。首先,根据区块链中的存储节点集合计算得到上限节点集合和下限节点集合。其中,上限节点集合为存储、网络等性能较优的存储节点。下限节点集合为存储、网络等性能较差的存储节点。其次,基于上限节点集合和下限节点集合,生成距离指标集合。其中,存储节点集合中的每个存储节点对应一个距离指标。然后,对距离指标集合进行排序后得到距离指标序列。根据距离指标序列得到存储节点序列。通过上述处理步骤,能够找到当前区块链中网络、存储和可靠性能最优的设备。将电子文件存储在性能最优的设备中,能够提高电子文件的存储、查询效率,从而解决了技术问题一。
步骤204,将电子文件分片集合中的第一数目个电子文件分片,分别存储到存储节点序列中的前第一数目个存储节点中。
在一些实施例中,上述执行主体将电子文件分片集合中的第一数目个电子文件分片,分别存储到存储节点序列中的前第一数目个存储节点中。
步骤205,根据电子文件分片集合和存储节点序列的对应关系,生成存储记录表。
在一些实施例中,上述执行主体根据电子文件分片集合和存储节点序列的对应关系,生成存储记录表。可选的,对于电子文件分片集合中的每个电子文件分片,将该电子文件分片与存储该电子文件分片对应的存储节点的组合,确定为该电子文件分片的存储关系,以得到存储关系集合。
步骤206,基于存储记录表,更新区块链。
在一些实施例中,上述执行主体基于存储记录表,更新区块链。
可选的,调用智能合约。其中,智能合约包括智能合约代码、实例和执行数据。具体的,智能合约是一套以数字形式定义的承诺。智能合约可以控制区块链中的数据,约定区块链中各个参与终端的权利和义务。智能合约可以由计算机系统自动执行。具体的,智能合约包括智能合约代码、实例和执行数据。智能合约代码可以是智能合约的源代码。智能合约代码可以是一份计算机系统能够执行的代码。实例可以是区块链中运行智能合约的一个实际业务。执行数据可以是执行一个实例后在区块链中留存的数据。
响应于确定具有写入区块链的权限,运行智能合约代码,将存储记录表存储在区块链中。具体的,记录该区块的智能合约在运行过程中产生实例和执行数据。将该实例和执行数据记录在区块链中。
图2给出的一个实施例具有如下有益效果:首先,将获取的电子文件进行直接切分以得到过程电子文件数据块集合,利用编码矩阵去乘过程电子文件数据块集合,得到电子文件分片集合。电子文件分片集合具有冗余度,在存在文件破坏的情况下能够根据电子文件分片集合恢复出原始的电子文件。其次,对区块链中的存储节点进行性能排序。根据存储节点集合中性能较有的上限节点集合和性能较差的下限节点集合,计算得到存储节点的距离指标,以得到距离指标集合。根据距离指标集合得到存储节点序列。然后,将电子文件分片集合存储在存储节点序列的前第一数目个存储节点中,以得到存储记录表。最后,将存储记录表记录到区块链中。利用区块链的去中心化、可追溯特点,实现基于区块链的电子文件存储。这种方法借助区块链技术实现电子文件的可靠存储。对待存储的电子文件进行分片处理,得到具有冗余度的电子文件分片集合,以保证在出现文件破坏或丢失情况下能够有足够的信息恢复电子文件。对存储节点集合进行排序,选择最佳节点存储电子文件,从而能够将电子文件存储在性能最优的存储节点中,提高电子文件的存储和查询效率。
继续参考图3,示出了根据本公开的基于区块链的电子存证节点选择方法的一个应用场景的示意图。
在图3的应用场景中,用户向服务器发送待存储的电子文件301。服务器接收到电子文件后,对电子文件进行分片处理,生成电子文件分片集合302。服务器生成存储节点序列303。将电子文件分片集合发送至存储节点序列,生成存储记录表304。基于存储记录表,更新区块链305。
本申请实施例提供的基于区块链的电子存证节点选择方法,首先对电子文件进行分片处理,生成具有冗余度的电子文件分片集合,满足数据恢复的需要。将区块链中的存储节点进行排序,得到存储节点序列。将电子文件分片集合存储在存储节点序列中前第一数目个存储节点中,以得到存储记录表。将电子文件存储在性能最优的存储节点中,提高电子文件的存储和查询效率。
下面参考图4,其示出了适于用来实现本公开实施例的服务器的计算机系统400的结构示意图。图4示出的服务器仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图4所示,计算机系统400包括中央处理单元(CPU,Central Processing Unit)401,其可以根据存储在只读存储器(ROM,Read Only Memory)402中的程序或者从存储部分408加载到随机访问存储器(RAM,Random Access Memory)403中的程序而执行各种适当的动作和处理。在RAM 403中,还存储有系统400操作所需的各种程序和数据。CPU 401、ROM402以及RAM 403通过总线404彼此相连。输入/输出(I/O,Input/Output)接口405也连接至总线404。
以下部件连接至I/O接口405:包括硬盘等的存储部分406;以及包括诸如LAN(局域网,Local Area Network)卡、调制解调器等的网络接口卡的通信部分407。通信部分407经由诸如因特网的网络执行通信处理。驱动器408也根据需要连接至I/O接口405。可拆卸介质409,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器408上,以便于从其上读出的计算机程序根据需要被安装入存储部分406。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分407从网络上被下载和安装,和/或从可拆卸介质409被安装。在该计算机程序被中央处理单元(CPU)401执行时,执行本公开的方法中限定的上述功能。需要说明的是,本公开所述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如C语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (10)

1.一种基于区块链的电子存证节点选择方法,包括:
获取待存储的电子文件;
对所述电子文件进行分片处理,以得到电子文件分片集合,其中,所述电子文件分片集合包括第一数目个电子文件分片;
基于存储节点集合,生成存储节点序列;
将所述电子文件分片集合中的第一数目个电子文件分片,分别存储到所述存储节点序列中的前第一数目个存储节点中;
根据所述电子文件分片集合和所述存储节点序列的对应关系,生成存储记录表;
基于所述存储记录表,更新所述区块链。
2.根据权利要求1所述的方法,其中,所述对所述电子文件进行分片处理,以得到电子文件分片集合,包括:
将所述电子文件切分为第二数目个数据块,生成过程电子文件数据块集合;
生成编码矩阵G=[In×n;Bm×n],其中,n为第二数目,I为单位对角矩阵,I包括n行和n列,B为各列为几何级数的矩阵,B包括m行和n列,m=n+δ,δ为冗余位数值,δ可以是任何整数;
利用所述编码矩阵G去乘所述过程电子文件数据块集合,得到所述电子文件分片集合。
3.根据权利要求2所述的方法,其中,所述存储节点集合包括第三数目个存储节点,所述存储节点用于存储所述电子文件分片。
4.根据权利要求3所述的方法,其中,所述基于存储节点集合,生成存储节点序列,包括:
基于所述存储节点集合,确定上限节点集合和下限节点集合;
基于所述上限节点集合和所述下限节点集合,生成距离指标集合,其中,所述距离指标对应存储节点;
对所述距离指标集合中的每个距离指标,按照数值从小到大重新排序,生成距离指标序列;
基于所述距离指标序列对所述存储节点集合进行排序,以得到所述存储节点序列。
5.根据权利要求4所述的方法,其中,所述基于所述存储节点集合,确定上限节点集合和下限节点集合,包括:
利用下式,基于所述存储节点集合确定上限节点,以得到所述上限节点集合:
Figure FDA0002841442040000021
其中,max{}表示取最大值操作,s表示存储节点,k为序号,k的取值为1或2,所述上限节点集合包括2个上限节点,Δ为上限节点标记符号,
Figure FDA0002841442040000022
表示第k个上限节点,sk表示第k个性能指标,响应于k=1,sk表征网络性能指标,响应于k=2,sk表征存储性能指标,n为存储节点集合中的存储节点数目,
Figure FDA0002841442040000023
表示第一个存储节点的第k个性能指标,
Figure FDA0002841442040000024
表示第二个存储节点的第k个性能指标,
Figure FDA0002841442040000025
表示第n个存储节点的第k个性能指标;
利用下式,基于所述存储节点集合确定下限节点,以得到所述下限节点集合:
Figure FDA0002841442040000026
其中,min{}表示取最小值操作,s表示存储节点,k为序号,k的取值为1或2,所述下限节点集合包括2个下限节点,
Figure FDA0002841442040000027
为下限节点标记符号,
Figure FDA0002841442040000028
表示第k个下限节点,sk表示第k个性能指标,响应于k=1,sk表征网络性能指标,响应于k=2,sk表征存储性能指标,n为存储节点集合中的存储节点数目,
Figure FDA0002841442040000029
表示第一个存储节点的第k个性能指标,
Figure FDA00028414420400000210
表示第二个存储节点的第k个性能指标,
Figure FDA00028414420400000211
表示第n个存储节点的第k个性能指标。
6.根据权利要求5所述的方法,其中,所述基于所述上限节点集合和所述下限节点集合,生成距离指标集合,包括:
对于所述存储节点集合中的每个存储节点,利用下式,基于所述上限节点集合,计算该存储节点的最优距离,以得到最优距离集合:
Figure FDA0002841442040000031
其中,s表示存储节点,k为序号,k的取值为1或2,所述上限节点集合包括2个上限节点,Δ为上限节点标记符号,
Figure FDA0002841442040000032
表示第k个上限节点,sk表示第k个性能指标,响应于k=1,sk表征网络性能指标,响应于k=2,sk表征存储性能指标,i表示存储节点计数序号,
Figure FDA0002841442040000033
表示第i个存储节点的第k个性能指标,
Figure FDA0002841442040000034
表示第i个存储节点的最优距离;
对于所述存储节点集合中的每个存储节点,利用下式,基于所述下限节点集合,计算该存储节点的最差距离,以得到最差距离集合:
Figure FDA0002841442040000035
其中,s表示存储节点,k为序号,k的取值为1或2,所述下限节点集合包括2个下限节点,
Figure FDA0002841442040000036
为下限节点标记符号,
Figure FDA0002841442040000037
表示第k个下限节点,sk表示第k个性能指标,响应于k=1,sk表征网络性能指标,响应于k=2,sk表征存储性能指标,i表示存储节点计数序号,
Figure FDA0002841442040000038
表示第i个存储节点的第k个性能指标,
Figure FDA0002841442040000039
表示第i个存储节点的最差距离;
对于所述存储节点集合中的每个存储节点,基于所述最优距离集合和所述最差距离集合,利用下式计算该存储节点的距离指标,以得到距离指标集合:
Figure FDA00028414420400000310
其中,i表示存储节点计数序号,
Figure FDA00028414420400000311
表示第i个存储节点的最差距离,
Figure FDA00028414420400000312
表示第i个存储节点的最优距离,mi表示第i个存储节点的距离指标。
7.根据权利要求6所述的方法,其中,所述根据所述电子文件分片集合和所述存储节点序列的对应关系,生成存储记录表,包括:
对于所述电子文件分片集合中的每个电子文件分片,将该电子文件分片与存储该电子文件分片对应的存储节点的组合,确定为该电子文件分片的存储关系,以得到所述存储关系集合。
8.根据权利要求7所述的方法,其中,所述基于所述存储记录表,更新所述区块链,包括:
调用智能合约,其中,所述智能合约包括智能合约代码、实例和执行数据;
响应于确定具有写入区块链的权限,运行所述智能合约代码,将所述存储记录表存储在区块链中。
9.一种第一终端设备,包括:
一个或多个处理器;
存储装置,其上存储有一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-8中任一所述的方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其中,所述程序被处理器执行时实现如权利要求1-8中任一所述的方法。
CN202011493720.8A 2020-12-16 2020-12-16 基于区块链的电子存证节点选择方法和电子设备 Withdrawn CN112565448A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011493720.8A CN112565448A (zh) 2020-12-16 2020-12-16 基于区块链的电子存证节点选择方法和电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011493720.8A CN112565448A (zh) 2020-12-16 2020-12-16 基于区块链的电子存证节点选择方法和电子设备

Publications (1)

Publication Number Publication Date
CN112565448A true CN112565448A (zh) 2021-03-26

Family

ID=75064355

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011493720.8A Withdrawn CN112565448A (zh) 2020-12-16 2020-12-16 基于区块链的电子存证节点选择方法和电子设备

Country Status (1)

Country Link
CN (1) CN112565448A (zh)

Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103024081A (zh) * 2013-01-04 2013-04-03 福建星网视易信息系统有限公司 适用于有时效保证通讯系统的点对点通讯的终端调度方法
CN107360248A (zh) * 2017-07-31 2017-11-17 众安信息技术服务有限公司 用于配置局部共识的方法和装置及计算机可读存储介质
CN107819829A (zh) * 2017-10-17 2018-03-20 上海点融信息科技有限责任公司 访问区块链的方法、系统、区块链节点设备及用户终端
US20180323974A1 (en) * 2017-05-03 2018-11-08 International Business Machines Corporation Optimal data storage configuration in a blockchain
CN109040305A (zh) * 2018-09-10 2018-12-18 浙江天脉领域科技有限公司 基于分层异构动态拓扑分片的区块链记录方法
CN109376122A (zh) * 2018-09-25 2019-02-22 深圳市元征科技股份有限公司 一种文件管理方法、系统及区块链节点设备和存储介质
CN111611622A (zh) * 2020-05-29 2020-09-01 宁波富万信息科技有限公司 基于区块链的文件存储方法和电子设备
CN111611621A (zh) * 2020-05-29 2020-09-01 宁波富万信息科技有限公司 基于区块链的分布式数据加密存储方法和电子设备
CN111610938A (zh) * 2020-05-29 2020-09-01 宁波富万信息科技有限公司 分布式数据编码存储方法、电子设备和计算机可读存储介质
CN111950030A (zh) * 2020-09-01 2020-11-17 宁波富万信息科技有限公司 基于区块链的数据共享存储方法、终端设备和存储介质
CN111950032A (zh) * 2020-09-01 2020-11-17 宁波富万信息科技有限公司 基于区块链的数据存储方法、终端设备和存储介质

Patent Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103024081A (zh) * 2013-01-04 2013-04-03 福建星网视易信息系统有限公司 适用于有时效保证通讯系统的点对点通讯的终端调度方法
US20180323974A1 (en) * 2017-05-03 2018-11-08 International Business Machines Corporation Optimal data storage configuration in a blockchain
CN107360248A (zh) * 2017-07-31 2017-11-17 众安信息技术服务有限公司 用于配置局部共识的方法和装置及计算机可读存储介质
CN107819829A (zh) * 2017-10-17 2018-03-20 上海点融信息科技有限责任公司 访问区块链的方法、系统、区块链节点设备及用户终端
CN109040305A (zh) * 2018-09-10 2018-12-18 浙江天脉领域科技有限公司 基于分层异构动态拓扑分片的区块链记录方法
CN109376122A (zh) * 2018-09-25 2019-02-22 深圳市元征科技股份有限公司 一种文件管理方法、系统及区块链节点设备和存储介质
CN111611622A (zh) * 2020-05-29 2020-09-01 宁波富万信息科技有限公司 基于区块链的文件存储方法和电子设备
CN111611621A (zh) * 2020-05-29 2020-09-01 宁波富万信息科技有限公司 基于区块链的分布式数据加密存储方法和电子设备
CN111610938A (zh) * 2020-05-29 2020-09-01 宁波富万信息科技有限公司 分布式数据编码存储方法、电子设备和计算机可读存储介质
CN111950030A (zh) * 2020-09-01 2020-11-17 宁波富万信息科技有限公司 基于区块链的数据共享存储方法、终端设备和存储介质
CN111950032A (zh) * 2020-09-01 2020-11-17 宁波富万信息科技有限公司 基于区块链的数据存储方法、终端设备和存储介质

Similar Documents

Publication Publication Date Title
CN111414334A (zh) 基于云技术的文件分片上传方法、装置、设备及存储介质
CN109508326B (zh) 用于处理数据的方法、装置和系统
CN111858146B (zh) 用于恢复数据的方法、设备和计算机程序产品
CN111611622A (zh) 基于区块链的文件存储方法和电子设备
CN111950032A (zh) 基于区块链的数据存储方法、终端设备和存储介质
CN111461751A (zh) 基于区块链的房产信息链上组织方法、历史状态追溯方法及装置
CN112181307A (zh) 基于区块链的分布式数据冗余存储方法和电子设备
CN111629063A (zh) 基于区块链的分布式文件下载的方法和电子设备
CN112541775A (zh) 基于区块链的交易溯源方法、电子设备和计算机存储介质
CN112631924A (zh) 自动化测试方法、装置、计算机设备及存储介质
CN112182109A (zh) 基于区块链的分布式数据编码存储方法和电子设备
CN115858488A (zh) 基于数据治理的平行迁移方法、装置及可读介质
CN112182108A (zh) 基于区块链的分布式数据存储更新方法和电子设备
CN112436943B (zh) 基于大数据的请求去重方法、装置、设备及存储介质
CN112182112A (zh) 基于区块链的分布式数据动态存储方法和电子设备
CN111610938B (zh) 分布式数据编码存储方法、电子设备和计算机可读存储介质
CN111951112A (zh) 基于区块链的智能合约执行方法、终端设备和存储介质
CN112182111A (zh) 基于区块链的分布式系统分层处理方法和电子设备
CN113157911A (zh) 一种服务验证方法和装置
CN112565448A (zh) 基于区块链的电子存证节点选择方法和电子设备
CN111949738A (zh) 基于区块链的数据存储去重方法、终端设备和存储介质
CN112732789A (zh) 基于区块链的可搜索加密方法和电子设备
CN112181974B (zh) 标识信息分配方法、系统及存储设备
CN116107991A (zh) 容器标签数据库构建方法、装置、存储介质及电子设备
CN114298543A (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
WW01 Invention patent application withdrawn after publication

Application publication date: 20210326

WW01 Invention patent application withdrawn after publication