CN111432026B - 平行链交易执行方法、设备和存储介质 - Google Patents

平行链交易执行方法、设备和存储介质 Download PDF

Info

Publication number
CN111432026B
CN111432026B CN202010288477.XA CN202010288477A CN111432026B CN 111432026 B CN111432026 B CN 111432026B CN 202010288477 A CN202010288477 A CN 202010288477A CN 111432026 B CN111432026 B CN 111432026B
Authority
CN
China
Prior art keywords
transaction
parallel chain
node
execution result
interface
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
CN202010288477.XA
Other languages
English (en)
Other versions
CN111432026A (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.)
Nanjing Benchain Information Technology Co ltd
Hangzhou Fuzamei Technology Co Ltd
Original Assignee
Nanjing Benchain Information Technology Co ltd
Hangzhou Fuzamei 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 Nanjing Benchain Information Technology Co ltd, Hangzhou Fuzamei Technology Co Ltd filed Critical Nanjing Benchain Information Technology Co ltd
Priority to CN202010288477.XA priority Critical patent/CN111432026B/zh
Publication of CN111432026A publication Critical patent/CN111432026A/zh
Application granted granted Critical
Publication of CN111432026B publication Critical patent/CN111432026B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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]
    • 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/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • G06F16/275Synchronous replication
    • 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/1095Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computing Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Multi Processors (AREA)
  • Devices For Executing Special Programs (AREA)

Abstract

本发明提供一种平行链交易执行方法、设备和存储介质,该方法包括:接收第一用户的第一客户端生成的第一平行链交易;将第一平行链交易发送至主链节点;根据交易排序规则预执行第一平行链交易以生成第一预执行结果;将第一平行链交易分别发送给各非接口共识节点,以供根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回;对第一预执行结果和各第二预执行结果进行共识,将共识成功的预执行结果返回给第一客户端。本申请加快了用户获得平行链交易的执行结果的时间,提高用户体验。

Description

