CN111770113A - 一种执行智能合约的方法、区块链节点和节点设备 - Google Patents

一种执行智能合约的方法、区块链节点和节点设备 Download PDF

Info

Publication number
CN111770113A
CN111770113A CN202010899216.1A CN202010899216A CN111770113A CN 111770113 A CN111770113 A CN 111770113A CN 202010899216 A CN202010899216 A CN 202010899216A CN 111770113 A CN111770113 A CN 111770113A
Authority
CN
China
Prior art keywords
code
intelligent contract
hot spot
compiling
block chain
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
Application number
CN202010899216.1A
Other languages
English (en)
Other versions
CN111770113B (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.)
Alipay Hangzhou Information Technology Co Ltd
Original Assignee
Alipay Hangzhou 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 Alipay Hangzhou Information Technology Co Ltd filed Critical Alipay Hangzhou Information Technology Co Ltd
Priority to CN202111095262.7A priority Critical patent/CN113872948A/zh
Priority to CN202010899216.1A priority patent/CN111770113B/zh
Publication of CN111770113A publication Critical patent/CN111770113A/zh
Priority to US17/358,126 priority patent/US11366677B2/en
Priority to EP21182397.6A priority patent/EP3961376B1/en
Application granted granted Critical
Publication of CN111770113B publication Critical patent/CN111770113B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
    • G06F9/45516Runtime code conversion or optimisation
    • G06F9/4552Involving translation to a different instruction set architecture, e.g. just-in-time translation in a JVM
    • 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/133Protocols for remote procedure calls [RPC]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • G06F8/44Encoding
    • G06F8/443Optimisation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44589Program code verification, e.g. Java bytecode verification, proof-carrying code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
    • G06F9/45508Runtime interpretation or emulation, e g. emulator loops, bytecode interpretation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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/00Payment architectures, schemes or protocols
    • G06Q20/04Payment circuits
    • G06Q20/06Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme
    • G06Q20/065Private payment circuits, e.g. involving electronic currency used among participants of a common payment scheme using e-cash
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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/00Payment architectures, schemes or protocols
    • G06Q20/38Payment protocols; Details thereof
    • G06Q20/382Payment protocols; Details thereof insuring higher security of transaction
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION 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/00Finance; Insurance; Tax strategies; Processing of corporate or income taxes
    • G06Q40/04Trading; Exchange, e.g. stocks, commodities, derivatives or currency exchange
    • 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/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • 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/32Cryptographic 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/3236Cryptographic 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/3239Cryptographic 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
    • 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

Abstract

本说明书提供一种执行智能合约的方法、区块链节点和节点设备。一种执行智能合约的方法实施例包括:区块链节点接收创建智能合约的请求,所述请求中包括所述智能合约的代码,所述智能合约的代码中包括通过热点标识符标明的热点代码;所述区块链节点完成所述智能合约的部署后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码;所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。通过上述本说明书的实施例,所述区块链节点可以大幅提升执行智能合约的速度。

Description

