CN111770205A - 一种执行智能合约的方法、区块链节点、系统和存储介质 - Google Patents
一种执行智能合约的方法、区块链节点、系统和存储介质 Download PDFInfo
- Publication number
- CN111770205A CN111770205A CN202010901436.3A CN202010901436A CN111770205A CN 111770205 A CN111770205 A CN 111770205A CN 202010901436 A CN202010901436 A CN 202010901436A CN 111770205 A CN111770205 A CN 111770205A
- Authority
- CN
- China
- Prior art keywords
- intelligent contract
- code
- block chain
- machine code
- byte
- 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.)
- Granted
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1097—Protocols 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]
-
- 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
- G06F9/45516—Runtime code conversion or optimisation
- G06F9/4552—Involving translation to a different instruction set architecture, e.g. just-in-time translation in a JVM
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
-
- 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/445—Program loading or initiating
- G06F9/44589—Program code verification, e.g. Java bytecode verification, proof-carrying code
-
- 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
-
- 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
- G06F9/45508—Runtime interpretation or emulation, e g. emulator loops, bytecode interpretation
-
- 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
- G06F9/45516—Runtime code conversion or optimisation
- G06F9/45525—Optimisation or modification within the same instruction set architecture, e.g. HP Dynamo
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/04—Payment circuits
- G06Q20/06—Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme
- G06Q20/065—Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme using e-cash
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/382—Payment protocols; Details thereof insuring higher security of transaction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q40/00—Finance; Insurance; Tax strategies; Processing of corporate or income taxes
- G06Q40/04—Trading; Exchange, e.g. stocks, commodities, derivatives or currency exchange
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3236—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
- H04L9/3239—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/50—Cryptographic 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)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Business, Economics & Management (AREA)
- General Engineering & Computer Science (AREA)
- Accounting & Taxation (AREA)
- Computer Security & Cryptography (AREA)
- Finance (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Development Economics (AREA)
- Economics (AREA)
- Marketing (AREA)
- Technology Law (AREA)
- Devices For Executing Special Programs (AREA)
- Stored Programmes (AREA)
Abstract
本说明书一个或多个实施例提供一种执行智能合约的方法、区块链节点、系统和存储介质。一种执行智能合约的方法实施例包括:第一区块链节点、第二区块链节点分别接收创建智能合约的请求,所述请求中包括所述智能合约的字节码;第一区块链节点、第二区块链节点分别在完成所述智能合约的部署后,开始将所述智能合约的字节码通过JIT编译为机器码并存储;第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码;第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
Description
技术领域
本说明书实施例属于区块链技术领域,尤其涉及一种执行智能合约的方法、区块链节点、系统和存储介质。
背景技术
区块链(Blockchain)是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链2.0时代中出现了智能合约,将区块链的应用范围提升到了一个新高度。有了智能合约,区块链能做不再是单一的转账交易,而是还可以调用一段代码,而这段代码可以由用户自定义。
发明内容
本说明书在于提供一种执行智能合约的方法、区块链节点、系统和存储介质。
本说明书实施例提供的一种执行智能合约的方法、区块链节点、系统和存储介质,通过以下方式实现:
一种执行智能合约的方法,包括:
第一区块链节点、第二区块链节点分别接收创建智能合约的请求,所述请求中包括所述智能合约的字节码;
第一区块链节点、第二区块链节点分别在完成所述智能合约的部署后,开始将所述智能合约的字节码通过JIT编译为机器码并存储;
第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码;
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
一种执行智能合约的方法,包括:
第一区块链节点、第二区块链节点分别在部署所述智能合约的字节码后,开始将所述智能合约的字节码通过JIT编译为机器码并存储;
第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码;
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
一种执行智能合约的区块链系统,包括第一区块链节点和第二区块链节点,第一区块链节点执行上述方法中由第一区块链节点执行的操作,第二区块链节点执行上述方法中由第二区块链节点执行的操作。
一种执行智能合约的区块链系统,包括:
第一区块链节点,包括处理器和存储器;存储器内存储有程序,其中在所述处理器执行所述程序时,执行上述方法中由第一区块链节点执行的操作;
第二区块链节点,包括处理器和存储器;存储器内存储有程序,其中在所述处理器执行所述程序时,执行上述方法中由第二区块链节点执行的操作。
一种执行智能合约的区块链节点,执行上述的方法中由第一区块链节点和/或第二区块链节点执行的操作。
一种执行智能合约的区块链节点,包括:
处理器,
存储器,存储有程序,其中在所述处理器执行所述程序时,执行上述的方法中由第一区块链节点和/或第二区块链节点执行的操作。
一种存储介质,用于存储程序,其中所述程序在被执行时进行上述方法的操作。
通过上述本说明书的实施例,在存储有智能合约的机器码的情况下,由于机器码本身即是CPU可以直接执行的,因此,第一区块链节点可以大幅提升执行智能合约的速度。而在局部编译尚未完成的情况下,第二区块链通过对所述智能合约的字节码进行解释执行,从而可以在局部编译的同时保证区块链业务请求的正常处理。由于不同区块链节点在处理性能等方面均可能存在差异,使得不同区块链节点在执行同一交易所指示的智能合约时,对于该智能合约的编译进度可能存在不同,那么可以在确定机器码与字节码的执行结果一致的情况下,由已编译完成的第一区块链节点执行机器码、尚未编译或尚未完成编译的第二区块链节点解释执行字节码,而无需第一区块链节点等待第二区块链节点的编译操作完成,有助于提升智能合约的执行效率。
附图说明
图1是一实施例中编译执行和解释执行的原理示意图;
图2是一实施例中解释执行和JIT编译的原理示意图;
图3为一个实施例的创建智能合约的图示过程;
图4为一个实施例的调用智能合约的图示过程;
图5为一个实施例中创建智能合约和调用智能合约的示意图;
图6-1是一实施例中的执行智能合约的流程图;
图6-2是另一实施例中的执行智能合约的流程图;
图7是一实施例中的区块链节点的模块结构图;
图8是一实施例中的创建智能合约和调用智能合约的示意图;
图9为一实施例中的创建智能合约和调用智能合约过程中包含虚拟机执行过程的示意图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本说明书一个或多个实施例相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本说明书一个或多个实施例的一些方面相一致的装置和方法的例子。
需要说明的是:在其他实施例中并不一定按照本说明书示出和描述的顺序来执行相应方法的步骤。在一些其他实施例中,其方法所包括的步骤可以比本说明书所描述的更多或更少。此外,本说明书中所描述的单个步骤,在其他实施例中可能被分解为多个步骤进行描述;而本说明书中所描述的多个步骤,在其他实施例中也可能被合并为单个步骤进行描述。
区块链1.0时代通常是指在2009年到2014年之间,以比特币为代表的区块链应用发展阶段,它们主要致力于解决货币和支付手段的去中心化问题。从2014年开始,开发者们越来越注重于解决比特币在技术和扩展性方面的不足。2013年底,VitalikButerin发布了以太坊白皮书《以太坊:下一代智能合约和去中心化应用平台》,将智能合约引入区块链,打开了区块链在货币领域以外的应用,从而开启了区块链2.0时代。
智能合约是一种基于规定触发规则的,可自动执行的计算机合约,也可以看作是传统合约的数字版本。智能合约这一概念最早由跨领域法律学者、密码学研究工作者尼克·萨博(Nick Szabo)在1994年提出。这项技术曾一度因为缺乏可编程数字系统和相关技术而没有被用于实际产业中,直到区块链技术和以太坊的出现为其提供了可靠的执行环境。由于区块链技术采用的块链式账本,产生的数据不可篡改或者删除,且整个账本将不断新增账本数据,从而保证了历史数据的可追溯;同时,去中心化的运行机制避免了中心化因素的影响。基于区块链技术的智能合约不仅可以发挥智能合约在成本、效率方面的优势,而且可以避免恶意行为对合约正常执行的干扰。将智能合约以数字化的形式写入区块链中,由区块链技术的特性保障存储、读取、执行整个过程透明可跟踪、不可篡改。
智能合约本质上是一段可由计算机执行的程序。智能合约与现在广泛使用的计算机程序一样,可以通过高级语言(例如C语言、C++语言等)编写而成。由高级语言编写好的智能合约的程序代码,一般可以通过“编译器”转换为计算机的CPU可以识别和运行的“机器码”,进而可以由CPU执行这样的机器码(或者称为“微处理器指令”)。这种方式一般称为“编译执行”。
编译执行一般不具有跨平台的可扩展性。由于存在不同厂商、不同品牌和不同代的CPU,而这些不同的CPU支持的指令集很多情况下是不同的,如x86指令集,ARM指令集等,且同一厂商同一品牌但不同代的CPU(如不同代的Intel CPU)支持的指令集也不完全相同,因此,用同样的高级语言编写的同样的程序代码,在不同CPU上被编译器转换出来的机器码可能不同。具体的,编译器在转换高级语言编写的程序代码到机器码的过程中,会结合具体的CPU指令集的特点(如向量指令集等)进行优化以提升程序执行的速度,而此类优化往往与具体的CPU硬件相关。这样,同样的机器码,一个在x86上可以运行,但另一个在ARM上就可能无法运行;甚至同样是x86平台,随着时间的推移,指令集也不断丰富和扩展,这就导致不同代的x86平台运行的机器码也有不同。而且,由于执行机器码需要由操作系统内核对CPU进行调度,因此即使是同样的硬件,在不同操作系统下支持运行的机器码也可能不同。
不同于编译执行,还存在一种“解释执行”的程序运行方式。比如Java语言,将Java源代码通过Java的编译器编译成标准的字节码(bytecode),这里编译器不针对任何实际的硬件处理器的指令集,而是定义了一套抽象的标准指令集。编译成的标准字节码一般无法在硬件CPU上直接运行,因此引入了一个虚拟机,即JVM,JVM运行在特定的硬件处理器上,用以解释和执行编译后的标准字节码。
JVM是Java Virtual Machine(Java虚拟机)的缩写,是一种虚构出来的计算机,往往通过在实际的计算机上仿真模拟各种计算机功能来实现。JVM屏蔽了与具体的硬件平台、操作系统等相关的信息,使Java程序只需要是生成的可在Java虚拟机上运行的标准字节码,就可以在多种平台上不加修改地运行。
Java语言的一个非常重要的特点就是与平台的无关性。而使用Java虚拟机是实现这一特点的关键。一般的高级语言如果要在不同的平台上运行,至少需要编译成不同的目标代码。而引入Java语言虚拟机后,Java语言在不同平台上运行时不需要重新编译。Java语言使用Java虚拟机屏蔽了与具体平台相关的信息,使得Java语言编译程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。Java虚拟机在执行字节码时,把字节码解释成具体平台上的机器指令执行。这就是Java能够“一次编译,到处运行”的原因。
JVM运行在特定的硬件处理器上,负责针对所运行的特定处理器而进行字节码的解释和执行,并向上屏蔽这些底层的差异,呈现给开发者以标准的开发规范。JVM在执行字节码时,实际上最终还是把字节码解释成具体平台上的机器指令执行。具体的,JVM接收到输入的字节码后,逐句解释其中的每一条指令,并翻译成适合当前机器的机器码来运行,这些过程例如由称为Interpreter的解释器进行解释和执行。这样一来,编写Java程序的开发者不需要考虑编写后的程序代码将运行在哪种硬件平台上。JVM本身的开发是由Java组织的专业开发人员完成,以将JVM适配到不同的处理器架构上。迄今为止,主流的处理器架构只有有限的几种,如X86,ARM,RISC-V,MIPS。专业的开发人员将JVM分别移植到支持这几种特定硬件的平台后,Java程序理论上就可以在所有的机器上运行了。JVM的移植工作通常由Java开发组织专业的人员提供的,这就极大减轻了Java应用开发者的负担。
解释执行带来了跨平台可移植性,但由于bytecode的执行经历了JVM中间翻译的过程,因此执行效率不如上述编译执行效率高,这种效率的差异有时甚至可达几十倍。
图1示出了编译执行和解释执行的共同点和不同点。不论是解释执行还是编译执行,也不论是物理机还是虚拟机,对于应用程序,机器都不可能如人那样阅读、理解,然后就获得了执行能力。大部分的程序代码到物理机的目标代码或虚拟机能执行的指令集之前,都需要经过图1中的各个步骤。图1中从顶部到左边的那条分支就是传统编译原理中程序代码到目标机器代码的生成过程,从顶部到右边的那条分支是解释执行的过程。如今,基于物理机、Java虚拟机,或者非Java的其他高级语言虚拟机(High-Level Language VirtualMachine,HLLVM)的语言,大多都会遵循这种基于现代经典编译原理的思路,在执行前先对程序源码进行词法分析和语法分析处理,把源码转化为抽象语法树(Abstract SyntaxTree,AST)。对于一门具体语言的实现来说,词法分析、语法分析以至后面的优化器和目标代码生成器都可以选择独立于执行引擎,形成一个完整意义的编译器去实现,这类代表是C或C++语言。也可以选择把其中一部分步骤(如生成抽象语法树之前的步骤)实现为一个半独立的编译器,这类代表是Java语言。又或者把这些步骤和执行引擎全部集中封装在一个封闭的黑匣子之中,如大多数的JavaScript执行器。
为了尽可能的兼顾跨平台可移植性和高性能,即时编译器(Just-In-TimeCompiler,JIT)的概念被提出。JIT的核心思想是“如何高效避免解释指令的重复工作”。计算机程序中存在大量重复执行的代码,比如某些计算“函数”在一个程序执行过程中可能被循环调用了很多次。如果是解释执行,则循环过程的每次执行都要对这个函数进行字节码到机器码的翻译。然而实际情况是,这个函数在几十次的翻译中产生的机器码都是完全一样的。很自然的,在第一次翻译后,将翻译好的函数的机器码缓存下来,后续再次执行的过程中,不需要再次翻译,而是直接使用缓存好的代码,这样可以提高执行效率。
相反的,有些函数在程序运行周期过程中只执行了一次(比如启动初始化),那么这类函数就不需要缓存,直接解释执行一次即可。因此JIT技术中一个核心的模块就是“热点分析”,即通过程序执行过程中分析出哪些代码执行了多次,从而对其翻译后的机器码进行缓存。对于执行次数较少的操作,不需要进行缓存。这样可以在执行效率和内存开销上达到最佳平衡。
此外,JIT技术中的另一个核心的模块是编译优化(或称为优化编译)。直接翻译的机器码,没有结合上下文进行优化,仅仅是将高频的机器码缓存下来,性能提升有限。如果要获得更好的性能,可以对编译器进行进一步的优化。编译优化的方式,一般需要相对更多的时间来实现。
JIT的工作原理例如图2中所示。Java源代码经过Java编译器编译后生成一段Java字节码,经过热点分析后被分发到两个执行路径上(JIT Compiler和Interpreter)。被判断为热点(高频执行)的代码经JIT compiler中进行编译得到机器码,缓存并执行,一般是由CPU在操作系统(Operating System,OS)的控制下执行。低频的进入解释器(Interpreter),翻译成机器码后由CPU在OS的控制下执行。
由于程序代码本身的前后关联性,编译过程往往存在较大的优化空间。优化后的机器码,执行效率会远高于直接翻译的机器码。如果要获得更好的性能,编译器的优化是必须的。JIT compiler编译的过程可能比较耗时。特别是JIT Compiler在第一次编译字节码的过程可能耗时很长,甚至不如解释执行。那么,对于某些java程序,如果热点不是很突出,即整体的执行频度都不是很高,而整体执行流程又很长的,JIT就很难发挥出编译执行的优势。
此外,还有一种想法被提出,就是AoT (Ahead of Time)。AoT相当于一种预编译执行的方法。在程序运行前针对目标执行环境对字节码进行一次编译,得到机器码,再将机器码部署到目标机器上执行,例如图8所示的过程。AoT的运行效率可以达到编译执行的效果,但在AoT时需要明确知道目标系统的硬件、指令集架构和系统等,确保编译后代码可以运行。而且,一般来说同样功能的指令,用机器码表达所需的语句量会大于字节码,更大于高级语言编写的代码,这样,同样内容的程序,很可能机器码的大小>字节码的大小>高级语言代码的大小。在明确知道目标系统的硬件、指令集架构和系统等情形的前提下,可以通过AoT将字节码编译为机器码。同时,不同类别的目标系统的机器码是不同的,因此,为了各种目标系统上都可以有对应的正确执行的机器码,可能需要将不同版本的机器码都提供。这样,机器码的总大小一般会大于字节码或是高级语言代码。
例如,Android在5.0版本以前采用Dalvik虚拟机,而在5.0版本以后采用了ART虚拟机。Dalvik是采用JIT编译器去解释字节码,而ART则是AoT机制。ART方式在应用安装时就预编译字节码(Android App的安装过程实际上是安装程序的字节码)到机器码。在移除解释代码这一过程后,Android上的应用程序执行更有效率,启动更快。
区块链中作为一个去中心化的分布式系统,需要保持分布式一致性。具体的,分布式系统中的一组节点,每个节点都内置了状态机。每个状态机需要从相同的初始状态起,按相同的顺序执行相同的指令,保持每一次状态的改变都相同,从而保证最终达到一致的状态。而参与到同一区块链网络的各个节点设备很难都是同样的硬件配置和软件环境。因此,在区块链2.0中的代表以太坊中,为了保证各个节点上执行智能合约的过程和结果是相同的,采用了类似于JVM的虚拟机——以太坊虚拟机(Ethereum Virtual Machine,EVM)。通过EVM可以屏蔽各个节点硬件配置和软件环境的差异性。这样,开发者可以开发一套智能合约的代码,并将该智能合约的代码在开发者本地编译后将编译得到的字节码(bytecode)上传到区块链。各个节点以相同的初始状态通过相同的EVM解释执行相同的字节码后,能够得到相同的最终结果和相同的中间结果,并可以屏蔽不同节点底层的硬件和环境差异。这样,去中心化的区块链技术的出现,才使得早在1994年就提出的智能合约得以实现,并且,由于去中心化的实现必然面临不同执行机器的硬件和运行环境差异,进一步以解释执行的方式对智能合约处理,以保证在去中心的多种不同硬件和运行环境的机器上能够得到相同的执行结果。
EVM是一个图灵完备的虚拟机,这意味着可以通过它实现各种复杂的逻辑,这也是以太坊作为区块链2.0的代表相对于区块链1.0的最大改进之一。用户在以太坊中发布和调用智能合约可以在EVM上运行。如前所述,EVM直接运行的是字节码,部署在区块链上的智能合约可以是字节码的形式。
如图3所示,Bob将一个包含创建智能合约信息的交易发送到以太坊网络后,节点1的EVM可以执行这个交易并生成对应的合约实例。图3中交易的data字段保存的可以是字节码,交易的to字段可以为一个空的地址。节点间通过共识机制达成一致后,这个合约成功创建,后续用户可以调用这个合约。
合约创建后,区块链上出现一个与该智能合约对应的合约账户,并拥有一个特定的地址,合约代码和账户存储可以保存在该合约账户中。智能合约的行为由合约代码控制,而智能合约的账户存储则保存了合约的状态。换句话说,智能合约使得区块链上产生包含合约代码和账户存储的虚拟账户。
前述提到,包含创建智能合约的交易的data字段保存的可以是该智能合约的字节码。字节码由一连串的字节组成,每一字节可以表明一个操作。基于开发效率、可读性等多方面考虑,开发者可以不直接书写字节码,而是选择一门高级语言编写智能合约代码。高级语言编写的智能合约代码,经过编译器编译,生成字节码,进而该字节码可以部署到区块链上。以太坊支持的高级语言很多,如Solidity、Serpent、LLL语言等。
以Solidity语言为例,用其编写的合约与面向对象编程语言中的类(Class)很相似,在一个合约中可以声明多种成员,包括状态变量、函数、函数修改器、事件等。状态变量是永久存储在智能合约的账户存储中的值,用于保存合约的状态。
如下是以Solidity语言编写的一个简单的智能合约的代码示例1:
Contract Example{
int balance;
function C( ){
balance + = 1;
}
functiongetbalance( ) returns(int){
return balance ;
}
}
一般的,这个合约部署在区块链后,“balance”这个状态变量可以是在合约中新定义的一种资产类型。function C()这个函数可以定义balance的变化操作,functiongetbalance() returns(int) 这个函数可以定义取当前balance的值并返回的操作。
此外,如图4所示,仍以以太坊为例,Bob将一个包含调用智能合约信息的交易发送到以太坊网络后,节点1的EVM可以执行这个交易并生成对应的合约实例。图4中交易的from字段是发起调用智能合约的账户的地址,to字段中的“0x692a70d2…”代表了被调用的智能合约的地址,value字段在以太坊中是以太币的值,交易的data字段保存的是调用智能合约的方法和参数。调用智能合约后,balance的值可能改变。后续,某个客户端可以通过某一区块链节点查看balance的当前值。
智能合约可以以规定的方式在区块链网络中每个节点独立的执行,所有执行记录和数据都保存在区块链上,所以当交易完成后,区块链上就保存了无法篡改、不会丢失的交易凭证。
创建智能合约和调用智能合约的示意图如图5所示。以太坊中要创建一个智能合约,需要经过编写智能合约、变成字节码(例如经过Solc或C++等编译工具编译为Bytecode)、部署到区块链等过程。以太坊中调用智能合约,是发起一笔指向智能合约地址的交易(可以通过交易中的to字段指向智能合约的地址),智能合约代码分布式的运行在以太坊网络中每个节点的虚拟机中。
创建智能合约的交易发送到区块链网络上,经过共识之后,各个区块链节点可以执行这个交易。具体的,可以是由区块链节点的EVM和/或WASM来执行这个交易。如前所述,这时区块链上出现一个与该智能合约对应的合约账户(包括例如帐户的标识Identity,合约的hash值Codehash,合约存储的根StorageRoot),并拥有一个特定的地址,合约代码和账户存储可以保存在该合约账户的存储(Storage)中,如图9所示。智能合约的行为由合约代码控制,而智能合约的账户存储则保存了合约的状态。换句话说,智能合约使得区块链上产生包含合约代码和账户存储的虚拟账户。对于合约部署交易或者合约更新交易,可以产生或变更Codehash的值。后续,区块链节点可以接收调用部署的智能合约的交易请求,该交易请求可以包括调用的合约的地址、调用的合约中的函数和输入的参数。一般的,该交易请求经过共识后,区块链各个节点可以各自独立执行指定调用的智能合约。具体的,如图9所示,节点可以根据合约的地址将合约的字节码(Bytecode)从存储载入虚拟机(EVM和/或WASM)中;进而,由解释器(Interpreter)解释执行,例如包括对调用的合约的字节码进行解析,得到操作码(OPcode),并将这些OPcode存储虚拟机的Memory中,同时还得到调用的函数的地址;经过对执行合约所需要消耗的Gas进行计算且Gas足够后,跳转到Memory的对应地址取得所调用函数的OPcode并开始执行,对所调用到的函数的OPcode所操作的数据进行计算(Data Computation)、推入/推出栈(Stack)等的操作,从而完成数据计算。这个过程中,还可能需要一些合约的上下文(Context)信息,例如区块号、调用合约的发起者的信息之类,这些信息可以从Context中得到(Get操作)。最后,将产生的状态通过调用存储接口以存入存储(Storage)中。需要说明的是,合约创建的过程中,也可能产生对合约中某些函数的解释执行,例如初始化操作的函数,这时也会解析代码、产生跳转指令,存入Memory,在Stack中操作数据等。上述涉及的解释执行过程中,一般来说,对重复执行的函数并不缓存,即使对于多次执行的函数,虚拟机也需要重复进行解析、执行的过程。
如同前面提到的JVM的跨平台可移植性的优点和有提升性能的需求,类似的,区块链中的EVM也可以采用JIT和AoT之类的技术来提升智能合约执行时的性能。本说明书提供一种执行智能合约的方法实施例,如图6-1所示,包括:
S611:第一区块链节点、第二区块链节点分别接收创建智能合约的请求,所述请求中包括所述智能合约的字节码。
用户可以在用户本地用高级语言编写智能合约。编写好的智能合约可以经过编译器编译,得到字节码。进而,可以通过客户端将编译得到的智能合约的字节码打包到交易中,发送至区块链网络。交易的格式例如为图3~5中所示,其中,需要创建的智能合约的字节码可以存放于交易的data字段中。
用户也可以是在区块链网络中的任一区块链节点上直接用高级语言编写智能合约,则该区块链节点还可以采用编译器对高级语言编写的智能合约进行编译,生成字节码。
第一区块链节点与第二区块链节点用于指代区块链网络中一般性的区块链节点,而并非特指某个或某些区块链节点。其中,第一区块链节点用于指代在执行部署的智能合约时已经编译得到机器码的区块链节点、第二区块链节点用于指代执行部署的智能合约时尚未编译得到机器码的区块链节点。实际上,除了对于智能合约的编译速度不同而导致执行的代码可能为机器码或字节码之外,第一区块链节点与第二区块链节点并不存在其他功能上的差异,因而下文描述过程中在不涉及到执行机器码或字节码的情况下,可能统一采用“区块链节点”的描述,而不对第一区块链节点、第二区块链节点予以区分。
S613:第一区块链节点、第二区块链节点分别在完成所述智能合约的部署后,开始将所述智能合约的字节码通过JIT编译为机器码并存储。
以太坊及类似原理的公有链、联盟链或者私有链系统中,区块链节点可以针对一批交易发起共识。所述一批交易中,可以包括上述创建智能合约的交易。通过共识后,一般的,各共识节点本地都存有所述待创建的智能合约的字节码。各共识节点本地可以执行所述创建智能合约的交易,创建对应的合约账户;并按照相同的规则给所述智能合约账户创建一个地址,各共识节点针对同一合约创建的地址是相同的。这样,就完成了合约的部署。
所述区块链节点完成创建所述智能合约后,即部署所述智能合约之后,可以开始将所述智能合约的字节码通过JIT编译为机器码并存储。所述区块链节点完成创建所述智能合约后,可以立即开始对所述智能合约的字节码进行JIT编译。这是因为,在部署智能合约之后,可能很快就有发起调用部署的智能合约的业务请求。此外,JIT需要花费相对较多的系统资源和时间,在区块链节点的业务负荷较重时分配系统资源进行JIT会影响业务的处理;因此,区块链节点也可以是利用相对空闲的时间段再对所述智能合约的字节码进行JIT编译,从而降低或避免对业务处理的影响。此外,所述区块链节点完成创建所述智能合约后,也可以是区块链节点接收到调用创建的所述智能合约的交易请求后,对所述智能合约的字节码进行JIT编译。
区块链各节点针对相同的智能合约的字节码在本地进行JIT编译,各节点仅需针对自身的处理器架构、运行环境等进行调整,而不需要编译多个不同版本的机器码。这样,节点设备上存储的机器码的大小得以大大降低,从而可以降低存储开销。
优选的,所述存储为缓存,通过缓存到内存,后续可以更快速的作出响应。具体的,所述内存可以是在虚拟机中开辟的一块缓存区域。当然,即使存储到磁盘,很多情形下也可以一定程度的提升响应速度。
区块链中的EVM采用JIT技术来提升智能合约执行时的性能,具体的,可以包括:
首先,可以对所述智能合约的字节码进行翻译和/或执行的过程中识别热点代码,例如通过JIT引擎的代码计数器来统计执行次数,从而分析出哪些字节码是多次执行的,从而对其翻译后的机器码进行缓存。而对于执行次数较少的操作,可以不进行缓存。这样可以在执行效率和内存开销上达到最佳平衡。识别热点代码并缓存的方式,可以使得多次执行字节码的过程中,在除了首次需要翻译外,后续可以直接利用缓存的机器码,从而免去再次翻译字节码的过程,从而可以缩减时间。识别执行次数的粒度,可以是函数级别,还可以是代码块级别。一般来说,代码块可能是函数中的一部分,也可能是由若干函数构成。
其次,可以在JIT编译中进行进一步的优化,结合程序代码的前后关联进行编译,并将优化编译后的机器码缓存下来以供后续调用时使用。经过编译优化的机器码,执行效率一般会高于直接翻译得到的机器码。一方面,JIT引擎可以带上执行编译的区块链节点的硬件和环境信息,从而使得编译得到的机器码具有硬件+环境的优化,具体可以包括机器代码生成过程中的优化,包括指令级的优化,寄存器分配和优化等等。另一方面,JIT引擎可以分析上下文信息,比如当前函数中执行的分支跳转语句,识别其中哪一句是跳转可能行最大的,从而将这个跳转可能性最大的调整到最前,从而可以在执行时更高概率的首先命中该分支的语句;编译器优化过程还可以通过数据流分析和/或活跃变量分析进行死代码消除,例如消除不会走到的分支,此外还可以包括对循环语句进行优化,公共字表达式替换等。
S615a:第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码。
S615b:第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
完成智能合约的部署后,可以提供对该合约的调用。这样,客户端(可能不同于S611中发起创建合约交易的客户端)可以发起对该合约的调用。例如,客户端发起一个交易,其中的to字段中为前述部署的智能合约的地址,data字段可以包括所调用的合约的方法和输入的参数,从而实现对部署的所述智能合约的调用。一般的,包括该调用合约的交易在内的一批交易经过共识后,各共识节点各自分别执行交易。
区块链网络中的每个区块链节点执行部署的所述智能合约时,可以先查看本地是否存在该被调用的合约的机器码。如存在,则说明本地已经对该智能合约的字节码的进行过JIT编译,否则表明本地尚未针对该智能合约的字节码进行JIT编译,或者编译尚未结束。由于不同区块链节点的处理性能可能存在差异,或者可能存在其他因素,导致不同区块链节点对于被调用合约的字节码实施JIT编译的进度有所不同,比如第一区块链节点已经编译生成了该智能合约的机器码、第二区块链节点尚未针对该智能合约的字节码进行JIT编译或者编译尚未结束。
第一区块链节点可以等待第二区块链节点执行JIT编译,在确定第二区块链节点已经编译生成机器码的情况下,由第一区块链节点、第二区块链节点各自执行本地的机器码。但是,上述等待过程将造成第一区块链节点的反馈延迟,拖慢了交易执行速度;以及,第二区块链节点同样无法实现快速反馈。同时,第一区块链节点不能够抢先执行机器码,否则第二区块链节点如果发生编译失败或其他异常,将导致第一区块链节点与第二区块链节点之间出现状态数据不一致的情况。
为了满足及时响应、快速反馈的需求,第一区块链节点可以无需等待第二区块链节点的JIT编译过程,而是由第一区块链节点与第二区块链节点分别执行不同形式的合约代码:
第一区块链节点由于已经完成编译,因而可以执行编译得到的机器码,避免等待第二区块链节点的编译过程而造成延误,具体的,第一区块链节点可以直接执行所述智能合约中对应所调用的函数/代码块的机器码,并输入前述data字段指明的输入参数。在存储有智能合约的机器码的情况下,由于机器码本身即是CPU(在OS的控制下)可以直接执行的,因此,第一区块链节点可以大幅提升执行智能合约的速度。并且,所述智能合约的机器码缓存在内存中的情形,可以更进一步的提升智能合约的执行速度。当然,即使存储在磁盘中,也可以一定程度上提升执行速度。第一区块链节点执行所述机器码,具体可以是执行存储的所述智能合约中对应所调用函数和/或代码块的机器码。
而第二区块链节点可以不必等待JIT编译的完成,而在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对部署的所述智能合约的字节码进行解释执行。机器码与字节码的执行结果一致可以包括下述维度中的一项或多项:返回的合约执行结果一致、形成的合约存储一致、消耗的区块链资产一致等。为了确保机器码与字节码的执行结果一致,可以预先在至少一种验证场景下分别对智能合约的机器码和字节码进行测试,如果测试结果均一致,则表明机器码与字节码的执行结果一致,否则表明执行结果不一致。还可以对所述机器码与所述字节码进行形式化验证(Formal Verification),验证结果一致表明所述机器码与所述字节码的执行结果一致,否则表明执行结果不一致。可以同时结合上述多种验证方式,从而在所有验证方式得到的验证结果均为一致的情况下,确定机器码与字节码的执行结果一致。
为了及时对业务请求作出响应,即快速响应发起调用部署的智能合约的业务请求,第二区块链节点在本地没有机器码时,还查询可以当前对所述智能合约的字节码的JIT编译情况,具体可能包括两种情况:
情况一:第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果正处于JIT编译中,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行。
如果本地没有存储所述智能合约的机器码,第二区块链节点可以查询当前对所述智能合约的字节码的JIT编译情况,查询结果可以是正处于JIT编译中。对于一些调用所述智能合约的业务请求来说,得到快速的响应是首选,这也是各类区块链系统设法提升每秒交易处理数量(Transaction Per Second,TPS)的目标。对于被调用的智能合约正处于JIT中的情况,为了快速响应,第二区块链节点可以不等待JIT编译结束,而是对所述智能合约的字节码进行解释执行。
情况二:第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并对所述智能合约的字节码进行解释执行。
类似于情况一,对于被调用的智能合约尚未启动JIT的情况,为了快速响应,第二区块链节点可以对所述智能合约的字节码进行解释执行。并且,对于尚未启动JIT的情况,第二区块链节点可以启动JIT编译。
第二区块链节点对所述智能合约的字节码进行解释执行,可以是采用EVM对所述智能合约的字节码进行逐句翻译,并对翻译后机器码进行逐条执行。除了EVM,还可以是WASM(Web Assembly)虚拟机、JSVM(JavaScript Virtual Machine)等,这里主要以EVM作为例子加以说明。
与第一区块链相类似的,第二区块链节点对所述智能合约完成JIT编译后,将所述编译后的机器码执行所述存储操作,这样,下次执行部署的所述智能合约时,由于本地存在该被调用的合约的经JIT编译后得到的机器码,即说明本地已经完成对该智能合约的字节码的JIT编译,因而同一区块链节点由第二区块链节点变为第一区块链节点。进而,该区块链节点可以直接执行所述智能合约中对应所调用的函数的经过JIT编译得到的机器码,并输入前述data字段指明的输入参数。
需要说明的是,上述S611中的第一区块链节点,可能不同于S613和S615a中的第一区块链节点;类似地,上述S611中的第二区块链节点,可能不同于S613和S615b中的第二区块链节点。这是因为,区块链作为分布式的系统,接收交易的节点和发起共识的节点以及执行交易的节点可以是不同的节点,当然也可以是相同的节点。
以下结合图6-2介绍本说明书另一执行智能合约的方法实施例,包括:
S621:第一区块链节点、第二区块链节点分别在部署所述智能合约的字节码后,开始将所述智能合约的字节码通过JIT编译为机器码并存储。
第一区块链节点、第二区块链节点分别在部署所述智能合约的字节码后,开始将所述智能合约的字节码通过JIT编译为机器码,具体可以包括:
第一区块链节点、第二区块链节点分别在完成创建所述智能合约后,立即开始对所述智能合约的字节码进行JIT编译;或,
第一区块链节点、第二区块链节点分别在完成创建所述智能合约后,利用相对空闲的时间段对所述智能合约的字节码进行JIT编译;或,
第一区块链节点、第二区块链节点分别在接收到调用所述创建的智能合约的交易请求后,对所述智能合约的字节码进行JIT编译。
所述将所述智能合约的字节码通过JIT编译为机器码并存储,包括:
对所述智能合约的字节码进行翻译和/或执行的过程中识别热点字节码进行编译并存储;
和/或,
对所述智能合约的字节码进行翻译和/或执行的过程中进行优化编译并存储。
所述识别热点字节码的粒度包括函数级别或代码块级别。
S623a:第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码。
第一区块链节点执行所述机器码,可以是执行存储的所述智能合约中对应所调用函数和/或代码块的机器码。
上述存储的具体方式可以为缓存。通过缓存到内存,后续可以更快速的作出响应。当然,即使存储到磁盘,很多情形下也可以一定程度的提升响应速度。
S623b:第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
第二区块链节点对所述智能合约的字节码进行解释执行,可以包括:
第二区块链节点对所述智能合约中对应所调用函数的字节码进行解释执行。
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行,具体可以包括:
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果正处于JIT编译中,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行;
或,
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行。
所述机器码与所述字节码的执行结果一致,包括下述至少之一:返回的合约执行结果一致、形成的合约存储一致、消耗的区块链资产一致。
验证所述机器码与所述字节码的执行结果是否一致,包括:
比较所述机器码与所述字节码在至少一种验证场景下的测试结果,测试结果一致表明所述机器码与所述字节码的执行结果一致;和/或,
对所述机器码与所述字节码进行形式化验证,验证结果一致表明所述机器码与所述字节码的执行结果一致。
以下介绍本说明书一种执行智能合约的区块链节点实施例,如图7所示,包括:
接收单元71,用于接收创建智能合约的请求,所述请求中包括所述智能合约的字节码;
部署单元72,用于根据接收单元71接收到的创建智能合约的请求部署所述智能合约;
编译单元73,用于所述部署单元72完成部署后,开始将所述智能合约的字节码通过JIT编译为机器码;
存储单元74,用于存储编译单元73编译的机器码;
执行单元75,接收到调用部署的所述智能合约时,如果存储单元74存储有所述智能合约的机器码,则执行所述机器码,如果存储单元74没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行。
所述部署单元72完成所述智能合约的部署后,编译单元73开始将所述智能合约的字节码通过JIT编译为机器码,包括:
所述部署单元72完成创建所述智能合约后,编译单元73立即开始对所述智能合约的字节码进行JIT编译;或,
部署单元72完成创建所述智能合约后,编译单元73利用相对空闲的时间段对所述智能合约的字节码进行JIT编译;或,
执行单元75接收到调用所述创建的智能合约的交易请求后,编译单元73对所述智能合约的字节码进行JIT编译。
所述存储单元74可以为内存或磁盘存储。
所述执行单元75执行所述机器码,包括:所述执行单元75执行存储的所述智能合约中对应所调用函数和/或代码块的机器码。
所述执行单元75对所述智能合约的字节码进行解释执行,包括:
所述执行单元75对所述智能合约中对应所调用函数的字节码进行解释执行。
所述执行单元75执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,执行单元75对所述智能合约的字节码进行解释执行,包括:
所述执行单元75执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,所述执行单元75还查询当前对所述智能合约的字节码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的字节码进行解释执行;
或,
所述执行单元75执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,所述执行单元75还查询当前对所述智能合约的字节码的JIT编译情况,如果尚未开始AoT编译,则启动JIT编译,并对所述智能合约的字节码进行解释执行。
执行单元75确定所述机器码与所述字节码的执行结果一致,包括下述至少之一:返回的合约执行结果一致、形成的合约存储一致、消耗的区块链资产一致。
其中,验证所述机器码与所述字节码的执行结果是否一致,包括:
比较所述机器码与所述字节码在至少一种验证场景下的测试结果,测试结果一致表明所述机器码与所述字节码的执行结果一致;和/或,
对所述机器码与所述字节码进行形式化验证,验证结果一致表明所述机器码与所述字节码的执行结果一致。
此外,执行智能合约的区块链节点,也可以执行上述S621至S625b的方法。
本说明书还提供一种区块链节点实施例,包括:
处理器,
存储器,存储有程序,其中在所述处理器执行所述程序时,按照前述的方式执行智能合约。
本说明书还提供一种存储介质实施例,用于存储程序,其中所述程序在被执行时,执行前述方法。
本说明书还提供一种区块链系统实施例,包括:第一区块链节点和第二区块链节点;
第一区块链节点包括:
第一接收单元,用于接收创建智能合约的请求,所述请求中包括所述智能合约的字节码;
第一部署单元,用于根据第一接收单元接收到的创建智能合约的请求部署所述智能合约;
第一编译单元,用于所述第一部署单元完成部署后,开始将所述智能合约的字节码通过JIT编译为机器码;
第一存储单元,用于存储第一编译单元编译的机器码;
第一执行单元,接收到调用部署的所述智能合约时,如果存储单元存储有所述智能合约的机器码,则执行所述机器码;
第二区块链节点包括:
第二接收单元,用于接收创建智能合约的请求,所述请求中包括所述智能合约的字节码;
第二部署单元,用于根据第二接收单元接收到的创建智能合约的请求部署所述智能合约;
第二编译单元,用于所述第二部署单元完成部署后,开始将所述智能合约的字节码通过JIT编译为机器码;
第二存储单元,用于存储第二编译单元编译的机器码;
第二执行单元,接收到调用部署的所述智能合约时,如果第二存储单元没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行。
第一部署单元或第二部署单元完成所述智能合约的部署后,第一编译单元或第二编译单元开始将所述智能合约的字节码通过JIT编译为机器码,包括:
第一部署单元或第二部署单元完成创建所述智能合约后,第一编译单元或第二编译单元立即开始对所述智能合约的字节码进行JIT编译;或,
第一部署单元或第二部署单元完成创建所述智能合约后,第一编译单元或第二编译单元利用相对空闲的时间段对所述智能合约的字节码进行JIT编译;或,
第一执行单元或第二执行单元接收到调用所述创建的智能合约的交易请求后,第一编译单元或第二编译单元对所述智能合约的字节码进行JIT编译。
第一存储单元和/或第二存储单元可以为内存或磁盘存储。
第一执行单元执行所述机器码,包括:第一执行单元执行存储的所述智能合约中对应所调用函数和/或代码块的机器码。
第二执行单元对所述智能合约的字节码进行解释执行,包括:
第二执行单元对所述智能合约中对应所调用函数的字节码进行解释执行。
第二执行单元执行部署的所述智能合约时,如果第二存储单元没有存储所述智能合约的机器码,第二执行单元在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行,包括:
第二执行单元执行部署的所述智能合约时,如果第二存储单元没有存储所述智能合约的机器码,第二执行单元还查询当前对所述智能合约的字节码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的字节码进行解释执行;
或,
第二执行单元执行部署的所述智能合约时,如果第二存储单元没有存储所述智能合约的机器码,第二执行单元还查询当前对所述智能合约的字节码的JIT编译情况,如果尚未开始AoT编译,则启动JIT编译,并对所述智能合约的字节码进行解释执行。
第二执行单元确定所述机器码与所述字节码的执行结果一致,包括下述至少之一:返回的合约执行结果一致、形成的合约存储一致、消耗的区块链资产一致。
其中,验证所述机器码与所述字节码的执行结果是否一致,包括:
比较所述机器码与所述字节码在至少一种验证场景下的测试结果,测试结果一致表明所述机器码与所述字节码的执行结果一致;和/或,
对所述机器码与所述字节码进行形式化验证,验证结果一致表明所述机器码与所述字节码的执行结果一致。
此外,执行智能合约的区块链节点,也可以执行上述S621至S623的方法。
本说明书还提供一种存储介质实施例,用于存储程序,其中所述程序在被执行时,执行前述方法。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为计算机,计算机的具体形式可以是个人计算机、膝上型计算机、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件收发设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任意几种设备的组合。
在一个典型的配置中,计算机包括一个或多个处理器 (CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器 (RAM) 和/或非易失性内存等形式,如只读存储器 (ROM) 或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存 (PRAM)、静态随机存取存储器 (SRAM)、动态随机存取存储器 (DRAM)、其他类型的随机存取存储器 (RAM)、只读存储器 (ROM)、电可擦除可编程只读存储器 (EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘 (DVD) 或其他光学存储、磁盒式磁带、磁盘存储、量子存储器、基于石墨烯的存储介质或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
上述对本说明书特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作或步骤可以按照不同于实施例中的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序才能实现期望的结果。在某些实施方式中,多任务处理和并行处理也是可以的或者可能是有利的。
在本说明书一个或多个实施例使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本说明书一个或多个实施例。在本说明书一个或多个实施例和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包含一个或多个相关联的列出项目的任何或所有可能组合。
应当理解,尽管在本说明书一个或多个实施例可能采用术语第一、第二、第三等来描述各种信息,但这些信息不应限于这些术语。这些术语仅用来将同一类型的信息彼此区分开。例如,在不脱离本说明书一个或多个实施例范围的情况下,第一信息也可以被称为第二信息,类似地,第二信息也可以被称为第一信息。取决于语境,如在此所使用的词语“如果”可以被解释成为“在……时”或“当……时”或“响应于确定”。
以上所述仅为本说明书一个或多个实施例的较佳实施例而已,并不用以限制本说明书一个或多个实施例,凡在本说明书一个或多个实施例的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本说明书一个或多个实施例保护的范围之内。
Claims (25)
1.一种执行智能合约的方法,包括:
第一区块链节点、第二区块链节点分别接收创建智能合约的请求,所述请求中包括所述智能合约的字节码;
第一区块链节点、第二区块链节点分别在完成所述智能合约的部署后,开始将所述智能合约的字节码通过JIT编译为机器码并存储;
第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码;
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
2.如权利要求1所述的方法,第一区块链节点、第二区块链节点分别在完成所述智能合约的部署后,开始将所述智能合约的字节码通过JIT编译为机器码,包括:
第一区块链节点、第二区块链节点分别在完成创建所述智能合约后开始对所述智能合约的字节码进行JIT编译;或,
第一区块链节点、第二区块链节点分别在完成创建所述智能合约后,利用相对空闲的时间段对所述智能合约的字节码进行JIT编译;或,
第一区块链节点、第二区块链节点分别在接收到调用所述创建的智能合约的交易请求后,对所述智能合约的字节码进行JIT编译。
3.如权利要求1所述的方法,所述将所述智能合约的字节码通过JIT编译为机器码并存储,包括:
对所述智能合约的字节码进行翻译和/或执行的过程中识别热点字节码进行编译并存储;
和/或,
对所述智能合约的字节码进行翻译和/或执行的过程中进行优化编译并存储。
4.如权利要求3所述的方法,所述识别热点字节码的粒度包括函数级别或代码块级别。
5.如权利要求1所述的方法,第一区块链节点执行所述机器码,包括:
第一区块链节点执行存储的所述智能合约中对应于所调用函数和/或代码块的机器码。
6.如权利要求1所述的方法,第二区块链节点对所述智能合约的字节码进行解释执行,包括:
第二区块链节点对所述智能合约中对应于所调用函数的字节码进行解释执行。
7.如权利要求1所述的方法,第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行,包括:
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果正处于JIT编译中,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行;
或,
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行。
8.如权利要求1所述的方法,所述机器码与所述字节码的执行结果一致,包括下述至少之一:返回的合约执行结果一致、形成的合约存储一致、消耗的区块链资产一致。
9.如权利要求1所述的方法,验证所述机器码与所述字节码的执行结果是否一致,包括:
比较所述机器码与所述字节码在至少一种验证场景下的测试结果,测试结果一致表明所述机器码与所述字节码的执行结果一致;和/或,
对所述机器码与所述字节码进行形式化验证,验证结果一致表明所述机器码与所述字节码的执行结果一致。
10.如权利要求1-9中任一项所述的方法,所述存储为缓存。
11.一种执行智能合约的方法,包括:
第一区块链节点、第二区块链节点分别在部署所述智能合约的字节码后,开始将所述智能合约的字节码通过JIT编译为机器码并存储;
第一区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的机器码,则执行所述机器码;
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行。
12.如权利要求11所述的方法,第一区块链节点、第二区块链节点分别在部署所述智能合约的字节码后,开始将所述智能合约的字节码通过JIT编译为机器码,包括:
第一区块链节点、第二区块链节点分别在完成创建所述智能合约后开始对所述智能合约的字节码进行JIT编译;或,
第一区块链节点、第二区块链节点分别在完成创建所述智能合约后,利用相对空闲的时间段对所述智能合约的字节码进行JIT编译;或,
第一区块链节点、第二区块链节点分别在接收到调用所述创建的智能合约的交易请求后,对所述智能合约的字节码进行JIT编译。
13.如权利要求11所述的方法,所述将所述智能合约的字节码通过JIT编译为机器码并存储,包括:
对所述智能合约的字节码进行翻译和/或执行的过程中识别热点字节码进行编译并存储;
和/或,
对所述智能合约的字节码进行翻译和/或执行的过程中进行优化编译并存储。
14.如权利要求13所述的方法,所述识别热点字节码的粒度包括函数级别或代码块级别。
15.如权利要求11所述的方法,第一区块链节点执行所述机器码,包括:
第一区块链节点执行存储的所述智能合约中对应于所调用函数和/或代码块的机器码。
16.如权利要求11所述的方法,第二区块链节点对所述智能合约的字节码进行解释执行,包括:
第二区块链节点对所述智能合约中对应于所调用函数的字节码进行解释执行。
17.如权利要求16所述的方法,第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述字节码进行解释执行,包括:
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果正处于JIT编译中,则在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行;
或,
第二区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,第二区块链节点还查询当前对所述智能合约的字节码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并在确定所述机器码与所述智能合约的字节码的执行结果一致的情况下对所述智能合约的字节码进行解释执行。
18.如权利要求11所述的方法,所述机器码与所述字节码的执行结果一致,包括下述至少之一:返回的合约执行结果一致、形成的合约存储一致、消耗的区块链资产一致。
19.如权利要求11所述的方法,验证所述机器码与所述字节码的执行结果是否一致,包括:
比较所述机器码与所述字节码在至少一种验证场景下的测试结果,测试结果一致表明所述机器码与所述字节码的执行结果一致;和/或,
对所述机器码与所述字节码进行形式化验证,验证结果一致表明所述机器码与所述字节码的执行结果一致。
20.如权利要求11-19中任一项所述的方法,所述存储为缓存。
21.一种执行智能合约的区块链系统,包括第一区块链节点和第二区块链节点,第一区块链节点执行上述权利要求1-10或11-20中任一项所述的方法中由第一区块链节点执行的操作,第二区块链节点执行上述权利要求1-10或11-20中任一项所述的方法中由第二区块链节点执行的操作。
22.一种执行智能合约的区块链系统,包括:
第一区块链节点,包括处理器和存储器;存储器内存储有程序,其中在所述处理器执行所述程序时,执行上述权利要求1-10或11-20中任一项所述的方法中由第一区块链节点执行的操作;
第二区块链节点,包括处理器和存储器;存储器内存储有程序,其中在所述处理器执行所述程序时,执行上述权利要求1-10或11-20中任一项所述的方法中由第二区块链节点执行的操作。
23.一种执行智能合约的区块链节点,执行上述权利要求1-10或11-20中任一项所述的方法中由第一区块链节点和/或第二区块链节点执行的操作。
24.一种执行智能合约的区块链节点,包括:
处理器,
存储器,存储有程序,其中在所述处理器执行所述程序时,执行上述权利要求1-10或11-20中任一项所述的方法中由第一区块链节点和/或第二区块链节点执行的操作。
25.一种存储介质,用于存储程序,其中所述程序在被执行时进行上述权利要求1-10或11-20中任一项的操作。
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110099206.4A CN112866392B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
CN202010901436.3A CN111770205B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
US17/362,921 US11416272B2 (en) | 2020-08-31 | 2021-06-29 | Methods, blockchain nodes, systems and storage media for executing smart contract |
EP21182628.4A EP3961976B1 (en) | 2020-08-31 | 2021-06-30 | Methods, blockchain nodes, systems and storage media for executing smart contract |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010901436.3A CN111770205B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110099206.4A Division CN112866392B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111770205A true CN111770205A (zh) | 2020-10-13 |
CN111770205B CN111770205B (zh) | 2020-12-04 |
Family
ID=72729195
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010901436.3A Active CN111770205B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
CN202110099206.4A Active CN112866392B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110099206.4A Active CN112866392B (zh) | 2020-08-31 | 2020-08-31 | 一种执行智能合约的方法、区块链节点、系统和存储介质 |
Country Status (3)
Country | Link |
---|---|
US (1) | US11416272B2 (zh) |
EP (1) | EP3961976B1 (zh) |
CN (2) | CN111770205B (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112363804A (zh) * | 2020-11-16 | 2021-02-12 | 杭州复杂美科技有限公司 | 区块链jvm应用方法、设备和存储介质 |
CN113220327A (zh) * | 2021-05-11 | 2021-08-06 | 支付宝(杭州)信息技术有限公司 | 智能合约升级方法及区块链系统 |
CN113220326A (zh) * | 2021-05-11 | 2021-08-06 | 支付宝(杭州)信息技术有限公司 | 智能合约升级方法及区块链系统 |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113688186B (zh) * | 2021-08-25 | 2022-11-22 | 工银科技有限公司 | 智能合约执行方法、引擎及区块链节点 |
CN114297119A (zh) * | 2021-12-30 | 2022-04-08 | 北京百度网讯科技有限公司 | 智能合约执行方法、装置、设备以及存储介质 |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108536514A (zh) * | 2017-03-01 | 2018-09-14 | 龙芯中科技术有限公司 | 一种热点方法的识别方法和装置 |
US20190065709A1 (en) * | 2017-08-24 | 2019-02-28 | Oracle International Corporation | Digital asset traceability and assurance using a distributed ledger |
CN110032883A (zh) * | 2019-01-31 | 2019-07-19 | 阿里巴巴集团控股有限公司 | 区块链中实现隐私保护的方法、系统和节点 |
CN110688122A (zh) * | 2019-09-30 | 2020-01-14 | 支付宝(杭州)信息技术有限公司 | 编译和执行智能合约的方法及装置 |
CN110704064A (zh) * | 2019-09-30 | 2020-01-17 | 支付宝(杭州)信息技术有限公司 | 编译和执行智能合约的方法及装置 |
CN110704063A (zh) * | 2019-09-30 | 2020-01-17 | 支付宝(杭州)信息技术有限公司 | 编译和执行智能合约的方法及装置 |
CN111033544A (zh) * | 2017-08-15 | 2020-04-17 | 区块链控股有限公司 | 用于区块链实现的基于脚本的字节解释的方法和系统 |
CN111399990A (zh) * | 2020-05-29 | 2020-07-10 | 支付宝(杭州)信息技术有限公司 | 解释执行智能合约指令的方法及装置 |
CN111538521A (zh) * | 2020-04-24 | 2020-08-14 | 中国工商银行股份有限公司 | 智能合约部署、交易方法及装置 |
Family Cites Families (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4713820B2 (ja) * | 2003-05-28 | 2011-06-29 | パナソニック株式会社 | プログラム実行制御装置、プログラム実行制御方法 |
US8543907B1 (en) * | 2009-10-16 | 2013-09-24 | Google Inc. | Context-sensitive optimization level selection |
CN106484375B (zh) * | 2015-08-26 | 2020-02-14 | 华为技术有限公司 | 一种指令块加载方法、软交换设备及系统 |
US9849364B2 (en) * | 2016-02-02 | 2017-12-26 | Bao Tran | Smart device |
US11017469B2 (en) * | 2016-08-04 | 2021-05-25 | Clarovia Holdings, Llc | System and method for manufacturing and trading securities and commodities |
US10616324B1 (en) * | 2017-07-20 | 2020-04-07 | Architecture Technology Corporation | Decentralized ledger system and method for enterprises |
US20190058709A1 (en) * | 2017-08-16 | 2019-02-21 | Telefonaktiebolaget Lm Ericsson (Publ) | Tenant management method and system in a cloud computing environment |
GB201720767D0 (en) * | 2017-12-13 | 2018-01-24 | Barker Trevor | Computer-implemented system and method |
CN108764870B (zh) * | 2018-05-29 | 2020-07-07 | 阿里巴巴集团控股有限公司 | 基于区块链的交易处理方法及装置、电子设备 |
CN110033368B (zh) * | 2018-11-30 | 2020-07-07 | 阿里巴巴集团控股有限公司 | 区块链中实现隐私保护的方法 |
CN110060111A (zh) * | 2018-12-12 | 2019-07-26 | 阿里巴巴集团控股有限公司 | 基于区块链的发票访问方法和装置、电子设备 |
JP6856749B2 (ja) * | 2018-12-29 | 2021-04-14 | アドバンスド ニュー テクノロジーズ カンパニー リミテッド | ブロックチェーン上のネイティブ契約を実施するためのシステムおよび方法 |
US10838750B2 (en) * | 2019-01-10 | 2020-11-17 | Red Hat, Inc. | Combining ahead-of-time compilation and just-in-time compilation to improve application deployment |
US11138600B2 (en) * | 2019-02-05 | 2021-10-05 | Capital One Services, Llc | Smart contract regulation |
CN110096338B (zh) | 2019-05-10 | 2021-12-14 | 百度在线网络技术(北京)有限公司 | 智能合约执行方法、装置、设备及介质 |
US10839107B2 (en) * | 2019-05-30 | 2020-11-17 | Advanced New Technologies Co., Ltd. | Managing a smart contract on a blockchain |
US10783082B2 (en) | 2019-08-30 | 2020-09-22 | Alibaba Group Holding Limited | Deploying a smart contract |
CN111061484B (zh) | 2019-11-28 | 2023-05-02 | Oppo广东移动通信有限公司 | 代码编译方法、装置、服务器、用户终端及可读介质 |
CN112100054B (zh) * | 2020-08-12 | 2021-07-20 | 北京大学 | 一种面向数据管控的程序静态分析方法和系统 |
-
2020
- 2020-08-31 CN CN202010901436.3A patent/CN111770205B/zh active Active
- 2020-08-31 CN CN202110099206.4A patent/CN112866392B/zh active Active
-
2021
- 2021-06-29 US US17/362,921 patent/US11416272B2/en active Active
- 2021-06-30 EP EP21182628.4A patent/EP3961976B1/en active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108536514A (zh) * | 2017-03-01 | 2018-09-14 | 龙芯中科技术有限公司 | 一种热点方法的识别方法和装置 |
CN111033544A (zh) * | 2017-08-15 | 2020-04-17 | 区块链控股有限公司 | 用于区块链实现的基于脚本的字节解释的方法和系统 |
US20190065709A1 (en) * | 2017-08-24 | 2019-02-28 | Oracle International Corporation | Digital asset traceability and assurance using a distributed ledger |
CN110032883A (zh) * | 2019-01-31 | 2019-07-19 | 阿里巴巴集团控股有限公司 | 区块链中实现隐私保护的方法、系统和节点 |
CN110688122A (zh) * | 2019-09-30 | 2020-01-14 | 支付宝(杭州)信息技术有限公司 | 编译和执行智能合约的方法及装置 |
CN110704064A (zh) * | 2019-09-30 | 2020-01-17 | 支付宝(杭州)信息技术有限公司 | 编译和执行智能合约的方法及装置 |
CN110704063A (zh) * | 2019-09-30 | 2020-01-17 | 支付宝(杭州)信息技术有限公司 | 编译和执行智能合约的方法及装置 |
CN111538521A (zh) * | 2020-04-24 | 2020-08-14 | 中国工商银行股份有限公司 | 智能合约部署、交易方法及装置 |
CN111399990A (zh) * | 2020-05-29 | 2020-07-10 | 支付宝(杭州)信息技术有限公司 | 解释执行智能合约指令的方法及装置 |
Non-Patent Citations (1)
Title |
---|
范锦锋: "智能合约和预言机初探 ", 《信息通信技术与政策》 * |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112363804A (zh) * | 2020-11-16 | 2021-02-12 | 杭州复杂美科技有限公司 | 区块链jvm应用方法、设备和存储介质 |
CN112363804B (zh) * | 2020-11-16 | 2024-01-26 | 北京差旅天下网络科技有限责任公司 | 区块链jvm应用方法、设备和存储介质 |
CN113220327A (zh) * | 2021-05-11 | 2021-08-06 | 支付宝(杭州)信息技术有限公司 | 智能合约升级方法及区块链系统 |
CN113220326A (zh) * | 2021-05-11 | 2021-08-06 | 支付宝(杭州)信息技术有限公司 | 智能合约升级方法及区块链系统 |
Also Published As
Publication number | Publication date |
---|---|
CN112866392B (zh) | 2023-06-30 |
US20210326158A1 (en) | 2021-10-21 |
CN112866392A (zh) | 2021-05-28 |
EP3961976A1 (en) | 2022-03-02 |
US11416272B2 (en) | 2022-08-16 |
CN111770205B (zh) | 2020-12-04 |
EP3961976B1 (en) | 2023-12-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111770113B (zh) | 一种执行智能合约的方法、区块链节点和节点设备 | |
CN111814202B (zh) | 一种执行智能合约的方法、区块链节点和存储介质 | |
CN111770205B (zh) | 一种执行智能合约的方法、区块链节点、系统和存储介质 | |
CN111770206B (zh) | 一种部署智能合约的方法、区块链节点和存储介质 | |
CN111815310B (zh) | 一种执行智能合约的方法、区块链节点和存储介质 | |
CN111770116B (zh) | 一种执行智能合约的方法、区块链节点、存储介质 | |
CN111770204B (zh) | 一种执行智能合约的方法、区块链节点和存储介质 | |
CN111768187A (zh) | 一种部署智能合约的方法、区块链节点和存储介质 | |
CN111815330A (zh) | 一种部署智能合约的方法、区块链节点和存储介质 | |
CN111768200A (zh) | 一种部署智能合约的方法、区块链节点和存储介质 | |
CN111768184A (zh) | 一种执行智能合约的方法及区块链节点 | |
EP3961438B1 (en) | Method for executing smart contract, blockchain node, and storage medium | |
WO2022237590A1 (zh) | 智能合约升级方法及区块链系统 | |
CN111770202B (zh) | 一种执行智能合约的方法、区块链节点和存储介质 | |
CN113220327B (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 | ||
REG | Reference to a national code |
Ref country code: HK Ref legal event code: DE Ref document number: 40039052 Country of ref document: HK |