平行链交易执行方法、设备和存储介质
技术领域
本申请涉及区块链技术领域,具体涉及一种平行链交易执行方法、设备和存储介质。
背景技术
当前的主链-平行链机制采用共识和执行分开的逻辑,判断一笔交易有没有执行成功,需要经过以下几步:
1、客户端向平行链节点发送平行链交易;
2、平行链节点将该平行链交易转发至主链,主链存证该平行链交易;
3、平行链节点从主链同步该平行链交易并执行,生成执行结果,将执行结果发送给主链;
4、主链存证各平行链节点分别生成的执行结果,并根据各平行链节点分别生成的执行结果进行平行链共识;
5、平行链节点从主链同步各平行链节点分别生成的执行结果,并根据各平行链节点分别生成的执行结果进行平行链自共识。
在一些主链-平行链机制中,平行链节点在执行完步骤3后将执行结果返回给用户的客户端;在另一些主链-平行链机制中,平行链节点在执行完成步骤5后,将执行结果返回给用户的客户端;使用上述两种机制时,用户都需要等待一段时间才能获取该平行链交易的执行结果,用户体验较差。
发明内容
鉴于现有技术中的上述缺陷或不足,期望提供一种提高用户体验的平行链交易执行方法、设备和存储介质。
第一方面,本发明提供一种适用于接口共识节点的平行链交易执行方法,平行链网络包括多个平行链共识节点,多个平行链共识节点包括一个接口共识节点和多个非接口共识节点,接口共识节点与各非接口共识节点可互相通信,接口共识节点的交易池、非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
接收第一用户的第一客户端生成的第一平行链交易;
将第一平行链交易发送至主链节点,以供主链节点:
判断第一平行链交易是否由当前节点发送:
是,则根据交易排序规则执行第一平行链交易:将第一平行链交易记录到主链上;
根据交易排序规则预执行第一平行链交易以生成第一预执行结果;
将第一平行链交易分别发送给各非接口共识节点,以供根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回;
对第一预执行结果和各第二预执行结果进行共识,将共识成功的预执行结果返回给第一客户端。
第二方面,本发明提供一种适用于非接口共识节点的平行链交易执行方法,平行链网络包括多个平行链共识节点,多个平行链共识节点包括一个接口共识节点和多个非接口共识节点,接口共识节点与各非接口共识节点可互相通信,接口共识节点的交易池、非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
接收接口共识节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回,以供接口共识节点:
对根据交易排序规则预执行第一平行链交易生成的第一预执行结果、第二预执行结果和各第三预执行结果进行共识,将共识成功的预执行结果返回给生成第一平行链交易的第一用户的第一客户端;
其中,第三预执行结果由其它各非接口共识节点接收接口共识节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易所生成;第一平行链交易由接口共识节点发送至主链节点,主链节点还用于在根据交易排序规则执行第一平行链交易时验证第一平行链交易是否由接口共识节点发送:是,则将第一平行链交易记录到主链上。
第三方面,本发明提供一种适用于接口节点的平行链交易执行方法,平行链网络中还包括一个接口节点,接口节点与各平行链共识节点可相互通信,接口节点的交易池、平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
接收第一用户的第一客户端生成的第一平行链交易;
将第一平行链交易发送至主链节点,以供主链节点:
判断第一平行链交易是否由当前节点发送:
是,则根据交易排序规则执行第一平行链交易:将第一平行链交易记录到主链上;
将第一平行链交易分别发送给各平行链共识节点,以供根据交易排序规则预执行第一平行链交易以生成预执行结果并返回;
对各预执行结果进行共识,将共识成功的预执行结果返回给第一客户端。
第四方面,本发明提供一种适用于平行链共识节点的平行链交易执行方法,平行链网络中还包括一个接口节点,接口节点与各平行链共识节点可相互通信,接口节点的交易池、平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
接收接口节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回,以供接口节点:
对第二预执行结果和各第一预执行结果进行共识,将共识成功的预执行结果返回给生成第一平行链交易的第一用户的第一客户端;
其中,第一预执行结果由其它各平行链共识节点接收接口节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易所生成;第一平行链交易由接口节点发送至主链节点,主链节点还用于在根据交易排序规则执行第一平行链交易时验证第一平行链交易是否由接口节点发送:是,则将第一平行链交易记录到主链上。
第五方面,本发明还提供一种设备,包括一个或多个处理器和存储器,其中存储器包含可由该一个或多个处理器执行的指令以使得该一个或多个处理器执行根据本发明各实施例提供的平行链交易执行方法。
第六方面,本发明还提供一种存储有计算机程序的存储介质,该计算机程序使计算机执行根据本发明各实施例提供的平行链交易执行方法。
本发明诸多实施例提供的平行链交易执行方法、设备和存储介质通过接收第一用户的第一客户端生成的第一平行链交易;将第一平行链交易发送至主链节点;根据交易排序规则预执行第一平行链交易以生成第一预执行结果;将第一平行链交易分别发送给各非接口共识节点,以供根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回;对第一预执行结果和各第二预执行结果进行共识,将共识成功的预执行结果返回给第一客户端的方法,加快了用户获得平行链交易的执行结果的时间,提高用户体验。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1为本发明一实施例提供的一种平行链交易执行方法的流程图。
图2为本发明一实施例提供的另一种平行链交易执行方法的流程图。
图3为本发明一实施例提供的另一种平行链交易执行方法的流程图。
图4为本发明一实施例提供的另一种平行链交易执行方法的流程图。
图5为本发明一实施例提供的一种设备的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1为本发明一实施例提供的一种平行链交易执行方法的流程图。如图1所示,在本实施例中,本发明提供一种适用于接口共识节点的平行链交易执行方法,平行链网络包括多个平行链共识节点,多个平行链共识节点包括一个接口共识节点和多个非接口共识节点,接口共识节点与各非接口共识节点可互相通信,接口共识节点的交易池、非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
S11:接收第一用户的第一客户端生成的第一平行链交易;
S13:将第一平行链交易发送至主链节点,以供主链节点:
判断第一平行链交易是否由当前节点发送:
是,则根据交易排序规则执行第一平行链交易:将第一平行链交易记录到主链上;
S15:根据交易排序规则预执行第一平行链交易以生成第一预执行结果;
S17:将第一平行链交易分别发送给各非接口共识节点,以供根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回;
S19:对第一预执行结果和各第二预执行结果进行共识,将共识成功的预执行结果返回给第一客户端。
具体地,假设平行链网络中有4个平行链共识节点a、b、c、d,其中a为接口共识节点,b、c、d为非接口共识节点;a、b、c、d的交易池中分别有paratx1、paratx2、paratx3;以交易排序规则为以交易池收到交易的时间先后顺序进行排序,第一用户的第一客户端生成paratx4为例;
第一用户的第一客户端生成paratx4;
a执行步骤S11,接收paratx4;
a执行步骤S13,将paratx4发送至主链节点;
主链节点判断paratx4由接口共识节点a发送,则根据交易池收到交易的时间先后顺序执行paratx4:将paratx4记录到主链上;
a执行步骤S15,由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此a的交易池中的交易排序为paratx1、paratx2、paratx3、paratx4,a以此排序预执行paratx4以生成预执行结果pre_ex ecution_a;
a执行步骤S17,将paratx4分别发送给b、c、d;
由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此b的交易池中的交易排序为paratx1、paratx2、paratx3、paratx4,b以此排序预执行paratx4以生成预执行结果pre_execution_b;b向a返回pre_execution_b;
由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此c的交易池中的交易排序为paratx1、paratx2、paratx3、paratx4,c以此排序预执行paratx4以生成预执行结果pre_execution_c;c向a返回pre_execution_c;
由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此d的交易池中的交易排序为paratx1、paratx2、paratx3、paratx4,d以此排序预执行paratx4以生成预执行结果pre_execution_d;d向a返回pre_execution_d;
a执行步骤S19,对pre_execution_a、pre_execution_b、pre_execu tion_c、pre_execution_d进行共识,将共识成功的预执行结果pre_exe cution返回给第一客户端。
以下部分为公知常识:
a、b、c、d从主链同步到paratx4,执行paratx4,生成相应的执行结果execution_a、execution_b、execution_c、execution_d并发送至主链节点,并删除本地交易池中的paratx4。
主链节点根据execution_a、execution_b、execution_c、execution_d进行paratx4的平行链共识,并将execution_a、execution_b、execution_c、execution_d记录到主链上;
a、b、c、d从主链同步到execution_a、execution_b、execution_c、execution_d,根据execution_a、execution_b、execution_c、execution_d进行paratx4的平行链自共识,并将execution_a、execution_b、execution_c、execution_d记录到所在平行链上。
需要说明的是,由于接口共识节点的交易池、非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,因此最终主链区块中的交易顺序也为paratx1、paratx2、paratx3、paratx4;a、b、c、d从主链同步平行链交易时,所同步到的交易顺序也为paratx1、paratx2、paratx3、paratx4,保证了执行平行链交易的顺序与预执行平行链交易的顺序的一致性。
在更多实施例中,交易排序规则还可以根据实际需求进行配置,例如配置为以交易的手续费从高到低的顺序进行排序,可实现相同的技术效果。
在更多实施例中,平行链网络中的平行链共识节点的个数还可以根据实际需求进行配置,例如配置为7个,只要接口共识节点为1个,可实现相同的技术效果。
在更多实施例中,在主链节点判断第一平行链交易不是由接口共识节点发送时,可以配置为丢弃第一平行链交易,或配置为丢弃第一平行链交易,并更新发送该第一平行链交易的节点的不正确发送交易的行为总数,可实现相同的技术效果。
上述实施例加快了用户获得平行链交易的执行结果的时间,提高用户体验。
优选地,上述方法还包括:
在第一平行链交易的平行链自共识成功,且通过平行链自共识的第一平行链交易的执行结果与共识成功的预执行结果不一致时,生成第一回滚信息并发送至第一客户端,以供回滚第一预执行结果。
具体地,a从主链同步到execution_a、execution_b、execution_c、execution_d,根据execution_a、execution_b、execution_c、execution_d进行paratx4的平行链自共识,假设自共识的执行结果为execution;
在execution与pre_execution不一致时,a生成第一回滚信息并发送至第一客户端;
第一客户端根据第一回滚信息回滚pre_execution;
a将execution发送至第一客户端。
图2为本发明一实施例提供的一种平行链交易执行方法的流程图。如图2所示,在本实施例中,本发明提供一种适用于非接口共识节点,的平行链交易执行方法,平行链网络包括多个平行链共识节点,多个平行链共识节点包括一个接口共识节点和多个非接口共识节点,接口共识节点与各非接口共识节点可互相通信,接口共识节点的交易池、非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
S21:接收接口共识节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回,以供接口共识节点:
对根据交易排序规则预执行第一平行链交易生成的第一预执行结果、第二预执行结果和各第三预执行结果进行共识,将共识成功的预执行结果返回给生成第一平行链交易的第一用户的第一客户端;
其中,第三预执行结果由其它各非接口共识节点接收接口共识节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易所生成;第一平行链交易由接口共识节点发送至主链节点,主链节点还用于在根据交易排序规则执行第一平行链交易时验证第一平行链交易是否由接口共识节点发送:是,则将第一平行链交易记录到主链上。
上述实施例的平行链交易执行原理可参考图1所示的方法,此处不再赘述。
优选地,接口共识节点还用于在第一平行链交易的平行链自共识成功,且通过平行链自共识的第一平行链交易的执行结果与共识成功的预执行结果不一致时,生成第一回滚信息并发送至第一客户端,以供回滚第一预执行结果。
上述实施例的平行链交易执行原理可参考图1所示的一种优选实施方式的方法,此处不再赘述。
图3为本发明一实施例提供的一种平行链交易执行方法的流程图。如图3所示,在本实施例中,本发明提供一种适用于接口节点的平行链交易执行方法,平行链网络中还包括一个接口节点,接口节点与各平行链共识节点可相互通信,接口节点的交易池、平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
S31:接收第一用户的第一客户端生成的第一平行链交易;
S33:将第一平行链交易发送至主链节点,以供主链节点:
判断第一平行链交易是否由当前节点发送:
是,则根据交易排序规则执行第一平行链交易:将第一平行链交易记录到主链上;
S35:将第一平行链交易分别发送给各平行链共识节点,以供根据交易排序规则预执行第一平行链交易以生成预执行结果并返回;
S37:对各预执行结果进行共识,将共识成功的预执行结果返回给第一客户端。
具体地,假设平行链网络中有3个平行链共识节点e、f、g;h为接口节点;e、f、g、h的交易池中分别有paratx5、paratx6、paratx7;以交易排序规则为以交易池收到交易的时间先后顺序进行排序,第一用户的第一客户端生成paratx8为例;
第一用户的第一客户端生成paratx8;
h执行步骤S31,接收paratx8;
h执行步骤S33,将paratx8发送至主链节点;
主链节点判断第一平行链交易由接口节点h发送,则根据交易池收到交易的时间先后顺序进行排序执行paratx8:将paratx8记录到主链上;
h执行步骤S35,将paratx8分别发送给e、f、g;
由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此e的交易池中的交易排序为paratx5、paratx6、paratx7、paratx8,e以此排序预执行paratx8以生成预执行结果pre_execution_e;e向h返回pre_execution_e;
由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此f的交易池中的交易排序为paratx5、paratx6、paratx7、paratx8,f以此排序预执行paratx8以生成预执行结果pre_execution_f;f向h返回pre_execution_f;
由于交易排序规则为以交易池收到交易的时间先后顺序进行排序,因此g的交易池中的交易排序为paratx5、paratx6、paratx7、paratx8,g以此排序预执行paratx8以生成预执行结果pre_execution_g;g向h返回pre_execution_g;
h执行步骤S37,对pre_execution_e、pre_execution_f、pre_execu tion_g进行共识,将共识成功的预执行结果pre_execution'返回给第一客户端。
以下部分为公知常识:
e、f、g从主链同步到paratx8,执行paratx8,生成相应的执行结果execution_e、execution_f、execution_g并发送至主链节点,并删除本地交易池中的paratx8。
主链节点根据execution_e、execution_f、execution_g进行paratx8的平行链共识,并将execution_e、execution_f、execution_g记录到主链上;
e、f、g从主链同步到execution_e、execution_f、execution_g,根据execution_e、execution_f、execution_g进行paratx8的平行链自共识,并将execution_e、execution_f、execution_g记录到所在平行链上。
需要说明的是,由于接口节点的交易池、平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,因此最终主链区块中的交易顺序也为paratx5、paratx6、paratx7、paratx8;e、f、g从主链同步平行链交易时,所同步到的交易顺序也为paratx5、paratx6、paratx7、paratx8,保证了执行平行链交易的顺序与预执行平行链交易的顺序的一致性。
在更多实施例中,交易排序规则还可以根据实际需求进行配置,例如配置为以交易的手续费从高到低的顺序进行排序,可实现相同的技术效果。
在更多实施例中,平行链网络中的平行链共识节点的个数还可以根据实际需求进行配置,例如配置为7个,只要接口节点为1个,可实现相同的技术效果。
在更多实施例中,在主链节点判断第一平行链交易不是由接口节点发送时,可以配置为丢弃第一平行链交易,或配置为丢弃第一平行链交易,并更新发送该第一平行链交易的节点的不正确发送交易的行为总数,可实现相同的技术效果。
上述实施例加快了用户获得平行链交易的执行结果的时间,提高用户体验。
优选地,上述方法还包括:
在第一平行链交易的平行链自共识成功后,向第一平行链共识节点同步通过平行链自共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至第一客户端,以供回滚第一预执行结果。
具体地,在paratx8的平行链自共识成功后,h向e(或f,或g)同步通过平行链自共识的paratx8的执行结果execution';
在execution'与pre_execution'不一致时,h生成第一回滚信息并发送至第一客户端;
第一客户端根据第一回滚信息回滚pre_execution';
h将execution'发送至第一客户端。
优选地,上述方法还包括:
在第一平行链交易的平行链共识成功后,向主链节点同步通过平行链共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至第一客户端,以供回滚第一预执行结果。
具体地,在paratx8的平行链共识成功后,h向e(或f,或g)同步通过平行链共识的paratx8的执行结果execution”;
在execution”与pre_execution'不一致时,h生成第一回滚信息并发送至第一客户端;
第一客户端根据第一回滚信息回滚pre_execution';
h将execution”发送至第一客户端。
图4为本发明一实施例提供的一种平行链交易执行方法的流程图。如图4所示,在本实施例中,本发明提供一种适用于平行链共识节点的平行链交易执行方法,平行链网络中还包括一个接口节点,接口节点与各平行链共识节点可相互通信,接口节点的交易池、平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,上述方法包括:
S41:接收接口节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易以生成第二预执行结果并返回,以供接口节点:
对第二预执行结果和各第一预执行结果进行共识,将共识成功的预执行结果返回给生成第一平行链交易的第一用户的第一客户端;
其中,第一预执行结果由其它各平行链共识节点接收接口节点发送的第一平行链交易,根据交易排序规则预执行第一平行链交易所生成;第一平行链交易由接口节点发送至主链节点,主链节点还用于在根据交易排序规则执行第一平行链交易时验证第一平行链交易是否由接口节点发送:是,则将第一平行链交易记录到主链上。
上述实施例的平行链交易执行原理可参考图3所示的方法,此处不再赘述。
优选地,接口节点还用于在第一平行链交易的平行链自共识成功后,向第一平行链共识节点同步通过平行链自共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至第一客户端,以供回滚第一预执行结果。
上述实施例的平行链交易执行原理可参考图3所示的一种优选实施方式的方法,此处不再赘述。
优选地,接口节点还用于在第一平行链交易的平行链共识成功后,向主链节点同步通过平行链共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至第一客户端,以供回滚第一预执行结果。
上述实施例的平行链交易执行原理可参考图3所示的一种优选实施方式的方法,此处不再赘述。
图5为本发明一实施例提供的一种设备的结构示意图。
如图5所示,作为另一方面,本申请还提供了一种设备500,包括一个或多个中央处理单元(CPU)501,其可以根据存储在只读存储器(ROM)502中的程序或者从存储部分508加载到随机访问存储器(RAM)503中的程序而执行各种适当的动作和处理。在RAM503中,还存储有设备500操作所需的各种程序和数据。CPU501、ROM502以及RAM503通过总线504彼此相连。输入/输出(I/O)接口505也连接至总线504。
以下部件连接至I/O接口505:包括键盘、鼠标等的输入部分506;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分507;包括硬盘等的存储部分508;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分509。通信部分509经由诸如因特网的网络执行通信处理。驱动器510也根据需要连接至I/O接口505。可拆卸介质511,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器510上,以便于从其上读出的计算机程序根据需要被安装入存储部分508。
特别地,根据本公开的实施例,上述任一实施例描述的方法可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括有形地包含在机器可读介质上的计算机程序,所述计算机程序包含用于执行上述任一方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分509从网络上被下载和安装,和/或从可拆卸介质511被安装。
作为又一方面,本申请还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施例的装置中所包含的计算机可读存储介质;也可以是单独存在,未装配入设备中的计算机可读存储介质。计算机可读存储介质存储有一个或者一个以上程序,该程序被一个或者一个以上的处理器用来执行描述于本申请提供的方法。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这根据所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以通过执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以通过专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元或模块可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元或模块也可以设置在处理器中,例如,各所述单元可以是设置在计算机或移动智能设备中的软件程序,也可以是单独配置的硬件装置。其中,这些单元或模块的名称在某种情况下并不构成对该单元或模块本身的限定。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离本申请构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (12)

