CN111190692A - 一种基于鲲鹏处理器的监控方法、系统及可读介质 - Google Patents
一种基于鲲鹏处理器的监控方法、系统及可读介质 Download PDFInfo
- Publication number
- CN111190692A CN111190692A CN201911368200.1A CN201911368200A CN111190692A CN 111190692 A CN111190692 A CN 111190692A CN 201911368200 A CN201911368200 A CN 201911368200A CN 111190692 A CN111190692 A CN 111190692A
- Authority
- CN
- China
- Prior art keywords
- virtual machine
- processor
- system call
- call
- kunpeng
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 74
- 238000012544 monitoring process Methods 0.000 title claims abstract description 41
- 230000008569 process Effects 0.000 claims description 29
- 238000004891 communication Methods 0.000 claims description 4
- 230000006870 function Effects 0.000 description 14
- 238000010586 diagram Methods 0.000 description 11
- 230000006872 improvement Effects 0.000 description 9
- 238000004590 computer program Methods 0.000 description 7
- 238000012545 processing Methods 0.000 description 7
- 238000005516 engineering process Methods 0.000 description 5
- 238000001228 spectrum Methods 0.000 description 4
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000005856 abnormality Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 229920001296 polysiloxane Polymers 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000001960 triggered effect Effects 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
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请实施例公开了一种基于鲲鹏处理器的监控方法,所述方法包括:在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令;若所述鲲鹏处理器监听到预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
Description
技术领域
本申请涉及计算机技术领域,尤其涉及一种基于鲲鹏处理器的监控方法、系统及可读介质。
背景技术
在云计算的场景中,为了确保虚拟机内部正常运行,通常需要监控虚拟机内部的运行状态,一旦发现虚拟机内部的运行状态出现异常时,可以及时采取应对措施。
在监控虚拟机内部的运行状态时,传统的解决方法是在虚拟机内部部署监控程序,通过监控程序直接监控虚拟机内部的运行状态,但在虚拟机内部部署监控程序时,在虚拟机运行的过程中也会运行该监控程序,影响虚拟机的运行效率。
发明内容
有鉴于此,本申请实施例提供了一种基于鲲鹏处理器的监控方法、系统及可读介质,用于解决现有技术在虚拟机内部部署监控程序,可能会影响虚拟机运行效率的问题。
本申请实施例采用下述技术方案:
本申请实施例提供一种基于鲲鹏处理器的监控方法,所述方法包括:
在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令;
若所述鲲鹏处理器监听到预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
进一步的,所述调用指令包括鲲鹏ARM处理器中的SWI软中断指令。
进一步的,所述配置信息包括以下任意一项或多项:所述系统调用的内容、所述系统调用对应的参数以及所述系统调用对应进程的地址。
进一步的,所述系统调用对应的参数存储于第一寄存器,所述系统调用对应进程的地址存储于第二寄存器;
所述在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,具体包括:
在虚拟机监控器中,所述鲲鹏处理器根据所述调用指令解析出系统调用的内容,从所述第一寄存器读取所述系统调用对应参数,从所述第二寄存器读取所述系统调用对应进程的地址。
进一步的,所述鲲鹏处理器根据所述调用指令解析出系统调用的内容,具体包括:
在虚拟监控器中所述鲲鹏处理器读取所述调用指令中的调用号;解析出系统调用的内容,其中,所述调用内容以下任意一项或多项包括读写文件、收发网络数据以及申请内存。
进一步的,所述得出所述系统调用对应的配置信息后,所述方法还包括:
将所述系统调用注入到虚拟机内核空间,以便于虚拟机执行后续任务。
进一步的,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令前,所述方法还包括:
所述鲲鹏处理器建立所述虚拟机与所述虚拟机监视器之间的通信通道。
进一步的,所述鲲鹏处理器运行模式包括以下任意一项或多项:虚拟机中的应用程序运行的用户模式、鲲鹏处理器内核空间运行的管理模式、鲲鹏处理器的虚拟机监控器运行的监管模式。
本申请实施例还提供一种基于鲲鹏处理器的监控系统,所述系统至少包括鲲鹏处理器;所述鲲鹏处理器用于执行:
在所述鲲鹏处理器对应的虚拟机运行时,实时监听所述虚拟机是否存在预先设置的调用指令;
若监听到所述预先设置的调用指令,在所述虚拟机中停止执行所述调用指令对应的系统调用,将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在所述虚拟机监控器中解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
本申请实施例还提供一种计算机可读介质,其上存储有计算机可读指令,所述计算机可读指令可被处理器执行以执行下述步骤:
在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令;
若所述鲲鹏处理器监听到预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
本申请实施例采用的上述至少一个技术方案能够达到以下有益效果:由于虚拟机在实现系统调用是通过特定的调用指令触发,所以本申请实施例预先设置实现虚拟机进行系统调用的调用指令,一旦监听到预先设置的调用指令,将该调用指令对应的系统调用陷入至虚拟机监控器,并在虚拟机监控器中完成对该系统调用的解析,得出系统调用对应的配置信息,进而完成了对虚拟机内部运行状态的监控工作,其中,虚拟机监控器独立于虚拟机。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1为本申请说明书实施例一提供的基于鲲鹏处理器的监控方法的流程示意图;
图2为本申请说明书实施例二提供的基于鲲鹏处理器的监控方法的流程示意图;
图3为本申请说明书实施例二提供的虚拟机运行过程的示意图;
图4为本申请说明书实施例二提供的虚拟机与虚拟机监控器运行过程的示意图。
具体实施方式
在监控虚拟机内部的运行状态时,传统的解决方法是在虚拟机内部部署监控程序,通过监控程序直接监控虚拟机内部的运行状态,但在虚拟机内部部署监控程序,会增加部署和维护的成本影响虚拟机的运行效率;在虚拟机内部部署监控程序,在虚拟机运行的过程中也会运行该监控程序,可能会影响虚拟机的运行效率;此外,若是在虚拟机内部部署监控程序,该监控程序可能会被不法分子获取并篡改,可能会影响监控的结果。
为使本申请的目的、技术方案和优点更加清楚,下面将结合本申请具体实施例及相应的附图对本申请技术方案进行清楚、完整地描述。显然,所描述的实施例仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
以下结合附图,详细说明本申请各实施例提供的技术方案。
图1为本说明书实施例一提供的一种基于鲲鹏处理器的监控方法的流程示意图。
本实施例可以由鲲鹏处理器执行下述步骤,具体包括:
步骤S101,在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令,若是,则执行步骤S102;若否,则继续执行步骤S101。
步骤S102,若所述鲲鹏处理器监听到预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机。
步骤S103,在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
由于虚拟机在实现系统调用是通过特定的调用指令触发,所以本发明实施例预先设置实现虚拟机进行系统调用的调用指令,一旦监听到预先设置的调用指令,将该调用指令对应的系统调用陷入至虚拟机监控器,并在虚拟机监控器中完成对该系统调用的解析,得出系统调用对应的配置信息,进而完成了对虚拟机内部运行状态的监控工作,其中,虚拟机监控器独立于虚拟机,所以本发明实施例并没有在虚拟机内部署监控程序,在虚拟机监控器监控虚拟机时不会影响虚拟机的运行效率。
与上述实施例一对应的,图2为本说明书实施例二提供的一种基于鲲鹏处理器的监控方法的流程示意图。
本实施例可以由鲲鹏处理器执行下述步骤,具体包括:
步骤S201,在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令,若是,则执行步骤S202;若否,则继续执行步骤S201。
在本说明书实施例的步骤S201中,调用指令可以包括鲲鹏ARM处理器中的SWI软中断指令。
参见图3,示出了本申请实施例提供的虚拟机运行过程的示意图。
用户在用户空间操作某个应用程序时,将会产生相对应的进程,而鲲鹏处理器的主要功能是为应用程序的运行创建良好的环境,保障每个进程都可以最大化利用硬件资源,防止非法程序破坏其它应用程序执行环境,为了达到这个目的。鲲鹏处理器将硬件的操作权限交给内核空间来管理,进程不能随意使用硬件,使用硬件(对硬件寄存器进行读写)时要先向鲲鹏处理器发出请求,鲲鹏处理器内核帮助用户程序实现其操作,也就是说用户程序不会直接操作硬件,而是提供给进程一些具备预定功能的内核函数,通过系统调用接口呈现给用户,系统调用把应用程序的请求传给内核空间,调用相应的内核函数完成所需的处理,将处理结果返回给应用程序,其中,触发系统调用的指令可以为SWI软中断指令。
需要说明的是,鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令前,所述方法还包括:
所述鲲鹏处理器建立所述虚拟机与所述虚拟机监视器之间的通信通道。
步骤S202,若所述鲲鹏处理器监听到预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机。
在本说明书实施例的步骤S202中,鲲鹏处理器支持多种模式,虚拟机中的应用程序运行在用户模式,鲲鹏处理器内核空间运行在管理模式,而鲲鹏处理器的虚拟机监控器运行在HYP模式,HYP模式的权限级别高于用户模式与管理模式。并且在HYP模式可以设置指令是否是调用指令。当处理器执行调用指令时,调用指令对应的系统调用将会自动陷入到HYP模式。其中,HYP(Hypervisor)模式为监管模式。
步骤S203,在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
在本说明书实施例的步骤S203中,配置信息包括以下任意一项或多项:系统调用的内容、系统调用对应的参数以及所述系统调用对应进程的地址。系统调用对应的参数存储于第一寄存器,系统调用对应进程的地址存储与第二寄存器。
在虚拟机监控器中解析所述系统调用,得出所述系统调用对应的配置信息,具体包括:
在虚拟机监控器中,根据所述调用指令解析出系统调用的内容,从所述第一寄存器读取所述系统调用对应参数,从所述第二寄存器读取所述系统调用对应进程的地址。
调用指令包括调用号,鲲鹏处理器根据所述调用指令解析出系统调用的内容,具体包括:
在虚拟监控器中所述鲲鹏处理器读取所述调用指令中的调用号;解析出系统调用的内容,其中,所述调用内容以下任意一项或多项包括读写文件、收发网络数据以及申请内存。
在本说明书实施例的步骤S203中,在虚拟机监控器中鲲鹏处理器读取SWI软中断指令的调用号,就可以判断出系统调用的内容,调用号就是系统调用的编号。例如,调用号可以为:
#define__NR_restart_syscall 0;
#define__NR_exit 1;
#define__NR_fork 2;
#define__NR_read 3;
#define__NR_write 4;
#define__NR_open 5;
#define__NR_close 6;
#define__NR_waitpid 7;
#define__NR_creat 8。
系统调用的内容包括读写文件、收发网络数据、申请内存,可以通过系统调用的编号解析出系统调用的内容。
虚拟机监控器运行在HYP模式时,鲲鹏处理器读取第一寄存器读取系统调用对应的参数,比如,用户需要读a文件,系统调用的内容为读文件,系统调用对应的参数为a文件,a文件是需要存储在第一寄存器(第一寄存器为硬件)。
虚拟机监控器运行在HYP模式时,鲲鹏处理器读取第二寄存器读取系统调用对应进程的地址,比如,用户在执行某个应用程序时,想要读a文件,生成一条进程A,该进程A拥有唯一的页表基地址,该页表基地址可以作为进程A的身份标识。
步骤S204,将所述系统调用注入到虚拟机内核空间,以便于虚拟机执行后续任务。
参见图3-4,系统调用陷入至虚拟监控器,记录信息(即系统调用对应的配置信息)后,将系统调用返回至内核空间。
需要说明的是:本申请的实施例不需要在虚拟机内部部署监控程序,也不需要定制修改虚拟机内部的处理器;不影响虚拟机内部的运行效率。此外,虚拟机监控器没有安装在虚拟机内部,不法分子无法了解基于鲲鹏处理器的监控机制,无法对基于鲲鹏处理器的监控系统造成危害,安全性高。
由于虚拟机在实现系统调用是通过特定的调用指令触发,所以本发明实施例预先设置实现虚拟机进行系统调用的调用指令,一旦监听到预先设置的调用指令,将该调用指令对应的系统调用陷入至虚拟机监控器,并在虚拟机监控器中完成对该系统调用的解析,得出系统调用对应的配置信息,进而完成了对虚拟机内部运行状态的监控工作,其中,虚拟机监控器独立于虚拟机,所以本发明实施例并没有在虚拟机内部署监控程序,在虚拟机监控器监控虚拟机时不会影响虚拟机的运行效率。
本申请实施例还提供一种基于鲲鹏处理器的监控系统,所述系统至少包括鲲鹏处理器;所述鲲鹏处理器用于执行:
在所述鲲鹏处理器对应的虚拟机运行时,实时监听所述虚拟机是否存在预先设置的调用指令;
若监听到所述预先设置的调用指令,在所述虚拟机中停止执行所述调用指令对应的系统调用,将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在所述虚拟机监控器中解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
本申请实施例还提供一种计算机可读介质,其上存储有计算机可读指令,所述计算机可读指令可被处理器执行以执行下述步骤:
在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令;
若所述鲲鹏处理器监听到预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
在20世纪90年代,对于一个技术的改进可以很明显地区分是硬件上的改进(例如,对二极管、晶体管、开关等电路结构的改进)还是软件上的改进(对于方法流程的改进)。然而,随着技术的发展,当今的很多方法流程的改进已经可以视为硬件电路结构的直接改进。设计人员几乎都通过将改进的方法流程编程到硬件电路中来得到相应的硬件电路结构。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(Programmable Logic Device,PLD)(例如现场可编程门阵列(Field Programmable GateArray,FPGA))就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片PLD上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片。而且,如今,取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compiler)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(Hardware Description Language,HDL),而HDL也并非仅有一种,而是有许多种,如ABEL(Advanced Boolean Expression Language)、AHDL(Altera Hardware DescriptionLanguage)、Confluence、CUPL(Cornell University Programming Language)、HDCal、JHDL(Java Hardware Description Language)、Lava、Lola、MyHDL、PALASM、RHDL(RubyHardware Description Language)等,目前最普遍使用的是VHDL(Very-High-SpeedIntegrated Circuit Hardware Description Language)与Verilog。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
控制器可以按任何适当的方式实现,例如,控制器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(Application Specific Integrated Circuit,ASIC)、可编程逻辑控制器和嵌入微控制器的形式,控制器的例子包括但不限于以下微控制器:ARC 625D、Atmel AT91SAM、Microchip PIC18F26K20以及Silicone Labs C8051F320,存储器控制器还可以被实现为存储器的控制逻辑的一部分。本领域技术人员也知道,除了以纯计算机可读程序代码方式实现控制器以外,完全可以通过将方法步骤进行逻辑编程来使得控制器以逻辑门、开关、专用集成电路、可编程逻辑控制器和嵌入微控制器等的形式来实现相同功能。因此这种控制器可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置也可以视为硬件部件内的结构。或者甚至,可以将用于实现各种功能的装置视为既可以是实现方法的软件模块又可以是硬件部件内的结构。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为计算机。具体的,计算机例如可以为个人计算机、膝上型计算机、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
为了描述的方便,描述以上装置时以功能分为各种单元分别描述。当然,在实施本申请时可以把各单元的功能在同一个或多个软件和/或硬件中实现。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带式磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
本申请可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本申请,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。
Claims (10)
1.一种基于鲲鹏处理器的监控方法,其特征在于,所述方法包括:
在所述鲲鹏处理器对应的虚拟机运行时,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令;
若所述鲲鹏处理器监听到所述预先设置的调用指令,在所述虚拟机中所述鲲鹏处理器停止执行所述调用指令对应的系统调用,所述鲲鹏处理器将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在所述虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
2.根据权利要求1所述的基于鲲鹏处理器的监控方法,其特征在于,所述调用指令包括鲲鹏ARM处理器中的SWI软中断指令。
3.根据权利要求1所述的基于鲲鹏处理器的监控方法,其特征在于,所述配置信息包括以下任意一项或多项:所述系统调用的内容、所述系统调用对应的参数以及所述系统调用对应进程的地址。
4.根据权利要求3所述的基于鲲鹏处理器的监控方法,其特征在于,所述系统调用对应的参数存储于第一寄存器,所述系统调用对应进程的地址存储于第二寄存器;
所述在虚拟机监控器中所述鲲鹏处理器解析所述系统调用,得出所述系统调用对应的配置信息,具体包括:
在虚拟机监控器中,所述鲲鹏处理器根据所述调用指令解析出系统调用的内容,从所述第一寄存器读取所述系统调用对应参数,从所述第二寄存器读取所述系统调用对应进程的地址。
5.根据权利要求4所述的基于鲲鹏处理器的监控方法,其特征在于,所述鲲鹏处理器根据所述调用指令解析出系统调用的内容,具体包括:
在虚拟监控器中所述鲲鹏处理器读取所述调用指令中的调用号;解析出系统调用的内容,其中,所述调用内容以下任意一项或多项包括读写文件、收发网络数据以及申请内存。
6.根据权利要求1所述的基于鲲鹏处理器的监控方法,其特征在于,所述得出所述系统调用对应的配置信息后,所述方法还包括:
将所述系统调用注入到虚拟机内核空间,以便于虚拟机执行后续任务。
7.根据权利要求1所述的基于鲲鹏处理器的监控方法,其特征在于,所述鲲鹏处理器实时监听所述虚拟机是否存在预先设置的调用指令前,所述方法还包括:
所述鲲鹏处理器建立所述虚拟机与所述虚拟机监视器之间的通信通道。
8.根据权利要求1所述的基于鲲鹏处理器的监控方法,其特征在于,所述鲲鹏处理器运行模式包括以下任意一项或多项:虚拟机中的应用程序运行的用户模式、鲲鹏处理器内核空间运行的管理模式、鲲鹏处理器的虚拟机监控器运行的监管模式。
9.一种基于鲲鹏处理器的监控系统,其特征在于,所述系统至少包括鲲鹏处理器;所述鲲鹏处理器用于执行:
在所述鲲鹏处理器对应的虚拟机运行时,实时监听所述虚拟机是否存在预先设置的调用指令;
若监听到所述预先设置的调用指令,在所述虚拟机中停止执行所述调用指令对应的系统调用,将所述系统调用陷入至虚拟机监控器,其中,所述虚拟机监控器独立于所述虚拟机;
在所述虚拟机监控器中解析所述系统调用,得出所述系统调用对应的配置信息,以实现对虚拟机内部运行状态的监控。
10.一种计算机可读介质,其特征在于,其上存储有计算机可读指令,所述计算机可读指令可被处理器执行以实现权利要求1至8中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911368200.1A CN111190692A (zh) | 2019-12-26 | 2019-12-26 | 一种基于鲲鹏处理器的监控方法、系统及可读介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911368200.1A CN111190692A (zh) | 2019-12-26 | 2019-12-26 | 一种基于鲲鹏处理器的监控方法、系统及可读介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN111190692A true CN111190692A (zh) | 2020-05-22 |
Family
ID=70707545
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201911368200.1A Pending CN111190692A (zh) | 2019-12-26 | 2019-12-26 | 一种基于鲲鹏处理器的监控方法、系统及可读介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111190692A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112363779A (zh) * | 2020-11-25 | 2021-02-12 | 王志平 | 一种动态链接程序的安全控制方法 |
CN112817690A (zh) * | 2021-01-22 | 2021-05-18 | 华东计算技术研究所(中国电子科技集团公司第三十二研究所) | 一种面向arm架构虚拟化领域的中断虚拟化处理方法及系统 |
CN115033302A (zh) * | 2022-05-27 | 2022-09-09 | 天翼云科技有限公司 | 一种安全加固方法、装置、设备及介质 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103632101A (zh) * | 2013-12-09 | 2014-03-12 | 北京奇虎科技有限公司 | 一种拦截系统调用的方法和装置 |
CN106055385A (zh) * | 2016-06-06 | 2016-10-26 | 四川大学 | 监控虚拟机进程的系统和方法、过滤page fault异常的方法 |
-
2019
- 2019-12-26 CN CN201911368200.1A patent/CN111190692A/zh active Pending
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103632101A (zh) * | 2013-12-09 | 2014-03-12 | 北京奇虎科技有限公司 | 一种拦截系统调用的方法和装置 |
CN106055385A (zh) * | 2016-06-06 | 2016-10-26 | 四川大学 | 监控虚拟机进程的系统和方法、过滤page fault异常的方法 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112363779A (zh) * | 2020-11-25 | 2021-02-12 | 王志平 | 一种动态链接程序的安全控制方法 |
CN112817690A (zh) * | 2021-01-22 | 2021-05-18 | 华东计算技术研究所(中国电子科技集团公司第三十二研究所) | 一种面向arm架构虚拟化领域的中断虚拟化处理方法及系统 |
CN112817690B (zh) * | 2021-01-22 | 2022-03-18 | 华东计算技术研究所(中国电子科技集团公司第三十二研究所) | 一种面向arm架构虚拟化领域的中断虚拟化处理方法及系统 |
CN115033302A (zh) * | 2022-05-27 | 2022-09-09 | 天翼云科技有限公司 | 一种安全加固方法、装置、设备及介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5985631B2 (ja) | 信頼レベルのアクティブ化 | |
CN111190692A (zh) | 一种基于鲲鹏处理器的监控方法、系统及可读介质 | |
CN107045438B (zh) | 一种应用顶层视图处理方法、装置及组件 | |
CN107368292B (zh) | 一种资源编译方法及装置 | |
CN115378735B (zh) | 一种数据处理方法、装置、存储介质及电子设备 | |
US11113387B2 (en) | Method and apparatus for improving security of Java sandbox | |
CN115185534A (zh) | 一种数据脱敏方法、装置、可读存储介质以及电子设备 | |
WO2023151436A1 (zh) | Sql语句风险检测 | |
CN111090425B (zh) | 一种程序封装方法、装置及电子设备 | |
CN108304313B (zh) | 一种用于数据测试的装置、客户端及方法 | |
CN114840427A (zh) | 一种代码测试、测试用例生成的方法及装置 | |
CN111459573B (zh) | 一种智能合约执行环境的启动方法以及装置 | |
CN113556260B (zh) | 一种流量监控方法、装置、存储介质及电子设备 | |
CN113449292B (zh) | 一种可信应用的运行方法、装置及设备 | |
CN111797387A (zh) | 拦截外挂插件的方法及装置 | |
CN111078435A (zh) | 业务处理方法、装置及电子设备 | |
CN111209079A (zh) | 一种基于鲲鹏处理器的调度方法、装置及介质 | |
CN115495343A (zh) | 一种安全维护方法、装置、存储介质及电子设备 | |
CN115185847A (zh) | 一种故障测试方法、装置、存储介质及电子设备 | |
CN110737524B (zh) | 一种任务规则管理方法、装置、设备及介质 | |
CN107239270B (zh) | 代码处理方法和装置 | |
CN108681492A (zh) | 数据处理方法及装置 | |
CN114428633A (zh) | 一种固件升级方法、装置以及设备 | |
CN114546628B (zh) | 一种线程处理方法、线程管理方法、装置以及设备 | |
CN112328213B (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20200522 |