一种执行智能合约的方法、区块链节点和节点设备
技术领域
本说明书实施例属于区块链技术领域,尤其涉及一种执行智能合约的方法、区块链节点和节点设备。
背景技术
区块链(Blockchain)是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链2.0时代中出现了智能合约,将区块链的应用范围提升到了一个新高度。有了智能合约,区块链能做不再是单一的转账交易,而是还可以调用一段代码,而这段代码可以由用户自定义。
发明内容
本说明书在于提供一种执行智能合约的方法、区块链节点和节点设备。
本说明书实施例提供的一种执行智能合约的方法、区块链节点和节点设备,通过以下方式实现:
一种执行智能合约的方法,包括:
区块链节点接收创建智能合约的请求,所述请求中包括所述智能合约的代码,所述智能合约的代码中包括通过热点标识符标明的热点代码;
所述区块链节点完成所述智能合约的部署后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码;
所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。
一种执行智能合约的方法,所述智能合约的代码中包括通过热点标识符标明的热点代码,所述方法包括:
区块链节点部署所述智能合约的代码后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码;
所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。
一种执行智能合约的区块链节点,执行上述的方法。
一种执行智能合约的区块链节点,包括:
处理器,
存储器,存储有程序,其中在所述处理器执行所述程序时,执行上述的方法。
一种存储介质,用于存储程序,其中所述程序在被执行时进行上述方法的操作。
通过上述本说明书的实施例,在区块链节点存储有智能合约的机器码的情况下,由于机器码本身即是CPU可以直接执行的,因此,所述区块链节点可以大幅提升执行智能合约的速度。通过在智能合约的代码中包含采用热点标识符标明的热点代码,使得该热点代码必然会被区块链节点进行JIT编译为机器码并存储,从而灵活地针对智能合约的代码进行JIT编译。
附图说明
为了更清楚地说明本说明书实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本说明书中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是一实施例中编译执行和解释执行的原理示意图;
图2是一实施例中解释执行和JIT编译的原理示意图;
图3为一个实施例的创建智能合约的图示过程;
图4为一个实施例的调用智能合约的图示过程;
图5为一个实施例中创建智能合约和调用智能合约的示意图;
图6-1是一实施例中的执行智能合约的流程图;
图6-2是另一实施例中的执行智能合约的流程图;
图7是一实施例中的区块链节点的模块结构图;
图8是一实施例中的创建智能合约和调用智能合约的示意图;
图9为一实施例中的创建智能合约和调用智能合约过程中包含虚拟机执行过程的示意图。
具体实施方式
为了使本技术领域的人员更好地理解本说明书中的技术方案,下面将结合本说明书实施例中的附图,对本说明书实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本说明书保护的范围。
区块链1.0时代通常是指在2009年到2014年之间,以比特币为代表的区块链应用发展阶段,它们主要致力于解决货币和支付手段的去中心化问题。从2014年开始,开发者们越来越注重于解决比特币在技术和扩展性方面的不足。2013年底,VitalikButerin发布了以太坊白皮书《以太坊:下一代智能合约和去中心化应用平台》,将智能合约引入区块链,打开了区块链在货币领域以外的应用,从而开启了区块链2.0时代。
智能合约是一种基于规定触发规则的,可自动执行的计算机合约,也可以看作是传统合约的数字版本。智能合约这一概念最早由跨领域法律学者、密码学研究工作者尼克·萨博(NickSzabo)在1994年提出。这项技术曾一度因为缺乏可编程数字系统和相关技术而没有被用于实际产业中,直到区块链技术和以太坊的出现为其提供了可靠的执行环境。由于区块链技术采用的块链式账本,产生的数据不可篡改或者删除,且整个账本将不断新增账本数据,从而保证了历史数据的可追溯;同时,去中心化的运行机制避免了中心化因素的影响。基于区块链技术的智能合约不仅可以发挥智能合约在成本、效率方面的优势,而且可以避免恶意行为对合约正常执行的干扰。将智能合约以数字化的形式写入区块链中,由区块链技术的特性保障存储、读取、执行整个过程透明可跟踪、不可篡改。
智能合约本质上是一段可由计算机执行的程序。智能合约与现在广泛使用的计算机程序一样,可以通过高级语言(例如C语言、C++语言等)编写而成。由高级语言编写好的智能合约的程序代码,一般可以通过“编译器”转换为计算机的CPU可以识别和运行的“机器码”,进而可以由CPU执行这样的机器码(或者称为“微处理器指令”)。这种方式一般称为“编译执行”。
编译执行一般不具有跨平台的可扩展性。由于存在不同厂商、不同品牌和不同代的CPU,而这些不同的CPU支持的指令集很多情况下是不同的,如x86指令集,ARM指令集等,且同一厂商同一品牌但不同代的CPU(如不同代的IntelCPU)支持的指令集也不完全相同,因此,用同样的高级语言编写的同样的程序代码,在不同CPU上被编译器转换出来的机器码可能不同。具体的,编译器在转换高级语言编写的程序代码到机器码的过程中,会结合具体的CPU指令集的特点(如向量指令集等)进行优化以提升程序执行的速度,而此类优化往往与具体的CPU硬件相关。这样,同样的机器码,一个在x86上可以运行,但另一个在ARM上就可能无法运行;甚至同样是x86平台,随着时间的推移,指令集也不断丰富和扩展,这就导致不同代的x86平台运行的机器码也有不同。相同硬件平台的机器码能够相互兼容,但是由于运行在操作系统上的程序(如机器码)需要依赖操作系统的基础库,而不同操作系统的基础库可能存在差异(比如基础库的版本不同等),可能造成程序的可执行文件与基础库的二进制接口不兼容而导致该程序无法运行或运行崩溃,因而此时需要根据操作系统的差异对机器码进行调整,从而造成同样硬件但不同操作系统的情况下,支持运行的机器码可能不同。
不同于编译执行,还存在一种“解释执行”的程序运行方式。比如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在操作系统(OperatingSystem,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方式在应用安装时就预编译字节码(AndroidApp的安装过程实际上是安装程序的字节码)到机器码。在移除解释代码这一过程后,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:
ContractExample{
int balance;
function C( ){
balance+ = 1;
}
functiongetbalance( ) returns(int){
return balance ;
}
}
一般的,这个合约部署在区块链后,“balance”这个状态变量可以是在合约中新定义的一种资产类型。functionC()这个函数可以定义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所操作的数据进行计算(DataComputation)、推入/推出栈(Stack)等操作,从而完成数据计算。这个过程中,还可能需要一些合约的上下文(Context)信息,例如区块号、调用合约的发起者的信息之类,这些信息可以从Context中得到(Get操作)。最后,将产生的状态通过调用存储接口以存入存储(Storage)中。需要说明的是,合约创建的过程中,也可能产生对合约中某些函数的解释执行,例如初始化操作的函数,这时也会解析代码、产生跳转指令,存入Memory,在Stack中操作数据等。上述涉及的解释执行过程中,一般来说,对重复执行的函数并不缓存,即使对于多次执行的函数,虚拟机也需要重复进行解析、执行的过程。
如同前面提到的JVM的跨平台可移植性的优点和有提升性能的需求,类似的,区块链中的EVM也可以采用JIT和AoT之类的技术来提升智能合约执行时的性能。在通过JIT编译智能合约的代码时,如果完全通过JIT的“热点分析”能力来统计代码的执行次数并分析得到热点代码,可能无法灵活地满足用户需求,譬如用户可能希望一些执行次数较少的代码被高效执行。
本说明书提供一种执行智能合约的方法实施例,如图6-1所示,包括:
S611:区块链节点接收创建智能合约的请求,所述请求中包括所述智能合约的代码,所述智能合约的代码中包括通过热点标识符标明的热点代码。
智能合约的代码可以为高级语言编写的代码,比如前述的Solidity语言等。用户可以在用户本地用高级语言编写智能合约的代码。用户也可以是在上述区块链节点上用高级语言编写智能合约的代码。用户还可以是在区别于上述区块链节点的其他区块链节点上用高级语言编写智能合约的代码。用户可以通过客户端将基于高级语言的智能合约的代码添加至交易中,并发送至区块链网络中,譬如直接发送至上述的区块链节点,或者先发送至其他区块链节点并进而转发至上述的区块链节点。相应的,收到上述基于高级语言的智能合约的代码后,上述区块链节点还可以采用编译器对高级语言编写的智能合约进行编译,生成字节码,进而对该字节码进行部署。
用户在用户本地或者某一区块链节点上用高级语言编写智能合约的代码后,可以在该用户本地或者某一区块链节点上采用编译器对所述高级语言编写的代码进行编译,生成字节码。进而,可以通过客户端将编译得到的智能合约的字节码添加到交易中,发送至区块链网络,并由区块链节点对交易中的字节码进行部署。
客户端生成交易的格式例如为图3~5中所示,其中,需要创建的智能合约的代码可以存放于交易的data字段中。
S613:所述区块链节点完成所述智能合约的部署后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码。
以太坊及类似原理的公有链、联盟链或者私有链系统中,区块链节点可以针对一批交易发起共识。所述一批交易中,可以包括上述创建智能合约的交易。通过共识后,一般的,各共识节点本地都存有待创建的所述智能合约的字节码。各共识节点本地可以执行所述创建智能合约的交易,创建对应的合约账户;并按照相同的规则给所述智能合约账户创建一个地址,各共识节点针对同一合约创建的地址是相同的。这样,就完成了合约的部署。
所述区块链节点完成创建所述智能合约后,即部署所述智能合约之后,可以开始将所述智能合约的字节码通过JIT编译为机器码并存储。所述区块链节点完成创建所述智能合约后,可以立即开始对所述智能合约的字节码进行JIT编译。这是因为,在部署智能合约之后,可能很快就有发起调用部署的智能合约的业务请求。此外,JIT需要花费相对较多的系统资源和时间,在区块链节点的业务负荷较重时分配系统资源进行JIT会影响业务的处理;因此,区块链节点也可以是利用相对空闲的时间段再对所述智能合约的字节码进行JIT编译,从而降低或避免对业务处理的影响。此外,所述区块链节点完成创建所述智能合约后,也可以是区块链节点接收到调用创建的所述智能合约的交易请求后,对所述智能合约的字节码进行JIT编译。
区块链各节点针对相同的智能合约字节码在本地进行JIT编译,各节点仅需针对自身的处理器架构、运行环境等进行调整,而不需要编译多个不同版本的机器码。这样,节点设备上存储的机器码的大小得以大大降低,从而可以降低存储开销。
优选的,所述存储为缓存,通过缓存到内存,后续可以更快速的作出响应。具体的,所述内存可以是在虚拟机中开辟的一块缓存区域。当然,即使存储到磁盘,很多情形下也可以一定程度的提升响应速度。
通过在智能合约的代码中添加热点标识符,使得热点标识符可以将至少一部分智能合约的代码标记为热点代码。那么,对于用户希望提升执行效率的代码(方法或函数),即便在智能合约的所有代码中并非大量重复执行(比如不符合JIT编译中定义的“热点代码”),仍然可以主动通过热点标识符将其标记为热点代码,从而使得这些代码必然能够被JIT编译为机器码并存储,使得区块链节点可以直接执行存储的机器码,而无需对这些代码进行解释执行。
热点标识符可以是专门表明需要作为热点代码的标识符,例如通过Hotspot这一关键字表示。那么,如果要将智能合约中的某一方法或函数对应的代码作为热点代码,可以在这个方法或函数的前面增加Hotspot这一热点标识符。这样,通过Hotspot作为前缀可以标明希望产生的热点代码。当然,除了Hotspot之外,还可以采用其他任意的热点标识符,本说明书并不对此进行限制;以及,除了将热点标识符作为前缀之外,还可以将热点标识符以后缀或其他方式进行标注,本说明书并不对此进行限制。
例如,对上面提到的代码示例1,如果想将函数“function C()”的代码作为热点代码,可以用热点标识符Hotspot在函数function C()之前标明(当然也可以将热点标识符Hotspot置于其他位置),如下代码示例2所示(下划线的部分表示热点标识符):
ContractExample{
int balance;
Hotspotfunction C( ){
balance+ = 1;
}
functiongetblance( ) returns(int){
return balance ;
}
}
在实例2中,用户通过热点标识符Hotspot标明了将函数function C()对应的代码作为热点代码。相应的,在将上述以Solidity语言编写的合约代码编译为字节码时,字节码中也将包含相应的热点标识符,以用于将对应于函数function C()的代码标记为热点代码。例如,字节码中同样可以采用Hotspot这一关键字作为热点标识符,即高级语言形式的代码与字节码形式的代码可以包含相同的热点标识符所标明的热点代码。而本领域技术人员明白,字节码形式的代码可以与高级语言形式的代码采用不同的热点标识符,比如高级语言形式的代码包括通过第一热点标识符标明的热点代码,字节码形式的代码包括通过第二热点标识符标明的热点代码,且第一热点标识符与第二热点标识符之间存在对应关系,使得在将高级语言形式的代码编译为字节码形式的代码时,可以自动将第一热点标识符转换为第二热点标识符。
如前所述,通过在智能合约的代码中包含热点标识符,使得热点标识符可以用于标明热点代码,而区块链节点在将智能合约的字节码通过JIT编译为机器码时,即可将热点标识符标明的热点代码编译为机器码并存储。同时,如前所述,JIT编译本身具有“热点分析”的能力,因而在对智能合约的代码进行翻译和/或执行的过程中,还可以据此能力识别除热点标识符标注的热点代码之外的非标注热点代码,并对该非标注热点代码进行编译和存储,从而既可以兼顾用户的个性化需求,又可以确保实际上的高频代码被编译为机器码,以提升执行效率。
在识别非标注热点代码时,例如通过JIT引擎的代码计数器来统计执行次数,从而分析出哪些字节码是多次执行的,从而对其翻译后的机器码进行缓存。而对于执行次数较少的操作,如果不属于热点标识符标明的热点代码,则可以不进行缓存,这样可以在执行效率和内存开销上达到最佳平衡。识别热点标识符标明的热点代码和非标注热点代码并缓存的方式,可以使得多次执行字节码的过程中,在除了首次需要翻译外,后续可以直接利用缓存的机器码,从而免去再次翻译字节码的过程,从而可以缩减时间。识别执行次数的粒度,可以是函数级别,还可以是代码块级别。一般来说,代码块可能是函数中的一部分,也可能是由若干函数构成。
区块链节点可以确定热点标识符标注的热点代码的占用空间大小,若用于存储机器码的存储空间大小超出该热点标识符标注的热点代码的占用空间大小,则可以对智能合约的代码进行翻译和/或执行的过程中,识别除热点标识符标注的热点代码之外的非标注热点代码,并对非标注热点代码进行编译和存储。当然,如果对于机器码的存储空间不存在大小限制,那么可以不考虑热点标识符标注的热点代码的占用空间大小,而总是通过JIT编译的热点分析能力识别除热点标识符标注的热点代码之外的非标注热点代码,并对该非标注热点代码进行编译和存储。
此外,对热点标识符标注的热点代码和/或非标注热点代码进行翻译和/或执行的过程中可以进行优化编译,以获得更好的性能,从而进一步提升执行效率。在JIT编译中进行进一步的优化,可以结合程序代码的前后关联进行编译,并将优化编译后的机器码缓存下来以供后续调用时使用。经过编译优化的机器码,执行效率一般会高于直接翻译得到的机器码。一方面,JIT引擎可以带上执行编译的区块链节点的硬件和环境信息,从而使得编译得到的机器码具有硬件+环境的优化,具体可以包括机器代码生成里的优化,包括指令级的优化,寄存器分配和优化等等。另一方面,JIT引擎可以分析上下文信息,比如当前函数中执行的分支跳转语句,识别其中哪一句是跳转可能行最大的,从而将这个跳转可能性最大的调整到最前,从而可以在执行时更高概率的首先命中该分支的语句;编译器优化过程还可以通过数据流分析/活跃变量分析进行死代码消除,例如消除不会走到的分支,此外还可以包括对循环语句进行优化,公共字表达式替换等。
S615:所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。
完成智能合约的部署后,可以提供对该合约的调用。这样,客户端(可能不同于S611中发起创建合约交易的客户端)可以发起对该合约的调用。例如,客户端发起一个交易,其中的to字段中为前述部署的智能合约的地址,data字段可以包括所调用的合约的方法和输入的参数,从而实现对部署的所述智能合约的调用。一般的,包括该调用合约的交易在内的一批交易经过共识后,各共识节点各自分别执行交易。
所述区块链节点执行部署的所述智能合约时,可以先查看本地是否存在该被调用的合约的机器码。如存在,则说明本地已经对该智能合约的字节码进行过JIT编译。进而,区块链节点可以直接执行所述智能合约中对应所调用的函数/代码块的机器码,并输入前述data字段指明的输入参数。
在存储有智能合约的机器码的情况下,由于机器码本身即是CPU(在OS的控制下)可以直接执行的,因此,所述区块链节点可以大幅提升执行智能合约的速度。并且,所述智能合约的机器码缓存在内存中的情形,可以更进一步的提升智能合约的执行速度。当然,即使存储在磁盘中,也可以一定程度上提升执行速度。
所述区块链节点执行所述机器码,具体可以是执行存储的所述智能合约中对应于所调用函数/代码块的机器码。
此外,所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,可以不必等待JIT编译的完成,而对部署的所述智能合约的字节码进行解释执行。为了及时对业务请求作出响应,即快速响应发起调用部署的智能合约的业务请求,区块链节点可以首先查询是否存在所述被调用的智能合约的机器码,如果有,则说明已经完成了JIT编译,如果没有,则说明尚未开始或尚未完成JIT编译。如果有机器码,如前所述,区块链节点执行部署的所述智能合约时,可以执行所述机器码,从而可以大幅提升执行智能合约的速度。如果没有机器码,则所述区块链节点还查询当前对所述智能合约字节码的JIT编译情况,具体可能包括两种情况:
情况一:区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约字节码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的字节码进行解释执行。
如果本地没有存储所述智能合约的机器码,所述区块链节点可以查询当前对所述智能合约字节码的JIT编译情况,查询结果可以是正处于JIT编译中。对于一些调用所述智能合约的业务请求来说,得到快速的响应是首选,这也是各类区块链系统设法提升每秒交易处理数量(TransactionPerSecond,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和S615中的区块链节点。这是因为,区块链作为分布式的系统,接收交易的节点和发起共识的节点以及执行交易的节点可以是不同的节点,当然也可以是相同的节点。
以下结合图6-2介绍本说明书另一执行智能合约的方法实施例,所述智能合约的代码中包括通过热点标识符标明的热点代码,所述方法包括:
S621:区块链节点部署所述智能合约的代码后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码。
所述智能合约的代码为高级语言编译生成的字节码;或者,在所述智能合约的代码由所述高级语言编写的情况下,所述区块链节点采用编译器对所述高级语言编写的代码进行编译,生成字节码。
所述高级语言形式的代码包括通过第一热点标识符标明的热点代码,所述字节码形式的代码包括通过第二热点标识符标明的热点代码。
所述区块链节点部署所述智能合约的代码后,开始将所述智能合约的代码通过JIT编译为机器码,具体可以包括:
所述区块链节点完成创建所述智能合约后,立即开始对所述智能合约的代码进行JIT编译;或,
所述区块链节点完成创建所述智能合约后,利用相对空闲的时间段对所述智能合约的代码进行JIT编译;或,
所述区块链节点接收到调用创建的所述智能合约的交易请求后,对所述智能合约的代码进行JIT编译。
所述将所述智能合约的代码通过JIT编译为机器码并存储,包括:
对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储。
对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储,包括:
若用于存储所述机器码的存储空间大小超出所述热点标识符标注的热点代码的占用空间大小,则在对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储。
所述将所述智能合约的代码通过JIT编译为机器码,包括:
对所述热点标识符标注的热点代码和/或所述非标注热点代码进行翻译和/或执行的过程中进行优化编译。
识别非标注热点代码的粒度包括函数级别或代码块级别。
S623:所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。
所述区块链节点执行所述机器码,可以是执行存储的所述智能合约中对应于所调用函数或代码块的机器码。
此外,所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则可以对所述智能合约的代码进行解释执行。
上述存储的具体方式可以为缓存。通过缓存到内存,后续可以更快速的作出响应。当然,即使存储到磁盘,很多情形下也可以一定程度的提升响应速度。
所述区块链节点对所述智能合约的代码进行解释执行,可以包括:
所述区块链节点对所述智能合约中对应于所调用函数的代码进行解释执行。
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,对所述智能合约的代码进行解释执行,具体可以包括:
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约字节码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的代码进行解释执行;
或,
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约的代码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并对所述智能合约的代码进行解释执行。
以下介绍本说明书一种执行智能合约的区块链节点实施例,如图7所示,包括:
接收单元71,用于接收创建智能合约的请求,所述请求中包括所述智能合约的代码,所述智能合约的代码中包括通过热点标识符标明的热点代码;
部署单元72,用于根据接收单元71接收到的创建智能合约的请求部署所述智能合约;
编译单元73,用于所述部署单元72完成部署后,开始将所述智能合约的代码中由所述热点标识符标明的热点代码通过JIT编译为机器码;
存储单元74,用于存储编译单元73编译的机器码;
执行单元75,接收到调用部署的所述智能合约时,如果存储单元74存储有所述智能合约的机器码,则执行所述机器码。
所述智能合约的代码为高级语言编译生成的字节码;或者,所述编译单元73还在所述智能合约的代码由所述高级语言编写的情况下,采用编译器对所述高级语言编写的代码进行编译,生成字节码。
所述高级语言形式的代码包括通过第一热点标识符标明的热点代码,所述字节码形式的代码包括通过第二热点标识符标明的热点代码,所述第一热点标识符对应于所述第二热点标识符。
所述部署单元72完成所述智能合约的部署后,编译单元73开始将所述智能合约的代码通过JIT编译为机器码,包括:
所述部署单元72完成创建所述智能合约后,编译单元73立即开始对所述智能合约的代码进行JIT编译;或,
部署单元72完成创建所述智能合约后,编译单元73利用相对空闲的时间段对所述智能合约的代码进行JIT编译;或,
执行单元75接收到调用创建的所述智能合约的交易请求后,编译单元73对所述智能合约的代码进行JIT编译。
所述存储单元74可以为内存或磁盘存储。
所述执行单元75执行所述机器码,包括:所述执行单元75执行存储的所述智能合约中对应于所调用函数/代码块的机器码。
所述编译单元73对所述智能合约的代码进行翻译和/或执行的过程中,还识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译;以及,所述存储单元74还对所述非标注热点代码进行存储。
所述编译单元73在用于存储所述机器码的存储空间大小超出所述热点标识符标注的热点代码的占用空间大小的情况下,对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译。
所述编译单元73识别非标注热点代码的粒度可以包括函数级别或代码块级别。
所述编译单元73可以在对所述热点标识符标注的热点代码和/或所述非标注热点代码进行翻译和/或执行的过程中进行优化编译。
所述执行单元75执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,则对所述智能合约的代码进行解释执行。
所述执行单元75对所述智能合约的代码进行解释执行,包括:
所述执行单元75对所述智能合约中对应于所调用函数的代码进行解释执行。
所述部署单元72执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,执行单元75对所述智能合约的代码进行解释执行,包括:
所述执行单元75执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,所述执行单元75还查询当前对所述智能合约的代码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的代码进行解释执行;
或,
所述执行单元75执行部署的所述智能合约时,如果存储单元74没有存储所述智能合约的机器码,所述执行单元75还查询当前对所述智能合约的代码的JIT编译情况,如果尚未开始AoT编译,则启动JIT编译,并对所述智能合约的代码进行解释执行。
此外,执行智能合约的区块链节点,也可以执行上述S621至S623的方法。
本说明书还提供一种区块链节点实施例,包括:
处理器,
存储器,存储有程序,其中在所述处理器执行所述程序时,按照前述的方式执行智能合约。
本说明书还提供一种存储介质实施例,用于存储程序,其中所述程序在被执行时,执行前述方法。
在20世纪90年代,对于一个技术的改进可以很明显地区分是硬件上的改进(例如,对二极管、晶体管、开关等电路结构的改进)还是软件上的改进(对于方法流程的改进)。然而,随着技术的发展,当今的很多方法流程的改进已经可以视为硬件电路结构的直接改进。设计人员几乎都通过将改进的方法流程编程到硬件电路中来得到相应的硬件电路结构。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(Programmable Logic Device,PLD)(例如现场可编程门阵列(Field Programmable GateArray,FPGA)就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片PLD上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片。而且,如今,取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compiler)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(HardwareDescription Language,HDL),而HDL也并非仅有一种,而是有许多种,如ABEL(AdvancedBoolean Expression Language)、AHDL(Altera Hardware Description Language)、Confluence、CUPL(Cornell University Programming Language)、HDCal、JHDL(JavaHardware Description Language)、Lava、Lola、MyHDL、PALASM、RHDL(Ruby HardwareDescription Language)等,目前最普遍使用的是VHDL(Very-High-Speed IntegratedCircuit Hardware Description Language)与Verilog。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
控制器可以按任何适当的方式实现,例如,控制器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(Application Specific Integrated Circuit,ASIC)、可编程逻辑控制器和嵌入微控制器的形式,控制器的例子包括但不限于以下微控制器:ARC 625D、Atmel AT91SAM、Microchip PIC18F26K20 以及Silicone Labs C8051F320,存储器控制器还可以被实现为存储器的控制逻辑的一部分。本领域技术人员也知道,除了以纯计算机可读程序代码方式实现控制器以外,完全可以通过将方法步骤进行逻辑编程来使得控制器以逻辑门、开关、专用集成电路、可编程逻辑控制器和嵌入微控制器等的形式来实现相同功能。因此这种控制器可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置也可以视为硬件部件内的结构。或者甚至,可以将用于实现各种功能的装置视为既可以是实现方法的软件模块又可以是硬件部件内的结构。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为服务器系统。当然,本说明书不排除随着未来计算机技术的发展,实现上述实施例功能的计算机例如可以为个人计算机、膝上型计算机、车载人机交互设备、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
虽然本说明书一个或多个实施例提供了如实施例或流程图所述的方法操作步骤,但基于常规或者无创造性的手段可以包括更多或者更少的操作步骤。实施例中列举的步骤顺序仅仅为众多步骤执行顺序中的一种方式,不代表唯一的执行顺序。在实际中的装置或终端产品执行时,可以按照实施例或者附图所示的方法顺序执行或者并行执行(例如并行处理器或者多线程处理的环境,甚至为分布式数据处理环境)。术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、产品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、产品或者设备所固有的要素。在没有更多限制的情况下,并不排除在包括所述要素的过程、方法、产品或者设备中还存在另外的相同或等同要素。例如若使用到第一,第二等词语用来表示名称,而并不表示任何特定的顺序。
为了描述的方便,描述以上装置时以功能分为各种模块分别描述。当然,在实施本说明书一个或多个时可以把各模块的功能在同一个或多个软件和/或硬件中实现,也可以将实现同一功能的模块由多个子模块或子单元的组合实现等。以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
本发明是参照根据本发明实施例的方法、装置(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储、石墨烯存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
本领域技术人员应明白,本说明书一个或多个实施例可提供为方法、系统或计算机程序产品。因此,本说明书一个或多个实施例可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本说明书一个或多个实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本说明书一个或多个实施例可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本本说明书一个或多个实施例,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。在本说明书的描述中,参考术语“一个实施例”、“一些实施例”、“示例”、“具体示例”、或“一些示例”等的描述意指结合该实施例或示例描述的具体特征、结构、材料或者特点包含于本说明书的至少一个实施例或示例中。在本说明书中,对上述术语的示意性表述不必须针对的是相同的实施例或示例。而且,描述的具体特征、结构、材料或者特点可以在任一个或多个实施例或示例中以合适的方式结合。此外,在不相互矛盾的情况下,本领域的技术人员可以将本说明书中描述的不同实施例或示例以及不同实施例或示例的特征进行结合和组合。
以上所述仅为本说明书一个或多个实施例的实施例而已,并不用于限制本本说明书一个或多个实施例。对于本领域技术人员来说,本说明书一个或多个实施例可以有各种更改和变化。凡在本说明书的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在权利要求范围之内。

Claims (29)

1.一种执行智能合约的方法,包括:
区块链节点接收创建智能合约的请求,所述请求中包括所述智能合约的代码,所述智能合约的代码中包括通过热点标识符标明的热点代码;
所述区块链节点完成所述智能合约的部署后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码;
所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。
2.如权利要求1所述的方法,
所述智能合约的代码为高级语言编译生成的字节码;或者,
所述方法还包括:在所述智能合约的代码由高级语言编写的情况下,所述区块链节点采用编译器对所述高级语言编写的代码进行编译,生成字节码。
3.如权利要求2所述的方法,所述高级语言形式的代码包括通过第一热点标识符标明的热点代码,所述字节码形式的代码包括通过第二热点标识符标明的热点代码,所述第一热点标识符对应于所述第二热点标识符。
4.如权利要求1所述的方法,所述区块链节点完成所述智能合约的部署后,开始将所述智能合约的代码通过JIT编译为机器码,包括:
所述区块链节点完成创建所述智能合约后开始对所述智能合约的代码进行JIT编译;或,
所述区块链节点完成创建所述智能合约后,利用相对空闲的时间段对所述智能合约的代码进行JIT编译;或,
所述区块链节点接收到调用创建的所述智能合约的交易请求后,对所述智能合约的代码进行JIT编译。
5.如权利要求1所述的方法,还包括:
对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储。
6.如权利要求5所述的方法,对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储,包括:
若用于存储所述机器码的存储空间大小超出所述热点标识符标注的热点代码的占用空间大小,则在对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储。
7.如权利要求5所述的方法,识别非标注热点代码的粒度包括函数级别或代码块级别。
8.如权利要求5所述的方法,所述将所述智能合约的代码通过JIT编译为机器码,包括:
在对所述热点标识符标注的热点代码和/或所述非标注热点代码进行翻译和/或执行的过程中进行优化编译。
9.如权利要求1所述的方法,所述区块链节点执行所述机器码,包括:
所述区块链节点执行存储的所述智能合约中对应于所调用函数或代码块的机器码。
10.如权利要求1所述的方法,所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则对所述智能合约的代码进行解释执行。
11.如权利要求10所述的方法,所述区块链节点对所述智能合约的代码进行解释执行,包括:
所述区块链节点对所述智能合约中对应于所调用函数的代码进行解释执行。
12.如权利要求10所述的方法,所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,对所述智能合约的代码进行解释执行,包括:
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约的代码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的代码进行解释执行;
或,
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约的代码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并对所述智能合约的代码进行解释执行。
13.如权利要求1所述的方法,所述存储为缓存。
14.一种执行智能合约的方法,所述智能合约的代码中包括通过热点标识符标明的热点代码,所述方法包括:
区块链节点部署所述智能合约的代码后,开始将所述智能合约的代码通过JIT编译为机器码并存储所述热点标识符标明的热点代码;
所述区块链节点执行部署的所述智能合约时,如果本地存储有所述智能合约的代码对应的机器码,则执行所述机器码。
15.如权利要求14所述的方法,
所述智能合约的代码为高级语言编译生成的字节码;或者
所述方法还包括:在所述智能合约的代码由高级语言编写的情况下,所述区块链节点采用编译器对所述高级语言编写的代码进行编译,生成字节码。
16.如权利要求15所述的方法,所述高级语言形式的代码包括通过第一热点标识符标明的热点代码,所述字节码形式的代码包括通过第二热点标识符标明的热点代码,所述第一热点标识符对应于所述第二热点标识符。
17.如权利要求14所述的方法,所述区块链节点部署所述智能合约的字节码后,开始将所述智能合约的代码通过JIT编译为机器码,包括:
所述区块链节点完成创建所述智能合约后开始对所述智能合约的代码进行JIT编译;或,
所述区块链节点完成创建所述智能合约后,利用相对空闲的时间段对所述智能合约的代码进行JIT编译;或,
所述区块链节点接收到调用创建的所述智能合约的交易请求后,对所述智能合约的代码进行JIT编译。
18.如权利要求14所述的方法,还包括:
对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储。
19.如权利要求18所述的方法,对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储,包括:
若用于存储所述机器码的存储空间大小超出所述热点标识符标注的热点代码的占用空间大小,则在对所述智能合约的代码进行翻译和/或执行的过程中,识别除所述热点标识符标注的热点代码之外的非标注热点代码,并对所述非标注热点代码进行编译和存储。
20.如权利要求18所述的方法,识别非标注热点代码的粒度包括函数级别或代码块级别。
21.如权利要求18所述的方法,所述将所述智能合约的代码通过JIT编译为机器码,包括:
在对所述热点标识符标注的热点代码和/或所述非标注热点代码进行翻译和/或执行的过程中进行优化编译。
22.如权利要求14所述的方法,所述区块链节点执行所述机器码,包括:
所述区块链节点执行存储的所述智能合约中对应于所调用函数或代码块的机器码。
23.如权利要求14所述的方法,所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,则对所述智能合约的代码进行解释执行。
24.如权利要求23所述的方法,所述区块链节点对所述智能合约的代码进行解释执行,包括:
所述区块链节点对所述智能合约中对应于所调用函数的代码进行解释执行。
25.如权利要求23所述的方法,所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,对所述智能合约的代码进行解释执行,包括:
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约的代码的JIT编译情况,如果正处于JIT编译中,则对所述智能合约的代码进行解释执行;
或,
所述区块链节点执行部署的所述智能合约时,如果本地没有存储所述智能合约的机器码,所述区块链节点还查询当前对所述智能合约的代码的JIT编译情况,如果尚未开始JIT编译,则启动JIT编译,并对所述智能合约的代码进行解释执行。
26.如权利要求14所述的方法,所述存储为缓存。
27.一种执行智能合约的区块链节点,执行上述权利要求1-13或14-26中任一项所述的方法。
28.一种执行智能合约的区块链节点,包括:
处理器,
存储器,存储有程序,其中在所述处理器执行所述程序时,执行上述权利要求1-13或14-26中任一项所述的方法。
29.一种存储介质,用于存储程序,其中所述程序在被执行时进行上述权利要求1-13或14-26中任一项的操作。
CN202010899216.1A 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备 Active CN111770113B (zh)

Priority Applications (4)

Application Number Priority Date Filing Date Title
CN202111095262.7A CN113872948A (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备
CN202010899216.1A CN111770113B (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备
US17/358,126 US11366677B2 (en) 2020-08-31 2021-06-25 Methods, blockchain nodes, and node devices for executing smart contract
EP21182397.6A EP3961376B1 (en) 2020-08-31 2021-06-29 Improving smart contracts execution with just-in-time compilation

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010899216.1A CN111770113B (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备

Related Child Applications (1)

Application Number Title Priority Date Filing Date
CN202111095262.7A Division CN113872948A (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备

Publications (2)

Publication Number Publication Date
CN111770113A true CN111770113A (zh) 2020-10-13
CN111770113B CN111770113B (zh) 2021-07-30

Family

ID=72729155

Family Applications (2)

Application Number Title Priority Date Filing Date
CN202111095262.7A Pending CN113872948A (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备
CN202010899216.1A Active CN111770113B (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备

Family Applications Before (1)

Application Number Title Priority Date Filing Date
CN202111095262.7A Pending CN113872948A (zh) 2020-08-31 2020-08-31 一种执行智能合约的方法、区块链节点和节点设备

Country Status (3)

Country Link
US (1) US11366677B2 (zh)
EP (1) EP3961376B1 (zh)
CN (2) CN113872948A (zh)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112882774A (zh) * 2021-02-08 2021-06-01 北京微芯区块链与边缘计算研究院 并行执行的智能合约芯片装置及方法、区块链节点装置
CN112905238A (zh) * 2021-02-08 2021-06-04 北京微芯区块链与边缘计算研究院 一种区块链智能合约执行器及方法、区块链运行系统
CN113067900A (zh) * 2021-06-02 2021-07-02 支付宝(杭州)信息技术有限公司 智能合约的部署方法及装置
CN113220327A (zh) * 2021-05-11 2021-08-06 支付宝(杭州)信息技术有限公司 智能合约升级方法及区块链系统
CN113220326A (zh) * 2021-05-11 2021-08-06 支付宝(杭州)信息技术有限公司 智能合约升级方法及区块链系统
CN113407198A (zh) * 2021-06-07 2021-09-17 广东辰宜信息科技有限公司 智能合约部署方法和装置
CN113689293A (zh) * 2021-08-09 2021-11-23 深圳前海微众银行股份有限公司 一种联盟链中智能合约文件确定方法及装置
CN113805889A (zh) * 2021-08-27 2021-12-17 成都质数斯达克科技有限公司 一种智能合约调用执行方法、装置、设备及可读存储介质
CN114879948A (zh) * 2022-07-08 2022-08-09 北京百度网讯科技有限公司 基于WebAssembly的智能合约处理方法、装置、设备及存储介质
CN116700628A (zh) * 2023-08-01 2023-09-05 腾讯科技(深圳)有限公司 区块链数据处理方法、装置、计算机设备和存储介质

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11409630B2 (en) * 2017-11-28 2022-08-09 Yale University Systems and methods of formal verification
CN113037817B (zh) * 2020-08-31 2022-12-20 支付宝(杭州)信息技术有限公司 启动智能合约的方法及装置、电子设备、存储介质
KR102398543B1 (ko) * 2021-11-09 2022-05-17 주식회사 온더 영지식 증명 알고리즘이 적용된 검증 가능한 블록체인 가상머신
CN113867709B (zh) * 2021-12-01 2022-04-12 深圳前海微众银行股份有限公司 区块链智能合约读写集构建方法及装置
US11934255B2 (en) 2022-01-04 2024-03-19 Bank Of America Corporation System and method for improving memory resource allocations in database blocks for executing tasks
CN114422535B (zh) * 2022-01-18 2024-04-09 网易(杭州)网络有限公司 区块链中部署合约的方法、装置、计算机设备及存储介质
CN115022312A (zh) * 2022-03-30 2022-09-06 中国信息通信研究院 多智能合约引擎的实现方法、装置、电子设备及存储介质
GB2618106A (en) * 2022-04-27 2023-11-01 Nchain Licensing Ag Messaging protocol for compact script transactions
CN116643727B (zh) * 2023-05-11 2024-02-06 北京秒如科技有限公司 编程语言检测及自动编译为wasm字节码的方法和系统
CN116382702B (zh) * 2023-06-06 2023-08-18 湖南天河国云科技有限公司 智能合约热点探测方法、装置、电子设备和存储介质

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101346706A (zh) * 2005-12-29 2009-01-14 英特尔公司 虚拟转换后备缓冲器
CN108717374A (zh) * 2018-04-24 2018-10-30 阿里巴巴集团控股有限公司 Java虚拟机启动时预热的方法、装置、及计算机设备
CN110032883A (zh) * 2019-01-31 2019-07-19 阿里巴巴集团控股有限公司 区块链中实现隐私保护的方法、系统和节点
CN110275713A (zh) * 2019-07-02 2019-09-24 四川长虹电器股份有限公司 一种Java虚拟机后端编译的改进方法
CN110543338A (zh) * 2019-09-09 2019-12-06 北京安云世纪科技有限公司 一种文件的动态加载方法及装置
CN110609689A (zh) * 2019-08-23 2019-12-24 北京安云世纪科技有限公司 一种应用的安装运行方法及装置
CN111033468A (zh) * 2019-03-26 2020-04-17 阿里巴巴集团控股有限公司 实施不同类型的区块链合约的系统和方法
CN111061484A (zh) * 2019-11-28 2020-04-24 Oppo广东移动通信有限公司 代码编译方法、装置、服务器、用户终端及可读介质
US20200174937A1 (en) * 2019-08-30 2020-06-04 Alibaba Group Holding Limited Deploying a smart contract

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030041110A1 (en) * 2000-07-28 2003-02-27 Storymail, Inc. System, Method and Structure for generating and using a compressed digital certificate
US8959495B2 (en) 2012-09-14 2015-02-17 Oracle International Corporation Unifying static and dynamic compiler optimizations in source-code bases
US9286089B2 (en) * 2014-01-24 2016-03-15 International Business Machines Corporation Just-in time expensive compilation hints
CN105511942B (zh) * 2015-12-02 2019-02-19 华为技术有限公司 语言虚拟机中热点中间代码的识别方法以及装置
US10447478B2 (en) * 2016-06-06 2019-10-15 Microsoft Technology Licensing, Llc Cryptographic applications for a blockchain system
US20200167870A1 (en) * 2017-05-12 2020-05-28 Insurdata Corporation Method and System Configured for Risk Asset Data Collection
US10268829B2 (en) * 2017-08-11 2019-04-23 Dragonchain, Inc. Security systems and methods based on cryptographic utility token inventory tenure
US10785197B2 (en) * 2017-11-21 2020-09-22 Jose Luis Merino Gonzalez System and method for distributed internet sharing
CN108196872A (zh) 2017-12-27 2018-06-22 邵美 一种区块链系统中智能合约的升级方法
US20200065124A1 (en) 2018-08-22 2020-02-27 International Business Machines Corporation Shortening just-in-time code warm up time of docker containers
CN111899102A (zh) 2018-11-30 2020-11-06 创新先进技术有限公司 区块链中实现隐私保护的方法
MX2019009344A (es) * 2018-12-28 2019-10-02 Alibaba Group Holding Ltd Ejecucion paralela de transacciones en una red de cadena de bloques con base en listas blancas de contratos inteligentes.
WO2020142431A1 (en) * 2019-01-02 2020-07-09 Formulus Black Corporation Systems and methods for memory failure prevention, management, and mitigation
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
EP3742322A1 (en) * 2019-05-22 2020-11-25 Siemens Aktiengesellschaft Operational policies or industrial field devices and distributed databases
US10699269B1 (en) * 2019-05-24 2020-06-30 Blockstack Pbc System and method for smart contract publishing
CN110675256B (zh) 2019-08-30 2020-08-21 阿里巴巴集团控股有限公司 部署和执行智能合约的方法及装置

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101346706A (zh) * 2005-12-29 2009-01-14 英特尔公司 虚拟转换后备缓冲器
CN108717374A (zh) * 2018-04-24 2018-10-30 阿里巴巴集团控股有限公司 Java虚拟机启动时预热的方法、装置、及计算机设备
CN110032883A (zh) * 2019-01-31 2019-07-19 阿里巴巴集团控股有限公司 区块链中实现隐私保护的方法、系统和节点
CN111033468A (zh) * 2019-03-26 2020-04-17 阿里巴巴集团控股有限公司 实施不同类型的区块链合约的系统和方法
CN110275713A (zh) * 2019-07-02 2019-09-24 四川长虹电器股份有限公司 一种Java虚拟机后端编译的改进方法
CN110609689A (zh) * 2019-08-23 2019-12-24 北京安云世纪科技有限公司 一种应用的安装运行方法及装置
US20200174937A1 (en) * 2019-08-30 2020-06-04 Alibaba Group Holding Limited Deploying a smart contract
CN110543338A (zh) * 2019-09-09 2019-12-06 北京安云世纪科技有限公司 一种文件的动态加载方法及装置
CN111061484A (zh) * 2019-11-28 2020-04-24 Oppo广东移动通信有限公司 代码编译方法、装置、服务器、用户终端及可读介质

Cited By (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112905238A (zh) * 2021-02-08 2021-06-04 北京微芯区块链与边缘计算研究院 一种区块链智能合约执行器及方法、区块链运行系统
CN112882774A (zh) * 2021-02-08 2021-06-01 北京微芯区块链与边缘计算研究院 并行执行的智能合约芯片装置及方法、区块链节点装置
CN113220327B (zh) * 2021-05-11 2022-09-16 支付宝(杭州)信息技术有限公司 智能合约升级方法及区块链系统
CN113220327A (zh) * 2021-05-11 2021-08-06 支付宝(杭州)信息技术有限公司 智能合约升级方法及区块链系统
CN113220326A (zh) * 2021-05-11 2021-08-06 支付宝(杭州)信息技术有限公司 智能合约升级方法及区块链系统
WO2022252995A1 (zh) * 2021-06-02 2022-12-08 支付宝(杭州)信息技术有限公司 智能合约部署的方法及装置
CN113067900B (zh) * 2021-06-02 2021-09-24 支付宝(杭州)信息技术有限公司 智能合约的部署方法及装置
CN113067900A (zh) * 2021-06-02 2021-07-02 支付宝(杭州)信息技术有限公司 智能合约的部署方法及装置
CN113407198A (zh) * 2021-06-07 2021-09-17 广东辰宜信息科技有限公司 智能合约部署方法和装置
CN113689293A (zh) * 2021-08-09 2021-11-23 深圳前海微众银行股份有限公司 一种联盟链中智能合约文件确定方法及装置
CN113689293B (zh) * 2021-08-09 2024-02-06 深圳前海微众银行股份有限公司 一种联盟链中智能合约文件确定方法及装置
CN113805889A (zh) * 2021-08-27 2021-12-17 成都质数斯达克科技有限公司 一种智能合约调用执行方法、装置、设备及可读存储介质
CN114879948A (zh) * 2022-07-08 2022-08-09 北京百度网讯科技有限公司 基于WebAssembly的智能合约处理方法、装置、设备及存储介质
CN114879948B (zh) * 2022-07-08 2022-10-28 北京百度网讯科技有限公司 基于WebAssembly的智能合约处理方法、装置、设备及存储介质
CN116700628A (zh) * 2023-08-01 2023-09-05 腾讯科技(深圳)有限公司 区块链数据处理方法、装置、计算机设备和存储介质
CN116700628B (zh) * 2023-08-01 2024-02-02 腾讯科技(深圳)有限公司 区块链数据处理方法、装置、计算机设备和存储介质

Also Published As

Publication number Publication date
EP3961376A1 (en) 2022-03-02
US20210318897A1 (en) 2021-10-14
CN113872948A (zh) 2021-12-31
CN111770113B (zh) 2021-07-30
EP3961376B1 (en) 2023-12-27
US11366677B2 (en) 2022-06-21

Similar Documents

Publication Publication Date Title
CN111770113B (zh) 一种执行智能合约的方法、区块链节点和节点设备
CN111814202B (zh) 一种执行智能合约的方法、区块链节点和存储介质
CN111770116B (zh) 一种执行智能合约的方法、区块链节点、存储介质
CN111815310B (zh) 一种执行智能合约的方法、区块链节点和存储介质
CN111770205B (zh) 一种执行智能合约的方法、区块链节点、系统和存储介质
CN111770204B (zh) 一种执行智能合约的方法、区块链节点和存储介质
CN111768184A (zh) 一种执行智能合约的方法及区块链节点
CN111768183B (zh) 一种执行智能合约的方法、区块链节点和存储介质
CN111768187A (zh) 一种部署智能合约的方法、区块链节点和存储介质
CN111815330A (zh) 一种部署智能合约的方法、区块链节点和存储介质
CN111768200A (zh) 一种部署智能合约的方法、区块链节点和存储介质
WO2022237590A1 (zh) 智能合约升级方法及区块链系统
CN111770202B (zh) 一种执行智能合约的方法、区块链节点和存储介质
CN113220327B (zh) 智能合约升级方法及区块链系统
CN116931947A (zh) 一种优化wasm字节码的方法及执行方法、计算机设备及存储介质

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
REG Reference to a national code

Ref country code: HK

Ref legal event code: DE

Ref document number: 40039048

Country of ref document: HK

GR01 Patent grant
GR01 Patent grant