1.一种平行链交易执行方法,其特征在于,平行链网络包括多个平行链共识节点,所述多个平行链共识节点包括一个接口共识节点和多个非接口共识节点,所述接口共识节点与各所述非接口共识节点可互相通信,所述接口共识节点的交易池、所述非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,所述方法适用于接口共识节点,所述方法包括:
接收第一用户的第一客户端生成的第一平行链交易;
将所述第一平行链交易发送至主链节点,以供所述主链节点:
判断所述第一平行链交易是否由当前节点发送:
是,则根据所述交易排序规则执行所述第一平行链交易:将所述第一平行链交易记录到主链上;
根据所述交易排序规则预执行所述第一平行链交易以生成第一预执行结果;
将所述第一平行链交易分别发送给各所述非接口共识节点,以供根据所述交易排序规则预执行所述第一平行链交易以生成第二预执行结果并返回;
对所述第一预执行结果和各所述第二预执行结果进行共识,将共识成功的预执行结果返回给所述第一客户端。
2.根据权利要求1所述的方法,其特征在于,还包括:
在所述第一平行链交易的平行链自共识成功,且通过平行链自共识的第一平行链交易的执行结果与共识成功的预执行结果不一致时,生成第一回滚信息并发送至所述第一客户端,以供回滚所述第一预执行结果。
3.一种平行链交易执行方法,其特征在于,平行链网络包括多个平行链共识节点,所述多个平行链共识节点包括一个接口共识节点和多个非接口共识节点,所述接口共识节点与各所述非接口共识节点可互相通信,所述接口共识节点的交易池、所述非接口共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,所述方法适用于非接口共识节点,所述方法包括:
接收所述接口共识节点发送的第一平行链交易,根据所述交易排序规则预执行所述第一平行链交易以生成第二预执行结果并返回,以供所述接口共识节点:
对根据所述交易排序规则预执行所述第一平行链交易生成的第一预执行结果、所述第二预执行结果和各第三预执行结果进行共识,将共识成功的预执行结果返回给生成所述第一平行链交易的第一用户的第一客户端;
其中,所述第三预执行结果由其它各所述非接口共识节点接收所述接口共识节点发送的第一平行链交易,根据所述交易排序规则预执行所述第一平行链交易所生成;所述第一平行链交易由所述接口共识节点发送至主链节点,所述主链节点还用于在根据所述交易排序规则执行所述第一平行链交易时验证所述第一平行链交易是否由所述接口共识节点发送:是,则将所述第一平行链交易记录到主链上。
4.根据权利要求3所述的方法,其特征在于,所述接口共识节点还用于在所述第一平行链交易的平行链自共识成功,且通过平行链自共识的第一平行链交易的执行结果与共识成功的预执行结果不一致时,生成第一回滚信息并发送至所述第一客户端,以供回滚所述第一预执行结果。
5.一种平行链交易执行方法,其特征在于,平行链网络中还包括一个接口节点,所述接口节点与各平行链共识节点可相互通信,所述接口节点的交易池、所述平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,所述方法适用于接口节点,所述方法包括:
接收第一用户的第一客户端生成的第一平行链交易;
将所述第一平行链交易发送至主链节点,以供所述主链节点:
判断所述第一平行链交易是否由当前节点发送:
是,则根据所述交易排序规则执行所述第一平行链交易:将所述第一平行链交易记录到主链上;
将所述第一平行链交易分别发送给各所述平行链共识节点,以供根据所述交易排序规则预执行所述第一平行链交易以生成第一预执行结果并返回;
对各所述第一预执行结果进行共识,将共识成功的预执行结果返回给所述第一客户端。
6.根据权利要求5所述的方法,其特征在于,还包括:
在所述第一平行链交易的平行链自共识成功后,向第一平行链共识节点同步通过平行链自共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至所述第一客户端,以供回滚所述第一预执行结果。
7.根据权利要求5所述的方法,其特征在于,还包括:
在所述第一平行链交易的平行链共识成功后,向主链节点同步通过平行链共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至所述第一客户端,以供回滚所述第一预执行结果。
8.一种平行链交易执行方法,其特征在于,平行链网络中还包括一个接口节点,所述接口节点与各平行链共识节点可相互通信,所述接口节点的交易池、所述平行链共识节点的交易池与主链节点的交易池配置有相同的交易排序规则,所述方法适用于平行链共识节点,所述方法包括:
接收所述接口节点发送的第一平行链交易,根据所述交易排序规则预执行所述第一平行链交易以生成第二预执行结果并返回,以供所述接口节点:
对所述第二预执行结果和各第一预执行结果进行共识,将共识成功的预执行结果返回给生成所述第一平行链交易的第一用户的第一客户端;
其中,所述第一预执行结果由其它各所述平行链共识节点接收所述接口节点发送的第一平行链交易,根据所述交易排序规则预执行所述第一平行链交易所生成;所述第一平行链交易由所述接口节点发送至主链节点,所述主链节点还用于在根据所述交易排序规则执行所述第一平行链交易时验证所述第一平行链交易是否由所述接口节点发送:是,则将所述第一平行链交易记录到主链上。
9.根据权利要求8所述的方法,其特征在于,所述接口节点还用于在所述第一平行链交易的平行链自共识成功后,向第一平行链共识节点同步通过平行链自共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至所述第一客户端,以供回滚所述第一预执行结果。
10.根据权利要求8所述的方法,其特征在于,所述接口节点还用于在所述第一平行链交易的平行链共识成功后,向主链节点同步通过平行链共识的第一平行链交易的执行结果,并判断是否与共识成功的预执行结果相同:
否,则生成第一回滚信息并发送至所述第一客户端,以供回滚所述第一预执行结果。
11.一种用于平行链交易执行的设备,其特征在于,所述设备包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器执行如权利要求1-10中任一项所述的方法。
12.一种存储有计算机程序的存储介质,其特征在于,该程序被处理器执行时实现如权利要求1-10中任一项所述的方法。
CN202010288477.XA 2020-04-14 2020-04-14 平行链交易执行方法、设备和存储介质 Active CN111432026B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010288477.XA CN111432026B (zh) 2020-04-14 2020-04-14 平行链交易执行方法、设备和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010288477.XA CN111432026B (zh) 2020-04-14 2020-04-14 平行链交易执行方法、设备和存储介质

