CN109032706B - 智能合约执行方法、装置、设备和存储介质 - Google Patents
智能合约执行方法、装置、设备和存储介质 Download PDFInfo
- Publication number
- CN109032706B CN109032706B CN201810778243.6A CN201810778243A CN109032706B CN 109032706 B CN109032706 B CN 109032706B CN 201810778243 A CN201810778243 A CN 201810778243A CN 109032706 B CN109032706 B CN 109032706B
- Authority
- CN
- China
- Prior art keywords
- target
- intelligent contract
- function
- rollback
- calling
- 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
- 238000000034 method Methods 0.000 title claims abstract description 58
- 230000006870 function Effects 0.000 claims abstract description 207
- 230000007246 mechanism Effects 0.000 claims abstract description 34
- 230000003993 interaction Effects 0.000 claims abstract description 31
- 238000005516 engineering process Methods 0.000 claims description 28
- 238000004891 communication Methods 0.000 claims description 13
- 238000004590 computer program Methods 0.000 claims description 9
- 238000012917 library technology Methods 0.000 claims description 9
- 230000008569 process Effects 0.000 claims description 8
- 238000005096 rolling process Methods 0.000 claims description 4
- 230000003287 optical effect Effects 0.000 description 6
- 238000010586 diagram Methods 0.000 description 5
- RTZKZFJDLAIYFH-UHFFFAOYSA-N Diethyl ether Chemical compound CCOCC RTZKZFJDLAIYFH-UHFFFAOYSA-N 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 244000035744 Hura crepitans Species 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005538 encapsulation Methods 0.000 description 1
- 230000001902 propagating effect Effects 0.000 description 1
- 230000008707 rearrangement Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/448—Execution paradigms, e.g. implementations of programming paradigms
- G06F9/4482—Procedural
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本发明实施例公开了一种智能合约执行方法、装置、设备和存储介质。该方法包括:从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;采用预设的智能合约交互方式,调用所述目标运行函数。本发明实施例基于区块链原生语言的插件机制编写智能合约,实现了可以直接在物理机上执行智能合约,避免了在虚拟机上执行智能合约导致的性能低下的问题,提高了区块链编程的亲和性和功能的完备性。
Description
技术领域
本发明实施例涉及区块链技术领域,尤其涉及一种智能合约执行方法、装置、设备和存储介质。
背景技术
随着互联网技术的不断发展,一种去中心化且公开透明的区块链技术应运而生。区块链网络依据不同的智能合约来限制事务的处理方式,智能合约旨在以信息化方式传播、验证或执行合约的计算机协议,维持了区块链网络中事务的处理秩序。
在区块链网络中,智能合约通常以一段可读字段或可执行代码段的形式存在。现有智能合约只有固定的几种开发模式,例如比特币的script模式,以太坊的solidity模式以及EOS的Web Assembly模式。现有技术中智能合约采用非区块链原生语言进行编写,并依赖于CPU、内存或者磁盘等有制约条件的虚拟机进行运行,同时还可以通过沙盒对其运行环境进行限制。
然而,虚拟机是通过软件模拟的具有完整硬件系统功能的且运行在一个完全隔离环境中的完整计算机系统。智能合约在虚拟机中的运行性能较低,限制了智能合约的开发模式,同时也降低了区块链编程的亲和性和功能实现的完备性。
发明内容
本发明实施例提供了一种智能合约执行方法、装置、设备和存储介质,能够提高区块链网络中智能合约的运行性能。
第一方面,本发明实施例提供了一种智能合约执行方法,由区块链网络中的节点执行,所述方法包括:
从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;
采用预设的智能合约交互方式,调用所述目标运行函数。
第二方面,本发明实施例提供了一种智能合约执行装置,配置于区块链网络中的节点中,所述装置包括:
目标运行函数选择模块,用于从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;
目标运行函数调用模块,用于采用预设的智能合约交互方式,调用所述目标运行函数。
第三方面,本发明实施例提供了一种设备,包括:
一个或多个处理器;
存储器,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明任意实施例所述的智能合约执行方法。
第四方面,本发明实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现本发明任意实施例所述的智能合约执行方法。
本发明实施例通过采用区块链原生语言及其对应的插件机制对目标智能合约进行编写,以插件的方式将目标智能合约注册于本地节点的物理机中;并在目标智能合约的执行时,选择目标智能合约中至少一个待运行的目标运行函数,区块链网络采用预设的智能合约交互方式调用选择的目标运行函数。本发明实施例基于区块链原生语言的插件机制编写智能合约,实现了直接在物理机上执行智能合约,避免了在虚拟机上执行智能合约导致的性能低下的问题,提高了区块链编程的亲和性和功能的完备性。
附图说明
图1为本发明实施例一提供的一种智能合约执行方法的流程图;
图2为本发明实施例二提供的一种智能合约执行方法的流程图;
图3为本发明实施例三提供的一种智能合约执行装置的结构示意图;
图4为本发明实施例四提供的一种设备的结构示意图。
具体实施方式
下面结合附图和实施例对本发明实施例作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明实施例,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明实施例相关的部分而非全部结构。
实施例一
图1为本发明实施例一提供的一种智能合约执行方法的流程图。该方法应用于区块链网络中的节点,区块链可以是公有链、联盟链或私有链,区块链网络通常都会包括多个节点。本发明实施例可适用于在物理机上执行智能合约的情况,该方法可由配置于区块链网络中的节点中的一种智能合约执行装置来执行。该方法具体包括如下步骤:
S110、从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中目标智能合约是采用区块链原生语言的插件机制编写的。
在本发明具体实施例中,目标智能合约是指依据需求所编写的可供区块链网络调用并执行的代码段,其中可以包括至少一个运行函数,还可包括不同运行函数之间的调用关系,从而通过区块链网络的调用实现至少一种功能或者规定至少一类事务的处理规则。需要说明的是,目标智能合约可以是本机节点用户自己编写的,也可以是其他用户在区块链网络中其他节点编写目标智能合约代码,将目标智能合约代码编译成可执行文件,并发布到本机节点中的。
具体的,本实施例采用区块链原生语言的插件机制编写目标智能合约。其中,区块链原生语言是指可以编写区块链底层网络架构的语言,例如GO语言、Java语言或者C++语言等。插件机制是指利用区块链原生语言对应的插件机制将智能合约编写为插件的形式,并配置于本地节点对应的物理机中,以与区块链网络互相交互,从而提供智能合约对应的功能或规则限定。进一步的,每个区块链原生语言都具有对应的插件机制,例如GO语言的plugin插件机制、Java语言的.jar插件机制、以及C++语言的.so插件机制等。
值得注意的是,独立的区块链网络的底层网络架构中通常采用统一的一种区块链原生语言进行开发,而在本地节点编写智能合约时,可以采用当前区块链网络所采用的区块链原生语言的插件机制,也可以采用除当前区块链网络所采用的区块链原生语言之外的其他原生语言的插件机制。
其中,目标智能合约还包括初始化函数。,在首次将目标智能合约配置到本地节点时,可以采用目标智能合约包括的初始化函数对目标智能合约进行初始化。其中,初始化函数可以为目标智能合约的初始化规则,也可以为可执行代码段进行初始化,以函数的形式能够被区块链网络调用并完成初始化即可,用于为首次配置于本地节点中的目标智能合约中的各个参数或条件赋予初始值,为目标智能合约的运行提供依据。待运行目标智能合约时,可以依据当前区块链网络所要处理的事务类别,或者可以依据当前区块链网络所要实现的功能,从目标智能合约中包括的至少一个运行函数中选择目标运行函数,供区块链网络调用。
示例性的,假设区块链网络采用GO语言进行开发,可以采用GO语言对应的plugin插件机制编写目标智能合约,将编写好的目标智能合约以插件的形式配置于本地节点的物理机中,并调用目标智能合约中的初始化函数对目标智能合约进行初始化。待运行目标智能合约时,若当前区块链网络要处理事务A,则从目标智能合约中包括的运行函数中选择事务A处理规则对应的函数作为目标运行函数,供区块链网络调用。
S120、采用预设的智能合约交互方式,调用目标运行函数。
在本发明具体实施例中,智能合约交互方式是指区块链网络调用目标运行函数的具体调用方式。本实施例根据当前区块链网络所采用的原生语言、目标智能合约所采用的原生语言、以及区块链网络的运行环境等条件预先设定了三种智能合约交互方式,分别为动态链接库(DynamicLinkLibrary,DLL)技术、进程间通信(Inter-ProcessCommunication,IPC)技术以及远程过程调用(Remote Procedure Call,RPC)技术。
其中,基于动态链接库技术的智能合约交互方式要求当前区块链网络所采用的原生语言与目标智能合约所采用的原生语言相同,至此无需借助于额外的工具即可直接在本地节点的物理机中进行函数的调用;基于进程间通信技术的智能合约交互方式需要借助轻量级虚拟化技术将物理机中的目标智能合约等各进程之间隔离开来,从而利用进程间通信技术实现区块链网络对目标运行函数的调用;基于远程过程调用技术的智能合约交互方式需要借助远程智能合约调度器,通过网络从远程计算机程序上请求运行目标智能合约的服务。
此外,目标智能合约中还可以包括各运行函数对应的回滚函数,运行函数与回滚函数一一对应,用于当区块链依据目标运行函数判别所生成的新的区块无效时,对新的区块所产生的事务记录数据进行回滚。其中,在某些存储结构中不需要回滚数据,则运行函数对应的回滚函数可以为空,例如以太坊的梅克尔帕特里夏树(Merkle Patricia Tree,MPT)。且目标智能合约中可以不包括回滚函数,则此时可以是系统默认生成运行函数的回滚函数。
具体的,若检测到目标运行函数的回滚事件,则获取目标智能合约中包括的该目标运行函数对应的回滚函数,或者,从区块链网络中预置的回滚函数选择该目标运行函数对应的回滚函数,并采用该目标运行函数对应的回滚函数对目标运行函数的执行结果进行回滚。
示例性的,在上述示例中,当前区块链网络采用GO语言进行开发,目标智能合约同样采用GO语言对应的plugin插件机制进行编写,因此在选择了目标智能合约中的目标运行函数后,可以采用DLL技术直接调用目标运行函数,实现本地节点的物理机中目标智能合约的执行。
本实施例的技术方案,通过采用区块链原生语言及其对应的插件机制对目标智能合约进行编写,以插件的方式将目标智能合约注册于本地节点的物理机中;并在目标智能合约的执行时,选择目标智能合约中至少一个待运行的目标运行函数,区块链网络采用预设的智能合约交互方式调用选择的目标运行函数。本发明实施例基于区块链原生语言的插件机制编写智能合约,实现了可以直接在物理机上执行智能合约,避免了在虚拟机上执行智能合约导致的性能低下的问题,提高了区块链编程的亲和性和功能的完备性。
实施例二
本实施例在上述实施例一的基础上,提供了智能合约执行方法的一个优选实施方式,能够基于一定的规则配置和调用目标智能合约。图2为本发明实施例二提供的一种智能合约执行方法的流程图,如图2所示,该方法包括以下具体步骤:
S210、在首次将目标智能合约配置到本地节点时,采用目标智能合约包括的初始化函数对目标智能合约进行初始化。
在本发明具体实施例中,基于区块链原生语言的插件机制编写的目标智能合约中还可以包括初始化函数。在目标智能合约经过编写、编译并下发到区块链网络中的所有节点中进行部署时,若区块链网络中的节点检测到目标智能合约是首次配置到节点中的,则采用目标智能合约包括的初始化函数对目标智能合约进行初始化。初始化函数可以为目标智能合约的初始化规则,也可以为可执行代码段进行初始化,以函数的形式能够被区块链网络调用并完成初始化即可,用于为首次配置于本地节点中的目标智能合约中的各个参数或条件赋予初始值,为目标智能合约的运行提供依据。
可以理解的是,目标智能合约中规定了具体的功能实现方式或者事务的处理方式,相应的目标智能合约的执行受到参数或条件的限制。因此在首次将目标智能合约配置到本地节点时,目标智能合约的初始化函数可以依据初始化函数规定以及当前的区块链网络状态,为目标智能合约中的各个参数或条件赋予初始值。
示例性的,在本机节点接收到或者编写并下发目标智能合约时,目标智能合约作为当前区块链网络中的一个全新的智能合约,首次部署到区块链网络中的各个节点中。相应的,采用目标智能合约中的初始化函数,同时依据当前区块链网络状态,给目标智能合约中的参数或条件赋予初始值,使其在后续的调用过程中能够正常运行。
S220、从目标智能合约包括的至少一个运行函数中选择目标运行函数。
在本发明具体实施例中,待运行目标智能合约时,可以依据当前区块链网络所要处理的事务类别,或者可以依据当前区块链网络所要实现的功能,以及当前区块链网络的状态,从目标智能合约中包括的至少一个运行函数中选择目标运行函数,供区块链网络调用。
S230、采用预设的智能合约交互方式,调用目标运行函数。
在本发明具体实施例中,智能合约交互方式是指区块链网络调用目标运行函数的具体调用方式。
可选的,若目标智能合约与区块链采用的原生语言相同,则采用动态链接库技术,调用目标运行函数。
在本发明具体实施例中,动态链接库技术用于提供区块链网络可以调用不属于其可执行代码的函数,动态链接库作为共享函数库的可执行文件,要求库内的共享函数的编程语言与区块链网络的开发语言相同方可被调用。鉴于本实施例可以采用插件机制对目标智能合约进行编写并配置于本地节点的物理机中,因此若当前区块链网络所采用的原生语言与目标智能合约所采用的原生语言相同,则可以采用基于动态链接库技术的智能合约交互方调用目标运行函数,至此无需借助于额外的工具即可直接在本地节点的物理机中进行函数的调用,实现直接在物理机上执行智能合约。
可选的,基于进程间通信技术,调用目标运行函数。
在本发明具体实施例中,进程间通信技术是指至少两个进程或线程间传送数据或信号的技术或方法。每个进程都有自己的一部分独立的系统资源,彼此之间是隔离的。相应的,基于进程间通信技术的智能合约交互方式无需要求目标智能合约与当前区块链采用的原生语言相同,但需要借助轻量级虚拟化技术,例如Docker或者chroot+cgroup等轻量级虚拟化技术,对于代码的运行环境进行各进程的隔离封装,以此实现进程间的通信,便于区块链网络调用目标运行函数。此类调用方式的性能和安全性的综合效果较佳。
可选的,基于远程过程调用技术,调用目标运行函数。
在本发明具体实施例中,远程过程调用技术是指通过网络从远程计算机程序上请求运行目标智能合约的服务。相应的,基于远程过程调用技术的智能合约交互方式需要借助远程智能合约调度器,在有网络的情况下,通过智能合约调度器实现从远程计算机程序上请求运行目标智能合约的服务。此类调用方式较为复杂,应用相对较少。
S240、若检测到目标运行函数的回滚事件,则采用目标运行函数的回滚函数对目标运行函数的执行结果进行回滚。
在本发明具体实施例中,目标智能合约中还可以包括各运行函数对应的回滚函数,运行函数与回滚函数一一对应;或者在目标智能合约中不包括回滚函数时,则可以是系统默认生成运行函数的回滚函数;或者在某些存储结构中不需要回滚数据,则运行函数对应的回滚函数可以为空。因此,对于能够进行回滚的目标运行函数,在检测到目标运行函数的回滚事件时,例如当区块链依据目标运行函数判别所生成的新的区块无效时,可选的,获取目标智能合约中包括的目标运行函数的回滚函数;或者,从预置的回滚函数中选择目标运行函数的回滚函数,采用目标运行函数对应的回滚函数对目标运行函数的执行结果进行回滚,例如对新的区块所产生的事务记录数据进行回滚。
本实施例的技术方案,通过采用区块链原生语言及其对应的插件机制对目标智能合约进行编写,以插件的方式将目标智能合约注册于本地节点的物理机中,并对首次配置于本地节点的目标智能合约进行初始化处理,从而在目标智能合约的执行时,选择目标智能合约中至少一个待运行的目标运行函数,区块链网络采用预设的智能合约交互方式调用选择的目标运行函数。本发明实施例基于区块链原生语言的插件机制编写智能合约,实现了直接在物理机上执行智能合约,避免了在虚拟机上执行智能合约导致的性能低下的问题,提高了区块链编程的亲和性和功能的完备性。
实施例三
图3为本发明实施例三提供的一种智能合约执行装置的结构示意图,本实施例可适用于在物理机上执行智能合约的情况,该装置配置于区块链网络中的节点中,可实现本发明任意实施例所述的智能合约执行方法。该装置具体包括:
目标运行函数选择模块310,用于从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;
目标运行函数调用模块320,用于采用预设的智能合约交互方式,调用所述目标运行函数。
进一步的,所述装置还包括:
目标智能合约初始化模块330,用于在所述从目标智能合约包括的至少一个运行函数中选择目标运行函数之前,在首次将所述目标智能合约配置到本地节点时,采用所述目标智能合约包括的初始化函数对所述目标智能合约进行初始化。
进一步的,所述装置还包括:
回滚模块340,用于在所述采用预设的智能合约交互方式,调用所述目标运行函数之后,若检测到所述目标运行函数的回滚事件,则采用所述目标运行函数的回滚函数对所述目标运行函数的执行结果进行回滚。
可选的,所述回滚模块340具体用于:
在所述采用所述目标运行函数的回滚函数对所述目标运行函数的执行结果进行回滚之前,获取所述目标智能合约中包括的所述目标运行函数的回滚函数;或者,
从预置的回滚函数中选择所述目标运行函数的回滚函数。
可选的,所述目标运行函数调用模块320具体用于:
若所述目标智能合约与区块链采用的原生语言相同;
采用预设的智能合约交互方式,调用所述目标运行函数,包括:
采用动态链接库技术,调用所述目标运行函数。
可选的,所述目标运行函数调用模块320具体用于:
基于进程间通信技术,调用所述目标运行函数。
可选的,所述目标运行函数调用模块320具体用于:
基于远程过程调用技术,调用所述目标运行函数。
本实施例的技术方案,通过各个功能模块之间的相互配合,实现了利用区块链原生语言的插件机制编写目标智能合约、将目标智能合约配置于本地节点的物理机中、初始化函数的调用、目标智能合约的初始化、目标运行函数的选择、目标运行函数的调用以及执行结果的回滚等功能。本发明实施例基于区块链原生语言的插件机制编写智能合约,实现了直接在物理机上执行智能合约,避免了在虚拟机上执行智能合约导致的性能低下的问题,提高了区块链编程的亲和性和功能的完备性。
实施例四
图4为本发明实施例四提供的一种设备的结构示意图,图4示出了适于用来实现本发明实施例实施方式的示例性设备的框图。图4显示的设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
图4显示的设备12仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图4所示,设备12以通用计算设备的形式表现。设备12的组件可以包括但不限于:一个或者多个处理器16,系统存储器28,连接不同系统组件(包括系统存储器28和处理器16)的总线18。
总线18表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,外围总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及外围组件互连(PCI)总线。
设备12典型地包括多种计算机系统可读介质。这些介质可以是任何能够被设备12访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
系统存储器28可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)30和/或高速缓存存储器32。设备12可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统34可以用于读写不可移动的、非易失性磁介质(图4未显示,通常称为“硬盘驱动器”)。尽管图4中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线18相连。系统存储器28可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明实施例各实施例的功能。
具有一组(至少一个)程序模块42的程序/实用工具40,可以存储在例如系统存储器28中,这样的程序模块42包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块42通常执行本发明实施例所描述的实施例中的功能和/或方法。
设备12也可以与一个或多个外部设备14(例如键盘、指向设备、显示器24等)通信,还可与一个或者多个使得用户能与该设备12交互的设备通信,和/或与使得该设备12能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口22进行。并且,设备12还可以通过网络适配器20与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器20通过总线18与设备12的其它模块通信。应当明白,尽管图中未示出,可以结合设备12使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理器、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
处理器16通过运行存储在系统存储器28中的程序,从而执行各种功能应用以及数据处理,例如实现本发明实施例所提供的智能合约执行方法。
实施例五
本发明实施例五还提供一种计算机可读存储介质,其上存储有计算机程序(或称为计算机可执行指令),该程序被处理器执行时用于执行一种智能合约执行方法,该方法包括:
从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;
采用预设的智能合约交互方式,调用所述目标运行函数。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明实施例操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如”C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明实施例进行了较为详细的说明,但是本发明实施例不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。
Claims (16)
1.一种智能合约执行方法,其特征在于,由区块链网络中的节点执行,所述方法包括:
从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;其中,所述区块链原生语言为编写区块链底层网络架构的语言,所述插件机制是指利用所述区块链原生语言对应的插件机制将智能合约编写为插件的形式,并配置于本地节点对应的物理机中;
采用预设的智能合约交互方式,调用所述目标运行函数;其中,所述预设的智能合约交互方式为动态链接库技术、进程间通信技术和远程过程调用技术中的其中一种。
2.根据权利要求1所述的方法,其特征在于,在所述从目标智能合约包括的至少一个运行函数中选择目标运行函数之前,还包括:
在首次将所述目标智能合约配置到本地节点时,采用所述目标智能合约包括的初始化函数对所述目标智能合约进行初始化。
3.根据权利要求1所述的方法,其特征在于,在所述采用预设的智能合约交互方式,调用所述目标运行函数之后,还包括:
若检测到所述目标运行函数的回滚事件,则采用所述目标运行函数的回滚函数对所述目标运行函数的执行结果进行回滚。
4.根据权利要求3所述的方法,其特征在于,在所述采用所述目标运行函数的回滚函数对所述目标运行函数的执行结果进行回滚之前,还包括:
获取所述目标智能合约中包括的所述目标运行函数的回滚函数;或者,
从预置的回滚函数中选择所述目标运行函数的回滚函数。
5.根据权利要求1-4任一项所述的方法,其特征在于,若所述目标智能合约与区块链采用的原生语言相同;
采用预设的智能合约交互方式,调用所述目标运行函数,包括:
采用动态链接库技术,调用所述目标运行函数。
6.根据权利要求1-4任一项所述的方法,其特征在于,所述采用预设的智能合约交互方式,调用所述目标运行函数,包括:
基于进程间通信技术,调用所述目标运行函数。
7.根据权利要求1-4任一项所述的方法,其特征在于,所述采用预设的智能合约交互方式,调用所述目标运行函数,包括:
基于远程过程调用技术,调用所述目标运行函数。
8.一种智能合约执行装置,其特征在于,配置于区块链网络中的节点中,所述装置包括:
目标运行函数选择模块,用于从目标智能合约包括的至少一个运行函数中选择目标运行函数,其中所述目标智能合约是采用区块链原生语言的插件机制编写的;其中,所述区块链原生语言为编写区块链底层网络架构的语言,所述插件机制是指利用所述区块链原生语言对应的插件机制将智能合约编写为插件的形式,并配置于本地节点对应的物理机中;
目标运行函数调用模块,用于采用预设的智能合约交互方式,调用所述目标运行函数;其中,所述预设的智能合约交互方式为动态链接库技术、进程间通信技术和远程过程调用技术中的其中一种。
9.根据权利要求8所述的装置,其特征在于,还包括:
目标智能合约初始化模块,用于在所述从目标智能合约包括的至少一个运行函数中选择目标运行函数之前,在首次将所述目标智能合约配置到本地节点时,采用所述目标智能合约包括的初始化函数对所述目标智能合约进行初始化。
10.根据权利要求8所述的装置,其特征在于,还包括:
回滚模块,用于在所述采用预设的智能合约交互方式,调用所述目标运行函数之后,若检测到所述目标运行函数的回滚事件,则采用所述目标运行函数的回滚函数对所述目标运行函数的执行结果进行回滚。
11.根据权利要求10所述的装置,其特征在于,所述回滚模块具体用于:
在所述采用所述目标运行函数的回滚函数对所述目标运行函数的执行结果进行回滚之前,获取所述目标智能合约中包括的所述目标运行函数的回滚函数;或者,
从预置的回滚函数中选择所述目标运行函数的回滚函数。
12.根据权利要求8-11任一项所述的装置,其特征在于,所述目标运行函数调用模块具体用于:
若所述目标智能合约与区块链采用的原生语言相同;
采用预设的智能合约交互方式,调用所述目标运行函数,包括:
采用动态链接库技术,调用所述目标运行函数。
13.根据权利要求8-11任一项所述的装置,其特征在于,所述目标运行函数调用模块具体用于:
基于进程间通信技术,调用所述目标运行函数。
14.根据权利要求8-11任一项所述的装置,其特征在于,所述目标运行函数调用模块具体用于:
基于远程过程调用技术,调用所述目标运行函数。
15.一种设备,其特征在于,包括:
一个或多个处理器;
存储器,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1至7中任一项所述的智能合约执行方法。
16.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1至7中任一项所述的智能合约执行方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810778243.6A CN109032706B (zh) | 2018-07-16 | 2018-07-16 | 智能合约执行方法、装置、设备和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810778243.6A CN109032706B (zh) | 2018-07-16 | 2018-07-16 | 智能合约执行方法、装置、设备和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109032706A CN109032706A (zh) | 2018-12-18 |
CN109032706B true CN109032706B (zh) | 2022-10-11 |
Family
ID=64642572
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810778243.6A Active CN109032706B (zh) | 2018-07-16 | 2018-07-16 | 智能合约执行方法、装置、设备和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109032706B (zh) |
Families Citing this family (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109710235B (zh) * | 2018-12-29 | 2022-04-01 | 杭州趣链科技有限公司 | 一种基于Java智能合约业务逻辑的事务实现系统及方法 |
CN110097464B (zh) * | 2019-04-10 | 2021-09-14 | 北京京东尚科信息技术有限公司 | 智能合约的生成方法、装置、电子设备与存储介质 |
CN110069295B (zh) * | 2019-05-06 | 2022-06-17 | 百度在线网络技术(北京)有限公司 | 区块链处理方法、装置、设备和介质 |
CN110096338B (zh) * | 2019-05-10 | 2021-12-14 | 百度在线网络技术(北京)有限公司 | 智能合约执行方法、装置、设备及介质 |
CN110221837A (zh) * | 2019-05-21 | 2019-09-10 | 深圳壹账通智能科技有限公司 | 智能合约调用方法、装置、设备和存储介质 |
CN110399184B (zh) * | 2019-07-31 | 2023-04-25 | 中国工商银行股份有限公司 | 区块链中智能合约的执行方法及装置 |
CN110995825B (zh) * | 2019-11-29 | 2022-08-26 | 腾讯科技(深圳)有限公司 | 一种智能合约的发布方法、智能节点设备及存储介质 |
CN111026461B (zh) * | 2019-12-06 | 2022-04-22 | 联想(北京)有限公司 | 用于区块链系统的数据处理方法、装置和电子设备 |
CN111179086B (zh) * | 2019-12-31 | 2024-01-02 | 杭州趣链科技有限公司 | 一种基于WebAssembly的智能合约虚拟机 |
CN111258714B (zh) * | 2020-01-13 | 2023-03-10 | 电子科技大学 | 一种区块链智能合约执行方法 |
CN111259298B (zh) * | 2020-01-16 | 2023-06-27 | 深圳市华海同创科技有限公司 | 基于区块链的话题生成方法、节点服务器及存储介质 |
CN111240772B (zh) * | 2020-01-22 | 2024-06-18 | 腾讯科技(深圳)有限公司 | 一种基于区块链的数据处理方法、装置及存储介质 |
CN111414159B (zh) * | 2020-03-16 | 2023-07-25 | 北京艾鸥科技有限公司 | 一种区块链虚拟机装置、虚拟机创建方法及交易方法 |
CN111324396B (zh) * | 2020-03-19 | 2023-09-15 | 深圳市迅雷网络技术有限公司 | 一种区块链智能合约执行方法、装置及设备 |
CN111524007A (zh) * | 2020-04-16 | 2020-08-11 | 广州拉卡拉信息技术有限公司 | 一种智能合约的嵌入式入侵检测方法及装置 |
CN111562969B (zh) * | 2020-07-15 | 2020-10-20 | 百度在线网络技术(北京)有限公司 | 一种区块链的智能合约实现方法、装置、设备和介质 |
CN112799674B (zh) * | 2021-01-19 | 2024-03-26 | 腾讯科技(深圳)有限公司 | 区块链中智能合约的执行方法、装置及节点设备 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106982205A (zh) * | 2017-03-01 | 2017-07-25 | 中钞信用卡产业发展有限公司北京智能卡技术研究院 | 基于区块链的数字资产处理方法和装置 |
CN107124278A (zh) * | 2017-03-30 | 2017-09-01 | 腾讯科技(深圳)有限公司 | 业务处理方法、装置以及数据共享系统 |
CN107147704A (zh) * | 2017-04-21 | 2017-09-08 | 杭州趣链科技有限公司 | 一种面向区块链的通用服务中间件系统 |
AU2017101413A4 (en) * | 2017-10-23 | 2017-11-23 | Bloxian International Pty Ltd | Method and system for streamlining property buying journey using blockchain and smart contracts. |
CN107679857A (zh) * | 2017-10-10 | 2018-02-09 | 马晶瑶 | 区块链的跨链交易方法和存储介质 |
-
2018
- 2018-07-16 CN CN201810778243.6A patent/CN109032706B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106982205A (zh) * | 2017-03-01 | 2017-07-25 | 中钞信用卡产业发展有限公司北京智能卡技术研究院 | 基于区块链的数字资产处理方法和装置 |
CN107124278A (zh) * | 2017-03-30 | 2017-09-01 | 腾讯科技(深圳)有限公司 | 业务处理方法、装置以及数据共享系统 |
CN107147704A (zh) * | 2017-04-21 | 2017-09-08 | 杭州趣链科技有限公司 | 一种面向区块链的通用服务中间件系统 |
CN107679857A (zh) * | 2017-10-10 | 2018-02-09 | 马晶瑶 | 区块链的跨链交易方法和存储介质 |
AU2017101413A4 (en) * | 2017-10-23 | 2017-11-23 | Bloxian International Pty Ltd | Method and system for streamlining property buying journey using blockchain and smart contracts. |
Also Published As
Publication number | Publication date |
---|---|
CN109032706A (zh) | 2018-12-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109032706B (zh) | 智能合约执行方法、装置、设备和存储介质 | |
CN110096338B (zh) | 智能合约执行方法、装置、设备及介质 | |
US9852015B2 (en) | Automatic discovery of a JavaScript API | |
US10996997B2 (en) | API-based service command invocation | |
US9075601B1 (en) | Providing a scripting interface to existing code | |
US9489182B1 (en) | Transparent process interception | |
US8938712B2 (en) | Cross-platform virtual machine and method | |
US10838780B2 (en) | Portable hosted content | |
US9710575B2 (en) | Hybrid platform-dependent simulation interface | |
US20190220294A1 (en) | Using lightweight jit compilation for short-lived jvms on parallel distributing computing framework | |
US9632816B2 (en) | Scaling past the Java virtual machine thread limit | |
US10599465B2 (en) | Off-the-shelf software component reuse in a cloud computing environment | |
US11689630B2 (en) | Request processing method and apparatus, electronic device, and computer storage medium | |
US11500661B2 (en) | Performing an application snapshot using process virtual machine resources | |
US11178216B2 (en) | Generating client applications from service model descriptions | |
US20180129517A1 (en) | Performance acceleration in mixed-language applications | |
CN112068814A (zh) | 可执行文件的生成方法、装置、系统及介质 | |
JP2007141248A (ja) | ジャバ言語におけるメソッド参照のサポート | |
CN110990167A (zh) | 前端通信方法及装置、存储介质及电子设备 | |
CN116701790B (zh) | 基于路由的前端权限控制方法及相关设备 | |
CN112817573B (zh) | 用于构建流式计算应用的方法、装置、计算机系统和介质 | |
CN112929675B (zh) | 一种图像资源的压缩方法、装置和电子设备 | |
US11194612B2 (en) | Selective code segment compilation in virtual machine environments | |
CN117785511A (zh) | 功能数据处理的方法及装置、存储介质及电子设备 | |
CN117519712A (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 |