CN115145696B - 确定进程虚拟机运行差异的方法、***及计算设备 - Google Patents
确定进程虚拟机运行差异的方法、***及计算设备 Download PDFInfo
- Publication number
- CN115145696B CN115145696B CN202211050855.6A CN202211050855A CN115145696B CN 115145696 B CN115145696 B CN 115145696B CN 202211050855 A CN202211050855 A CN 202211050855A CN 115145696 B CN115145696 B CN 115145696B
- Authority
- CN
- China
- Prior art keywords
- virtual machine
- program
- process virtual
- architecture
- computing device
- 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 246
- 230000008569 process Effects 0.000 title claims abstract description 173
- 230000015654 memory Effects 0.000 claims description 18
- 238000004891 communication Methods 0.000 claims description 10
- 238000004088 simulation Methods 0.000 claims description 9
- 238000010586 diagram Methods 0.000 description 8
- 238000012545 processing Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 5
- 230000008901 benefit Effects 0.000 description 4
- 238000005516 engineering process Methods 0.000 description 4
- 230000004044 response Effects 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 3
- 238000013507 mapping Methods 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- 230000007723 transport mechanism Effects 0.000 description 2
- 230000006978 adaptation Effects 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 229910002056 binary alloy Inorganic materials 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 238000013508 migration Methods 0.000 description 1
- 230000005012 migration Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000000644 propagated effect Effects 0.000 description 1
- 239000000758 substrate Substances 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/194—Calculation of difference between files
-
- 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
- G06F9/45512—Command shells
-
- 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/45533—Hypervisors; Virtual machine monitors
- G06F9/45537—Provision of facilities of other operating environments, e.g. WINE
-
- 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/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45575—Starting, stopping, suspending or resuming virtual machine instances
-
- 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/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45591—Monitoring or debugging support
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Health & Medical Sciences (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种确定进程虚拟机运行差异的方法、***及计算设备,涉及计算机技术领域。方法包括:通过第一进程虚拟机模拟执行第二架构程序,生成第一执行结果文件;获取第一执行命令并进行解析生成第一文本文件;将第一文本文件发送至第二计算设备的第二服务程序,以便第二服务程序对第一文本文件进行解析生成第二执行命令;将第二架构程序发送至第二服务程序,第二服务程序通过第二执行命令启动第二进程虚拟机,模拟执行第二架构程序,生成第二执行结果文件;将第一执行结果文件与第二执行结果文件进行对比,以确定进程虚拟机基于第一架构与第二架构运行的差异信息。根据本发明的技术方案,可以自动查找进程虚拟机基于不同架构平台运行的差异。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种确定进程虚拟机运行差异的方法、确定进程虚拟机运行差异的***及计算设备。
背景技术
目前,Windows操作***占据了计算机操作***的绝大部分市场,Windows操作***上的软件生态也极其丰富,大部分常用软件都是基于Windows开发。为了在UOS上为用户提供相同体验,需要将Windows上的软件迁移到UOS上使用。因***接口不同,导致Windows应用程序无法直接迁移到UOS上运行。而Wine作为Windows应用和Linux内核之间的兼容适配层,为应用跨平台迁移提供了支持。
Wine模拟了x86和x64 Window应用程序调用的API接口,但没有模拟硬件层。从指令集的角度来看,Windows应用程序通过Wine能够在基于x86、x64架构的Linux***上运行,但无法在其它架构上运行。而UOS支持多种架构,为了使基于ARM架构的UOS***也能运行Windows应用程序,需要使用进程虚拟机来仿真运行Wine。
进程虚拟机的原理是逐条解析X86指令并使用c代码模拟X86指令的功能来实现其行为,或者,将X86二进制进行分块后,逐块翻译成ARM指令并执行。通常,待仿真的应用程序需要频繁使用***资源,而***调用是用户程序访问***资源的必经入口,为此,进程虚拟机需要拦截仿真程序的***调用并将其转发到真实***上,以使待仿真程序认为自身完成了***资源的操作。
事实上,进程虚拟机并不是简单的拦截int 80指令、接管待仿真程序的***调用后将其直接转发。还需要解决如下问题:不同架构下,***调用的调用号及数量并不完全相同;不同位宽下,数据并不能直接传递,需要在32位和64位之间相互转换;需要将内存分配、文件路径、信号等相关的***调用转入相应的处理模块。为此,进程虚拟机设计了一个中间层来仿真X86的***调用,该中间层称为***调用引擎。
***调用引擎属于进程虚拟机的一个核心模块,由于***调用引擎在模拟X86***调用时,并不清楚ARM平台和X86平台的所有差异,且***调用数量较大,从而不能确保所有可能出现差异的地方都进行了平台差异处理。这会造成在运行***调用相关测试程序时,出现多个测试程序在X86平台上正常运行,而ARM平台上出现卡死、崩溃、执行结果不符合预期等情况。
为了调试和跟踪***调用引擎在X86平台和ARM平台的执行差异,避免上述可能出现的一些潜在问题,需要一种确定进程虚拟机运行差异的方法。
发明内容
为此,本发明提供一种确定进程虚拟机运行差异的方法及***,以解决或至少缓解上面存在的问题。
根据本发明的一个方面,提供一种确定进程虚拟机运行差异的方法,在第一计算设备执行,所述第一计算设备与第二计算设备通信连接;所述第一计算设备包括第一架构处理器并运行有第一操作***,所述第一操作***上部署有第一进程虚拟机、第一服务程序;所述第二计算设备包括第二架构处理器并运行有第二操作***,所述第二操作***上部署有第二进程虚拟机、第二服务程序;所述方法包括:通过第一进程虚拟机模拟执行第二架构程序,以生成第一执行结果文件;第一服务程序获取第一执行命令,并对所述第一执行命令进行解析生成第一文本文件;将所述第一文本文件发送至第二服务程序,以便第二服务程序对所述第一文本文件进行解析生成第二执行命令;将所述第二架构程序发送至第二服务程序,以便第二服务程序通过所述第二执行命令来启动第二进程虚拟机,并通过所述第二进程虚拟机模拟执行所述第二架构程序,以生成第二执行结果文件;启动对比程序,通过对比程序将第一执行结果文件与第二执行结果文件进行对比,以确定进程虚拟机基于第一架构与第二架构运行的差异信息。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,将第一执行结果文件与第二执行结果文件进行对比,包括:基于第一执行结果文件生成第一数据列表,基于第二执行结果文件生成第二数据列表;将第一数据列表、第二数据列表中位于相同行的相同数据删除,并将第一数据列表中的剩余数据与第二数据列表中的剩余数据进行对比。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,将第一数据列表中的剩余数据与第二数据列表中的剩余数据进行对比,包括:将第一数据列表中的剩余数据、第二数据列表中的剩余数据划分为多个数据块并进行对比。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,在通过第一进程虚拟机启动第一服务程序之前,包括:启动第一进程虚拟机,通过第一进程虚拟机启动第一服务程序。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,在将所述第一文本文件发送至第二服务程序之前,包括:通知第二服务程序启动第二进程虚拟机;将所述第一文本文件发送至第二服务程序,包括:响应于第二服务程序获取第一文本文件的请求,将所述第一文本文件发送至第二服务程序。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,将所述第二架构程序发送至第二服务程序,包括:响应于第二服务程序获取第二架构程序的请求,将所述第二架构程序发送至第二服务程序。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,在将第一执行结果文件与第二执行结果文件进行对比之前,包括:响应于第二计算设备发送的第二架构程序执行完毕的消息,向第二服务程序请求获取第二执行结果文件; 响应于所述第一进程虚拟机模拟执行第二架构程序完毕的消息,获取第一执行结果文件。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,进程虚拟机中包括***调用引擎,确定进程虚拟机基于第一架构与第二架构运行的差异信息,包括:确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,所述第一操作***上还部署有第二操作***的兼容层,通过第一进程虚拟机模拟执行第二架构程序,包括:通过所述第一进程虚拟机模拟运行所述兼容层、并基于兼容层模拟执行第二架构程序。
可选地,在根据本发明的确定进程虚拟机运行差异的方法中,所述第一架构为ARM架构,所述第一操作***为UOS操作***;所述第二架构为X86架构,所述第二操作***为Windows操作***。
根据本发明的一个方面,提供一种确定进程虚拟机运行差异的***,包括:第一计算设备,所述第一计算设备包括第一架构处理器,并运行有第一操作***,所述第一操作***上部署有第一进程虚拟机、第一服务程序,所述第一计算设备适于执行如上所述的方法;第二计算设备,所述第二计算设备包括第二架构处理器,并运行有第二操作***,所述第二操作***上部署有第二进程虚拟机、第二服务程序。
根据本发明的一个方面,提供一种计算设备,包括:至少一个处理器;存储器,存储有程序指令,其中,程序指令被配置为适于由上述至少一个处理器执行,所述程序指令包括用于执行如上所述的确定进程虚拟机运行差异的方法的指令。
根据本发明的一个方面,提供一种存储有程序指令的可读存储介质,当该程序指令被计算设备读取并执行时,使得该计算设备执行如上所述的确定进程虚拟机运行差异的方法。
根据本发明的技术方案,提供了一种确定进程虚拟机运行差异的方法,其中,在不同架构的第一计算设备、第二计算设备分别部署进程虚拟机和服务程序,在第一计算设备通过第一进程虚拟机模拟执行第二架构程序,以生成第一执行结果文件,并通过第一服务程序获取用户输入的第一执行命令,将第一执行命令解析为第一文本文件,并将第一文本文件发送至第二计算设备的第二服务程序。第二服务程序可以将第一文本文件解析为文本文件,并在从第一计算设备获取到第二架构程序后,通过第二执行命令来启动第二进程虚拟机,通过第二进程虚拟机模拟执行第二架构程序,以生成第二执行结果文件。最后,第一计算设备通过启动对比程序,通过对比程序将第一执行结果文件与第二执行结果文件进行对比,便可以确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。根据本发明的方法,可以在无人值守情况下、自动化查找进程虚拟机的***调用引擎基于不同架构平台运行的差异,从而可以实现批量查找多个架构平台的运行差异,有利于提高工作效率,降低误操作率,节约人力成本。
进一步地,根据本发明的方法,通过将两个执行结果文件对应的两个数据列表中、位于相同行的相同数据删除后,再将剩余数据划分为数据块进行对比,可以大大降低对比的数据量,提高对比效率和对比速度。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个实施例的确定进程虚拟机运行差异的***100的示意图;
图2示出了根据本发明一个实施例的计算设备200的示意图;
图3示出了根据本发明一个实施例的确定进程虚拟机运行差异的方法300的流程图;
图4示出了根据本发明一个实施例的确定进程虚拟机运行差异的方法的时序图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例的确定进程虚拟机运行差异的***100的示意图。
如图1所示,确定进程虚拟机运行差异的***100包括第一计算设备110、第二计算设备120,第一计算设备110与第二计算设备120通信连接,例如可以通过有线或无线的方式网络连接。其中,第一计算设备110包括第一架构处理器115并运行有第一操作***。第一计算设备110的第一操作***上部署有第一进程虚拟机111、第一服务程序112、第二架构程序、对比程序。
第二计算设备120包括第二架构处理器125并运行有第二操作***,第二计算设备120的第二操作***上部署有第二进程虚拟机121、第二服务程序122。
在一个实施例中,第一计算设备110可以实现为客户端,第二计算设备120可以实现为服务端。
需要说明的是,在本发明的实施例中,第一进程虚拟机111与第二进程虚拟机121是相同的进程虚拟机,区别仅在于运行环境不同。为了区分运行在不同架构平台的进程虚拟机,将运行在第一计算设备110的第一架构处理器115和第一操作***上的进程虚拟机称为第一进程虚拟机111,将运行在第二计算设备120的第二架构处理器125和第二操作***上的进程虚拟机称为第二进程虚拟机121。
还需要说明的是,在本发明的实施例中,第一计算设备110、第二计算设备120之间可以通过第一服务程序112、第二服务程序122来识别对方的控制命令,并可以相互传送消息或文件。
应当指出,在本发明的实施例中,对第一架构、第二架构的具体类型不做限制。
在一个实施例中,第一架构可以为ARM架构,相应地,第一架构处理器115可以为ARM处理器。第一操作***可以为UOS操作***。第二架构可以为X86架构,相应地,第二架构处理器125可以为X86处理器。第二操作***可以为Windows操作***。
根据本发明的一个实施例,通过对进程虚拟机(第一进程虚拟机111、第二进程虚拟机121)进行Hook(挂钩),可以使进程虚拟机根据传入的环境变量来确定是否启动后台的服务程序(第一服务程序112、第二服务程序122),并且,在进程虚拟机执行完成并退出之前,可以向服务程序发送执行完毕消息。另外,服务程序可以获取用户输入的命令。
在本发明的实施例中,在第一计算设备110,启动第一进程虚拟机111,并通过第一进程虚拟机111启动第一服务程序112。随后,可以通过第一进程虚拟机111模拟执行第二架构程序,以生成第一执行结果文件。
第一计算设备110的第一服务程序112可以获取第一计算设备110用户输入的第一执行命令,并对该第一执行命令进行解析,生成第一文本文件,并可以将第一文本文件发送至第二计算设备120的第二服务程序122。这里,在一种实现方式中,第一文本文件可以实现为json文本文件。
第二计算设备120的第二服务程序122通过对第一文本文件进行解析,生成适于在第二计算设备120执行的第二执行命令,随后可以请求从第一计算设备110获取第二架构程序。
第一计算设备110的第一服务程序112在将第二架构程序发送至第二计算设备120的第二服务程序122后,第二计算设备120的第二服务程序122可以通过执行第二执行命令来启动第二进程虚拟机121,在第二进程虚拟机121启动后,可以通过第二进程虚拟机121模拟执行来自于第一计算设备110的第二架构程序,以便生成第二执行结果文件。
在第一进程虚拟机111模拟执行第二架构程序完毕、生成第一执行结果文件,并且,第二进程虚拟机121模拟执行第二架构程序完毕、生成第二执行结果文件之后,第一计算设备110的第一服务程序112通过获取第一执行结果文件、第二执行结果文件,并启动对比程序。通过对比程序来将第一执行结果文件与第二执行结果文件进行对比,可以确定进程虚拟机基于第一架构与第二架构运行的差异信息。具体地,可以确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。
在本发明的实施例中,第一计算设备110、第二计算设备120分别可以是桌面电脑、笔记本电脑等个人计算机,也可以是手机、平板电脑、多媒体设备、智能可穿戴设备等,但不限于此。
在本发明的实施例中,第一计算设备110适于执行本发明的确定进程虚拟机运行差异的方法300。本发明的确定进程虚拟机运行差异的方法300将在下文中详述。
在本发明的一个实施例中,第一计算设备110、第二计算设备120分别可以实现为如下所示的计算设备。
图2示出了根据本发明一个实施例的计算设备200的示意图。如图2所示,在基本配置中,计算设备200包括至少一个处理单元202和***存储器204。根据一个方面,取决于计算设备的配置和类型,处理单元202可以实现为处理器。***存储器204包括但不限于易失性存储(例如,随机存取存储器)、非易失性存储(例如,只读存储器)、闪速存储器、或者这样的存储器的任何组合。根据一个方面,***存储器204中包括操作***205。
根据一个方面,操作***105例如适合于控制计算设备200的操作。此外,示例结合图形库、其他操作***、或任何其他应用程序而被实践,并且不限于任何特定的应用或***。在图2中通过在虚线内的那些组件示出了该基本配置。根据一个方面,计算设备200具有额外的特征或功能。例如,根据一个方面,计算设备200包括额外的数据存储设备(可移动的和/或不可移动的),例如磁盘、光盘、或者磁带。这样额外的存储在图2中是由可移动存储设备209和不可移动存储设备210示出的。
如在上文中所陈述的,根据一个方面,在***存储器204中存储有程序模块203。根据一个方面,程序模块203可以包括一个或多个应用程序,本发明不限制应用程序的类型,例如应用程序可以包括:电子邮件和联系人应用程序、文字处理应用程序、电子表格应用程序、数据库应用程序、幻灯片展示应用程序、绘画或计算机辅助应用程序、网络浏览器应用程序等。在根据本发明的实施例中,程序模块203中包括执行本发明的确定进程虚拟机运行差异的方法300的多条程序指令。
根据一个方面,程序模块203中包括进程虚拟机、服务程序。进程虚拟机和服务程序被配置为执行本发明的确定进程虚拟机运行差异的方法300。
根据一个方面,处理单元202可以实现为第一架构处理器,操作***205可以实现为第一操作***。
根据一个方面,可以在包括分立电子元件的电路、包含逻辑门的封装或集成的电子芯片、利用微处理器的电路、或者在包含电子元件或微处理器的单个芯片上实践示例。例如,可以经由其中在图2中所示出的每个或许多组件可以集成在单个集成电路上的片上***(SOC)来实践示例。根据一个方面,这样的SOC设备可以包括一个或多个处理单元、图形单元、通信单元、***虚拟化单元、以及各种应用功能,其全部作为单个集成电路而被集成(或“烧”)到芯片基底上。当经由SOC进行操作时,可以经由在单个集成电路(芯片)上与计算设备200的其他组件集成的专用逻辑来对在本文中所描述的功能进行操作。还可以使用能够执行逻辑操作(例如AND、OR和NOT)的其他技术来实践本发明的实施例,所述其他技术包括但不限于机械、光学、流体、和量子技术。另外,可以在通用计算机内或在任何其他任何电路或***中实践本发明的实施例。
根据一个方面,计算设备200还可以具有一个或多个输入设备212,例如键盘、鼠标、笔、语音输入设备、触摸输入设备等。还可以包括输出设备214,例如显示器、扬声器、打印机等。前述设备是示例并且也可以使用其他设备。计算设备200可以包括允许与其他计算设备218进行通信的一个或多个通信连接216。合适的通信连接216的示例包括但不限于:RF发射机、接收机和/或收发机电路;通用串行总线(USB)、并行和/或串行端口。
如在本文中所使用的术语计算机可读介质包括计算机存储介质。计算机存储介质可以包括以任何用于存储信息(例如,计算机可读指示、数据结构、或程序模块)的方法或技术来实现的易失性的和非易失性的、可移动的和不可移动的介质。***存储器204、可移动存储设备209、和不可移动存储设备210都是计算机存储介质的示例(即,存储器存储)。计算机存储介质可以包括随机存取存储器(RAM) 、只读存储器(ROM) 、电可擦只读存储器(EEPROM)、闪速存储器或其他存储器技术、CD-ROM、数字通用盘(DVD)或其他光存储、盒式磁带、磁带、磁盘存储器或其他磁存储设备、或者可用于存储信息并且可以由计算设备200访问的任何其他制品。根据一个方面,任何这样的计算机存储介质都可以是计算设备200的一部分。计算机存储介质不包括载波或其他经传播的数据信号。
根据一个方面,通信介质是由计算机可读指令、数据结构、程序模块、或者经调制的数据信号(例如,载波或其他传输机制)中的其他数据实施的,并且包括任何信息传递介质。根据一个方面,术语“经调制的数据信号”描述了具有一个或多个特征集或者以将信息编码在信号中的方式改变的信号。作为示例而非限制,通信介质包括诸如有线网络或直接有线连接之类的有线介质,以及诸如声学、射频(RF)、红外线的、以及其他无线介质之类的无线介质。
在根据本发明的实施例中,计算设备200被配置为执行根据本发明的确定进程虚拟机运行差异的方法300。计算设备200包括一个或多个处理器、以及存储有程序指令的一个或多个可读存储介质,当程序指令被配置为由一个或多个处理器执行时,使得计算设备执行本发明实施例中的确定进程虚拟机运行差异的方法300。
图3示出了根据本发明一个实施例的确定进程虚拟机运行差异的方法300的流程图。方法300适于在第一计算设备110(例如前述计算设备200)中执行。另外,图4示出了根据本发明一个实施例的确定进程虚拟机运行差异的方法的时序图。
在根据本发明的实施例中,第一计算设备110与第二计算设备120通信连接。其中,第一计算设备110包括第一架构处理器115并运行有第一操作***。第一计算设备110的第一操作***上部署有第一进程虚拟机111、第一服务程序112、第二架构程序、对比程序。
第二计算设备120包括第二架构处理器125并运行有第二操作***,第二计算设备120的第二操作***上部署有第二进程虚拟机121、第二服务程序122。
需要说明的是,在本发明的实施例中,第一进程虚拟机111与第二进程虚拟机121是相同的进程虚拟机,区别仅在于运行环境不同。为了区分运行在不同架构平台的进程虚拟机,将运行在第一计算设备110的第一架构处理器115和第一操作***上的进程虚拟机称为第一进程虚拟机111,将运行在第二计算设备120的第二架构处理器125和第二操作***上的进程虚拟机称为第二进程虚拟机121。
还需要说明的是,在本发明的实施例中,第一计算设备110、第二计算设备120之间可以通过第一服务程序112、第二服务程序122来识别对方的控制命令,并可以相互传送消息或文件。
应当指出,在本发明的实施例中,对第一架构、第二架构的具体类型不做限制。
在一个实施例中,第一架构可以为ARM架构,相应地,第一架构处理器115可以为ARM处理器。第一操作***可以为UOS操作***。第二架构可以为X86架构,相应地,第二架构处理器125可以为X86处理器。第二操作***可以为Windows操作***。
如图3所示,方法300始于步骤310。
在执行步骤310之前,在第一计算设备110启动第一进程虚拟机111,并通过第一进程虚拟机111启动第一服务程序112。
根据本发明的一个实施例,在执行方法300之前,通过对进程虚拟机(第一进程虚拟机111、第二进程虚拟机121)进行Hook(挂钩),可以使进程虚拟机根据传入的环境变量来确定是否启动后台的服务程序(第一服务程序112、第二服务程序122),并且,在进程虚拟机执行完成并退出之前,可以向服务程序发送执行完毕消息。另外,服务程序可以获取用户输入的命令。
这样,第一计算设备110启动第一进程虚拟机111后,第一进程虚拟机111可以根据传入的环境参数来确定是否启动第一服务程序112,如果根据传入的环境参数确定启动第一服务程序112,则启动第一服务程序112。
在步骤310中,在第一计算设备110,通过第一进程虚拟机111模拟执行第二架构程序,以生成第一执行结果文件。
需要说明的是,第二架构程序是基于第二架构和第二操作***的应用程序,换言之,第二架构程序可以基于第二架构处理器125和第二操作***来运行。
在一个实施例中,第一架构可以为ARM架构,第一操作***可以为UOS操作***。第二架构可以为X86架构,第二操作***可以为Windows操作***。而兼容层(Wine)仅支持X86、X64架构,不支持ARM架构。基于此,当第一计算设备110通过第一进程虚拟机111模拟执行第二架构程序时,还需要在第一计算设备110的第一操作***上部署兼容层(Wine),通过第一进程虚拟机111来模拟运行兼容层,并基于兼容层来模拟执行(基于第二架构和第二操作***的)第二架构程序。具体地,第一进程虚拟机111可以将兼容层和第二架构程序的第二架构指令,转换为第一架构指令(ARM指令)并执行。
随后,在步骤320中,第一计算设备110的第一服务程序112获取第一计算设备110用户输入的第一执行命令,并对该第一执行命令进行解析,生成第一文本文件。这里,在一种实现方式中,第一文本文件可以实现为json文本文件。
接着,第一服务程序112可以通知第二计算设备120的第二服务程序122启动第二进程虚拟机121。
接下来,在步骤330中,第一计算设备110的第一服务程序112可以将第一文本文件发送至第二计算设备120的第二服务程序122。
具体地,第二计算设备120的第二服务程序122,在接收到第一计算设备110的第一服务程序112发送的启动第二进程虚拟机121的通知消息后,向第一计算设备110的第一服务程序112发送获取第一文本文件的请求。第一计算设备110的第一服务程序112响应于第二计算设备120的第二服务程序122获取第一文本文件的请求,将第一文本文件发送至第二计算设备120的第二服务程序122。
随后,第二服务程序122对第一文本文件进行解析,生成第二执行命令。这里,第二执行命令是适于在第二计算设备120执行的命令。
第二计算设备120的第二服务程序122在对第一文本文件进行解析完成、生成第二执行命令之后,可以向第一计算设备110发送获取第二架构程序的请求,以请求从第一计算设备110获取第二架构程序。
随后,在步骤340中,第一计算设备110的第一服务程序112响应于第二计算设备120的第二服务程序122获取第二架构程序的请求,将第二架构程序发送至第二计算设备120的第二服务程序122。这样,第二计算设备120的第二服务程序122可以通过执行第二执行命令来启动第二进程虚拟机121,在第二进程虚拟机121启动后,可以通过第二进程虚拟机121模拟执行来自于第一计算设备110的第二架构程序,以便生成第二执行结果文件。
这里,需要说明的是,第一计算设备110的第一服务程序112在对第一执行命令进行解析、生成第一文本文件时,并没有将启动第一服务程序112的环境参数置位,因此,第二计算设备120的第二进程虚拟机121在进入执行主体后,可以直接开始模拟执行第二架构程序。
在本发明的一个实施例中,第二计算设备120的第二进程虚拟机121在模拟执行第二架构程序完毕后,第二计算设备120会向第一计算设备110发送第二架构程序执行完毕的消息。具体地,第二进程虚拟机121在执行第二架构程序完毕后,向第二服务程序122发送第二架构程序执行完毕的消息,并退出执行。随后,第二服务程序122再将第二架构程序执行完毕的消息发送至第一计算设备110的第一服务程序112。
在一种实现方式中,第一计算设备110的第一服务程序112可以在预定时间范围内持续等待第二计算设备的执行完毕消息,直至接收到第二计算设备120发送的第二架构程序执行完毕的消息。
第一计算设备110的第一服务程序112在接收到第二计算设备120发送的第二架构程序执行完毕的消息后,响应于第二计算设备120发送的第二架构程序执行完毕的消息,向第二计算设备120的第二服务程序122请求获取第二执行结果文件。这里,第二进程虚拟机121在模拟执行第二架构程序完毕后,可以生成第二执行结果文件,并将第二执行结果文件提供给第二服务程序122,从而第二服务程序122可以将第二执行结果文件发送至第一计算设备110的第一服务程序112。
另外,在一个实施例中,当第一计算设备110的第一进程虚拟机111模拟执行第二架构程序完毕后,可以生成第一执行结果文件,并且,第一进程虚拟机111可以将模拟执行第二架构程序完毕的消息发送第一服务程序112,并退出执行。第一计算设备110的第一服务程序112可以响应于第一进程虚拟机111模拟执行第二架构程序完毕的消息,从第一进程虚拟机111获取第一执行结果文件。
最后,在步骤350中,第一计算设备110的第一服务程序112启动对比程序,通过对比程序来将第一执行结果文件与第二执行结果文件进行对比,以确定进程虚拟机基于第一架构与第二架构运行的差异信息。
这样,通过对比程序,将第一进程虚拟机111在第一架构处理器115和第一操作***上模拟执行第二架构程序的第一执行结果文件,与第二进程虚拟机121在第二架构处理器125和第二操作***上模拟执行第二架构程序的第二执行结果文件,进行对比,便可以确定进程虚拟机基于第一架构与第二架构运行的差异信息。具体地,可以确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。
需要说明的是,进程虚拟机中包括***调用引擎,第一进程虚拟机111中的***调用引擎为第一***调用引擎,第二进程虚拟机121中的***调用引擎为第二***调用引擎。根据本发明的一个实施例,通过对比程序来将第一执行结果文件与第二执行结果文件进行对比,可以确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。
但,根据本发明的方法300,并不受限于确定进程虚拟机的***调用引擎基于不同架构平台运行的差异,还可以确定进程虚拟机的其他模块基于不同架构平台运行的差异。
根据本发明的一个实施例,对比程序在将第一执行结果文件与第二执行结果文件进行对比时,首先,可以基于第一执行结果文件生成第一数据列表,基于第二执行结果文件生成第二数据列表。这里,具体可以将第一执行结果文件中的数据按行进行分割并存放在第一列表中,得到第一数据列表;并将第二执行结果文件中的数据按行进行分割并存放在第二列表中,得到第二数据列表。可以理解,第一数据列表是基于第一执行结果文件中的数据生成,第二数据列表是基于第二执行结果文件中的数据生成。其中,第一数据列表、第二数据列表中分别可以包括多行数据。
接着,可以将第一数据列表、第二数据列表中位于相同行的相同数据删除,并将第一数据列表中的剩余数据与第二数据列表中的剩余数据进行对比。
具体地,第一数据列表、第二数据列表中分别可以包括多行数据,每一行数据对应一个行号。通过将第一数据列表、第二数据列表中标记有相同行号的行数据依次进行比对,并确定第一数据列表、第二数据列表中标记有相同行号的行数据是否相同,如果两个数据列表中标记有相同行号的行数据相同,说明是第一数据列表、第二数据列表中位于相同行的相同数据,并将第一数据列表、第二数据列表中位于相同行的相同数据删除。
在将第一数据列表、第二数据列表中标记有相同行号的所有行数据均比对完成后,并将第一数据列表、第二数据列表中所有位于相同行的相同数据均删除后,再将第一数据列表中的剩余数据与第二数据列表中的剩余数据进行对比。这样,通过将两个数据列表中位于相同行的相同数据删除,只比对剩余数据,可以大大降低对比的数据量,提高对比效率。
在一个实施例中,可以将第一数据列表中的剩余数据、第二数据列表中的剩余数据分别划分为多个数据块后,对第一数据列表与第二数据列表中的数据块进行对比。这样,有利于实现快速对比,进一步提高对比效率。
在一种实现方式中,第一计算设备110的对比程序可以利用python的标准库Difflib,来对比第一执行结果文件中的文本与第二执行结果文件中的文本之间的差异。
在一个实施例中,对比程序在将第一执行结果文件中的文本与第二执行结果文件对比结束后,可以生成对比结果,并在第一计算设备110展示对比结果,以便将对比结果呈现给用户。在一种实现方式中,对比程序可以利用标准库Difflib按照不同的格式来输出对比结果。例如,对比结果可以为HTML文档格式。即,通过HTML文档来向用户呈现对比结果。这样,用户根据对比结果(HTML文档)可以确定进程虚拟机基于第一架构与第二架构运行的差异信息,例如,可以确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。
根据本发明的实施例,在确定进程虚拟机基于第一架构与第二架构运行的差异信息之后,可以快速定位到造成差异的原因,从而达到改进和完善进程虚拟机的目的,最终可以使进程虚拟机在ARM平台上可以更稳定、可靠地运行X86程序。例如,在根据本发明的方法300确定差异信息后,可以基于差异信息建立两种架构平台的差异映射表,根据差异映射表来对进程虚拟机中的***调用引擎进行配置,以便***调用引擎可以将参数转换为与架构平台相对应的语义后再将其转发给真实***,从而解决不同架构平台之间的语义问题。
根据本发明的确定进程虚拟机运行差异的方法,其中,在不同架构的第一计算设备、第二计算设备分别部署进程虚拟机和服务程序,在第一计算设备通过第一进程虚拟机模拟执行第二架构程序,以生成第一执行结果文件,并通过第一服务程序获取用户输入的第一执行命令,将第一执行命令解析为第一文本文件,并将第一文本文件发送至第二计算设备的第二服务程序。第二服务程序可以将第一文本文件解析为文本文件,并在从第一计算设备获取到第二架构程序后,通过第二执行命令来启动第二进程虚拟机,通过第二进程虚拟机模拟执行第二架构程序,以生成第二执行结果文件。最后,第一计算设备通过启动对比程序,通过对比程序将第一执行结果文件与第二执行结果文件进行对比,便可以确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。根据本发明的方法,可以在无人值守情况下、自动化查找进程虚拟机的***调用引擎基于不同架构平台运行的差异,从而可以实现批量查找多个架构平台的运行差异,有利于提高工作效率,降低误操作率,节约人力成本。
进一步地,根据本发明的方法,通过将两个执行结果文件对应的两个数据列表中、位于相同行的相同数据删除后,再将剩余数据划分为数据块进行对比,可以大大降低对比的数据量,提高对比效率和对比速度。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如可移动硬盘、U盘、软盘、CD-ROM或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,移动终端一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的确定进程虚拟机运行差异的方法。
以示例而非限制的方式,可读介质包括可读存储介质和通信介质。可读存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在可读介质的范围之内。
在此处所提供的说明书中,算法和显示不与任何特定计算机、虚拟***或者其它设备固有相关。各种通用***也可以与本发明的示例一起使用。根据上面的描述,构造这类***所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组件可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。
此外,所述实施例中的一些在此被描述成可以由计算机***的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的而非限制性的,本发明的范围由所附权利要求书限定。
Claims (11)
1.一种确定进程虚拟机运行差异的方法,在第一计算设备执行,所述第一计算设备与第二计算设备通信连接;
所述第一计算设备包括第一架构处理器并运行有第一操作***,所述第一操作***上部署有第一进程虚拟机、第一服务程序;
所述第二计算设备包括第二架构处理器并运行有第二操作***,所述第二操作***上部署有第二进程虚拟机、第二服务程序;
所述方法包括:
通过第一进程虚拟机模拟执行第二架构程序,以生成第一执行结果文件;
第一服务程序获取第一执行命令,并对所述第一执行命令进行解析生成第一文本文件;
将所述第一文本文件发送至第二服务程序,以便第二服务程序对所述第一文本文件进行解析生成第二执行命令;
将所述第二架构程序发送至第二服务程序,以便第二服务程序通过所述第二执行命令来启动第二进程虚拟机,并通过所述第二进程虚拟机模拟执行所述第二架构程序,以生成第二执行结果文件;
将第一执行结果文件与第二执行结果文件进行对比,以确定进程虚拟机基于第一架构与第二架构运行的差异信息。
2.如权利要求1所述的方法,其中,将第一执行结果文件与第二执行结果文件进行对比,包括:
基于第一执行结果文件生成第一数据列表,基于第二执行结果文件生成第二数据列表;
将第一数据列表、第二数据列表中位于相同行的相同数据删除,并将第一数据列表中的剩余数据与第二数据列表中的剩余数据进行对比。
3.如权利要求2所述的方法,其中,将第一数据列表中的剩余数据与第二数据列表中的剩余数据进行对比,包括:
将第一数据列表中的剩余数据、第二数据列表中的剩余数据划分为多个数据块并进行对比。
4.如权利要求1-3中任一项所述的方法,其中,在将所述第一文本文件发送至第二服务程序之前,包括:
通知第二服务程序启动第二进程虚拟机;
将所述第一文本文件发送至第二服务程序,包括:
响应于第二服务程序获取第一文本文件的请求,将所述第一文本文件发送至第二服务程序。
5.如权利要求1-3中任一项所述的方法,其中,将所述第二架构程序发送至第二服务程序,包括:
响应于第二服务程序获取第二架构程序的请求,将所述第二架构程序发送至第二服务程序。
6.如权利要求1-3中任一项所述的方法,其中,在将第一执行结果文件与第二执行结果文件进行对比之前,包括:
响应于第二计算设备发送的第二架构程序执行完毕的消息,向第二服务程序请求获取第二执行结果文件;
响应于所述第一进程虚拟机模拟执行第二架构程序完毕的消息,获取第一执行结果文件。
7.如权利要求1-3中任一项所述的方法,其中,进程虚拟机中包括***调用引擎,确定进程虚拟机基于第一架构与第二架构运行的差异信息,包括:
确定进程虚拟机的***调用引擎基于第一架构与第二架构运行的差异信息。
8.如权利要求1-3中任一项所述的方法,其中,所述第一操作***上还部署有第二操作***的兼容层,通过第一进程虚拟机模拟执行第二架构程序,包括:
通过所述第一进程虚拟机模拟运行所述兼容层、并基于兼容层模拟执行第二架构程序。
9.一种确定进程虚拟机运行差异的***,包括:
第一计算设备,所述第一计算设备包括第一架构处理器,并运行有第一操作***,所述第一操作***上部署有第一进程虚拟机、第一服务程序,所述第一计算设备适于执行如权利要求1-8中任一项所述的方法;
第二计算设备,所述第二计算设备包括第二架构处理器,并运行有第二操作***,所述第二操作***上部署有第二进程虚拟机、第二服务程序。
10.一种计算设备,包括:
至少一个处理器;以及
存储器,存储有程序指令,其中,所述程序指令被配置为适于由所述至少一个处理器执行,所述程序指令包括用于执行如权利要求1-8中任一项所述的方法的指令。
11.一种存储有程序指令的可读存储介质,当所述程序指令被计算设备读取并执行时,使得所述计算设备执行如权利要求1-8中任一项所述方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211050855.6A CN115145696B (zh) | 2022-08-30 | 2022-08-30 | 确定进程虚拟机运行差异的方法、***及计算设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211050855.6A CN115145696B (zh) | 2022-08-30 | 2022-08-30 | 确定进程虚拟机运行差异的方法、***及计算设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115145696A CN115145696A (zh) | 2022-10-04 |
CN115145696B true CN115145696B (zh) | 2022-11-29 |
Family
ID=83415738
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211050855.6A Active CN115145696B (zh) | 2022-08-30 | 2022-08-30 | 确定进程虚拟机运行差异的方法、***及计算设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115145696B (zh) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103136060A (zh) * | 2011-11-23 | 2013-06-05 | 联想(北京)有限公司 | 运行控制方法和运行控制装置 |
CN103793260A (zh) * | 2013-10-09 | 2014-05-14 | 中国电子设备***工程公司研究所 | 一种平台虚拟化*** |
CN104321745A (zh) * | 2012-02-07 | 2015-01-28 | 泰利瑞克股份公司 | 用于软件应用程序的跨平台开发的环境及方法 |
CN107463427A (zh) * | 2017-06-29 | 2017-12-12 | 北京北信源软件股份有限公司 | 一种虚拟机操作***类型与版本的获取方法与装置 |
CN113626133A (zh) * | 2021-06-29 | 2021-11-09 | 济南浪潮数据技术有限公司 | 一种虚拟机控制方法、装置、设备及计算机可读存储介质 |
CN114138423A (zh) * | 2021-12-13 | 2022-03-04 | 上海交通大学 | 基于国产gpu显卡的虚拟化构建***及方法 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11029991B2 (en) * | 2019-03-08 | 2021-06-08 | International Business Machines Corporation | Dispatch of a secure virtual machine |
-
2022
- 2022-08-30 CN CN202211050855.6A patent/CN115145696B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103136060A (zh) * | 2011-11-23 | 2013-06-05 | 联想(北京)有限公司 | 运行控制方法和运行控制装置 |
CN104321745A (zh) * | 2012-02-07 | 2015-01-28 | 泰利瑞克股份公司 | 用于软件应用程序的跨平台开发的环境及方法 |
CN103793260A (zh) * | 2013-10-09 | 2014-05-14 | 中国电子设备***工程公司研究所 | 一种平台虚拟化*** |
CN107463427A (zh) * | 2017-06-29 | 2017-12-12 | 北京北信源软件股份有限公司 | 一种虚拟机操作***类型与版本的获取方法与装置 |
CN113626133A (zh) * | 2021-06-29 | 2021-11-09 | 济南浪潮数据技术有限公司 | 一种虚拟机控制方法、装置、设备及计算机可读存储介质 |
CN114138423A (zh) * | 2021-12-13 | 2022-03-04 | 上海交通大学 | 基于国产gpu显卡的虚拟化构建***及方法 |
Non-Patent Citations (1)
Title |
---|
基于平台抽象层的进程虚拟机设计与实现;阳昕等;《计算机工程》;20080505(第09期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN115145696A (zh) | 2022-10-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111427803B (zh) | 自动化随机测试方法、装置、计算机设备及介质 | |
WO2019161619A1 (zh) | 接口自动化测试方法、装置、设备及计算机可读存储介质 | |
US20190034318A1 (en) | Hardware-Software Co-Verification for Debugging Firmware on a Hardware Simulator | |
CN109508178A (zh) | 一种程序开发方法及装置 | |
CN110532182A (zh) | 一种虚拟化平台的自动化测试方法及装置 | |
CN110516447A (zh) | 一种识别终端模拟器的方法与设备 | |
CN112154417B (zh) | 经由仿真网络通信信道在应用的单机版本和基于Web的版本之间共享代码库 | |
CN117914737A (zh) | 一种网络靶场的镜像资源测试方法及装置 | |
CN115145696B (zh) | 确定进程虚拟机运行差异的方法、***及计算设备 | |
CN112860587A (zh) | Ui自动测试方法和装置 | |
CN106502707B (zh) | 代码生成方法及装置 | |
CN112597718A (zh) | 集成电路设计的验证方法、验证装置以及存储介质 | |
CN115374017A (zh) | 一种仿真运行可执行文件时抓取现场的方法及计算设备 | |
CN114816772B (zh) | 基于兼容层运行的应用的排错方法、排错***及计算设备 | |
US20230103210A1 (en) | System Call Method and Apparatus, and Electronic Device | |
CN115185638A (zh) | 一种仿真运行应用程序时获取调用栈的方法及计算设备 | |
CN116540929A (zh) | 磁盘阵列的虚拟化读取方法、装置、电子设备及存储介质 | |
CN111240790A (zh) | 一种应用的多语言适配方法、装置、客户端和存储介质 | |
CN116775202A (zh) | 模糊测试方法、装置、介质、电子设备及计算机程序产品 | |
CN115687146A (zh) | Bios测试方法、装置、计算机设备和存储介质 | |
CN115576711A (zh) | 一种返回数据模拟方法、***及计算设备 | |
CN111949510B (zh) | 测试处理方法、装置、电子设备及可读存储介质 | |
CN114911541A (zh) | 配置信息的处理方法、装置、电子设备及存储介质 | |
CN113792522A (zh) | 仿真验证方法、装置及计算设备 | |
CN111679862A (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 |