Publications (2)

Publication Number Publication Date
CN111432026A CN111432026A (zh) 2020-07-17
CN111432026B true CN111432026B (zh) 2022-10-28

Family

ID=71554583

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010288477.XA Active CN111432026B (zh) 2020-04-14 2020-04-14 平行链交易执行方法、设备和存储介质

Country Status (1)

Country Link
CN (1) CN111432026B (zh)

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109035016A (zh) * 2018-06-28 2018-12-18 杭州复杂美科技有限公司 一种多链并发交易方法
CN109271446A (zh) * 2018-08-30 2019-01-25 杭州复杂美科技有限公司 一种平行链数据同步方法、设备和存储介质
CN109379429A (zh) * 2018-10-25 2019-02-22 龚玉环 一种基于区块链的多链管理方法及系统
CN109697606A (zh) * 2018-09-30 2019-04-30 贝克链区块链技术有限公司 基于创新性的信誉证明共识协议的分布式网络及生态系统
CN109872161A (zh) * 2019-03-01 2019-06-11 山东大学 一种加速iota子链交易验证过程的芯片及系统
CN110473093A (zh) * 2019-07-29 2019-11-19 杭州复杂美科技有限公司 平行链资产转移方法、设备和存储介质
WO2020042930A1 (zh) * 2018-08-28 2020-03-05 白杰 基于平行链的交易方法及区块链系统

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10812274B2 (en) * 2015-05-07 2020-10-20 Blockstream Corporation Transferring ledger assets between blockchains via pegged sidechains
US20190236559A1 (en) * 2018-01-31 2019-08-01 Salesforce.Com, Inc. Systems, methods, and apparatuses for implementing smart flow contracts using distributed ledger technologies in a cloud based computing environment

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109035016A (zh) * 2018-06-28 2018-12-18 杭州复杂美科技有限公司 一种多链并发交易方法
WO2020042930A1 (zh) * 2018-08-28 2020-03-05 白杰 基于平行链的交易方法及区块链系统
CN109271446A (zh) * 2018-08-30 2019-01-25 杭州复杂美科技有限公司 一种平行链数据同步方法、设备和存储介质
CN109697606A (zh) * 2018-09-30 2019-04-30 贝克链区块链技术有限公司 基于创新性的信誉证明共识协议的分布式网络及生态系统
CN109379429A (zh) * 2018-10-25 2019-02-22 龚玉环 一种基于区块链的多链管理方法及系统
CN109872161A (zh) * 2019-03-01 2019-06-11 山东大学 一种加速iota子链交易验证过程的芯片及系统
CN110473093A (zh) * 2019-07-29 2019-11-19 杭州复杂美科技有限公司 平行链资产转移方法、设备和存储介质

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
H∞ Consensus for Multiagent-Based Supply Chain Systems Under Switching Topology and Uncertain Demands;Qing-Kui Li et.al.;《IEEE》;20181127;全文 *
公链3.0进行时: chain33区块链生态中平行链和主链是什么关系?;冬梅志科技;《网易 https://www.163.com/dy/article/DV26PV020511LP1Q.html》;20181026;全文 *
基于侧链的去中心化智能合约审计系统;赵炳铖;《中国优秀硕士学位论文全文数据库 (信息科技辑) 》;20200315;全文 *

Also Published As

Publication number Publication date
CN111432026A (zh) 2020-07-17

Similar Documents

Publication Publication Date Title
CN109087204B (zh) 跨链交易校验方法、设备和存储介质
CN110569311B (zh) 一种数据库的数据同步方法、设备和计算机存储介质
CN109951547B (zh) 事务请求并行处理方法、装置、设备和介质
WO2019153490A1 (zh) 房产交易方法、装置、计算机可读存储介质及终端设备
CN110443690A (zh) 一种差异数据对账的方法、装置、服务器和存储介质
CN111798238A (zh) 平行链共识方法、设备和存储介质
CN111274313A (zh) 分段共识方法、设备和存储介质
CN111432026B (zh) 平行链交易执行方法、设备和存储介质
CN113962401A (zh) 联邦学习系统、联邦学习系统中的特征选择方法及装置
US8935354B2 (en) Coordinating write sequences in a data storage system
WO2022021768A1 (zh) 平行链交易组执行方法、设备和存储介质
CN115330171A (zh) 业务流程控制方法、装置、计算机设备及可读存储介质
CN114781517A (zh) 风险识别的方法、装置及终端设备
CN110535922B (zh) 状态数据存储方法和平行链区块生成方法
US20210240698A1 (en) Asynchronous remote calls with undo data structures
CN113657817A (zh) 交易处理方法、装置、电子设备和可读存储介质
CN114547182A (zh) 人员信息同步方法、终端设备及存储介质
CN114968491B (zh) 虚拟资源测试方法、装置、电子设备及存储介质
CN111199382A (zh) 换房事务处理方法和装置
CN115577031B (zh) 一种数据库事务处理方法、装置、电子设备及存储介质
CN110046192B (zh) 请求信息的序号生成系统和方法
CN116070601B (zh) 数据拼接方法、装置、电子设备及存储介质
CN111242592B (zh) 资源转移检测方法、装置、服务器及计算机可读存储介质
CN113849278A (zh) 全局事务处理方法及系统
CN115687534A (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