CN106997316B - 内存异常增长的检测系统及方法 - Google Patents

内存异常增长的检测系统及方法 Download PDF

Info

Publication number
CN106997316B
CN106997316B CN201710232891.7A CN201710232891A CN106997316B CN 106997316 B CN106997316 B CN 106997316B CN 201710232891 A CN201710232891 A CN 201710232891A CN 106997316 B CN106997316 B CN 106997316B
Authority
CN
China
Prior art keywords
memory
metadata
module
recording
monitoring
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
Application number
CN201710232891.7A
Other languages
English (en)
Other versions
CN106997316A (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.)
SHANGHAI LIANTONG NETWORK COMMUNICATIONS TECHNOLOGY Co Ltd
Original Assignee
SHANGHAI LIANTONG NETWORK COMMUNICATIONS 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 SHANGHAI LIANTONG NETWORK COMMUNICATIONS TECHNOLOGY Co Ltd filed Critical SHANGHAI LIANTONG NETWORK COMMUNICATIONS TECHNOLOGY Co Ltd
Priority to CN201710232891.7A priority Critical patent/CN106997316B/zh
Publication of CN106997316A publication Critical patent/CN106997316A/zh
Application granted granted Critical
Publication of CN106997316B publication Critical patent/CN106997316B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • G06F11/0727Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a storage system, e.g. in a DASD or network based storage system

Abstract

本发明涉及一种内存异常增长的检测系统及方法,包括内存记录模块,用于注册钩子函数并记录所有已经申请的内存的元数据;内存监控模块,用于监控目标进程的已使用内存,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据;数据分析模块,用于分析内存监控模块的所有数据,将元数据转换成调试信息并生成可视化信息,显示内存异常增长的总大小和各个内存申请点所申请内存的大小和百分比。采用该系统及方法,实现了内存异常增长的检测;能在进程运行同时自由启动和关闭,并检测到任意短时间内的内存突发性增长,检测效果显著;能准确定位泄露位置并获得内存增长点和图表统计数据,提高准确性,具有广泛的应用范围。

Description

内存异常增长的检测系统及方法
技术领域
本发明涉及计算机系统技术领域,尤其涉及内存分配、管理和分析技术领域,具体是指一种内存异常增长的检测系统及方法。
背景技术
内存异常增长包含内存泄露和非泄露性质的内存异常增长,当前主流的内存检测工具都偏向检测内存泄露的情形,一般内存泄露检测方法是,hook目标进程的内存管理函数,在目标进程生命周期结束的时候,若检测到目标进程有未释放的内存,则目标进程内存泄露。而对于无法结束其生命周期的进程,比较流行的一种检测方法是基于时间片轮询检查目标进程在两个时间点之间内存使用情况,进而找到内存泄露的怀疑点,然后再由程序员代码分析判断。但是,目前已知的工具,并没有特别针对非泄露的内存增长检测工具,而已知的内存检测工具存在以下不足:
1、对于系统级别进程,其生命周期与系统同步,依赖进程生命周期结束的工具,无法检测该类进程。
2、基于时间片检测内存泄露的工具,其时间片就是个经验值,无法应对任意场景的内存泄露,并且对于小内存泄露,无法准确侦测和排除噪点。
3、目前流行的工具都不能准确侦测非泄露性质的内存异常增长,比如短时间内申请大量内存,之后再释放,该场景依然会可能导致系统异常,但却事后从内存上无法发现问题,而且内存泄露工具也无法准确发现该异常。
发明内容
本发明的目的是克服了上述现有技术的缺点,提供了一种能够解决特殊情况下出现的内存非泄露性异常增长的情况和系统级生命周期的进程内存泄露的问题,并实现检测内存异常增长的系统及方法。
为了实现上述目的,本发明具有如下构成:
该内存异常增长的检测系统,包括:
内存记录模块,用于注册钩子函数并记录所有已经申请的内存的元数据;
内存监控模块,用于监控目标进程的已使用内存,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据;
数据分析模块,用于分析内存监控模块的所有数据,将元数据转换成调试信息并生成可视化信息,显示内存异常增长的总大小和各个内存申请点所申请内存的大小和百分比。
还包括一种基于上述系统实现内存异常增长的检测方法,所述的方法包括以下步骤:
(1)在进程启动时通过所述的内存记录模块注册钩子函数;
(2)所述的内存记录模块对进程的内存申请和释放过程进行记录;
(3)所述的内存监控模块对内存的使用情况进行监控,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据;
(4)所述的数据分析模块分析并生成可视化数据和调试信息。
较佳地,所述的步骤(3)包括以下步骤:
(3-1)应用发起内存申请的请求;
(3-2)通过所述的钩子函数记录内存元数据并保存到哈希表;
(3-3)向系统申请内存;
(3-4)检查内存占用是否超过阈值,如果是,则继续步骤(3-5),否则,完成本次内存申请的监控;
(3-5)通知内存监控模块记录当前进程的所有内存信息;
(3-6)更新当前进程的内存阈值。
更佳地,所述的更新当前进程的内存阈值,具体为:
基于最大占用内存或最小占用内存的稳步更新当前进程的内存阈值,或者基于最大占用内存或最小占用内存的梯度更新当前进程的内存阈值。
较佳地,所述的内存记录模块进程的内存释放过程进行记录并监控,具体包括以下步骤:
(3-7)进程申请内存释放;
(3-8)钩子函数检查当前释放的内存的元数据是否被记录,如果是,则删除元数据并继续步骤(3-9),否则,继续步骤(3-9);
(3-9)释放进程的内存。
较佳地,所述的步骤(4)包括以下步骤:
(4-1)根据内存监控模块获取的数据,通过比较任意两次内存申请的数据获得内存增加的元数据表;
(4-2)合并所述的元数据表并生成对应的调试信息,对信息进行排序;
(4-3)根据所述的调试信息生成可视化图标和调试信息表。
采用了该发明中的内存异常增长的检测系统及方法,实现了内存异常增长的检测和统计,基于钩子函数并不改动内存申请逻辑,可以在进程运行同时自由启动和关闭;可以检测到任意短时间内的内存突发性增长,对于内存非泄露性质的异常增长的检测效果显著;对于生命周期长的进程的内存泄露,该方案能较准确定位泄露位置并提供可靠的调试数据;通过分析任意一次内存增长前后的内存信息,可以获得内存增长点和图表统计数据;通过比对多个图表,在一定程度上排除噪点,增加判断内存异常位置的准确性。
附图说明
图1为本发明的内存异常增长的检测系统的示意图。
图2为本发明的内存异常增长的检测系统的数据交互的示意图。
图3为本发明的内存异常增长的检测方法的注册钩子函数的示意图。
图4为本发明的内存异常增长的检测方法的内存申请的示意图。
图5为本发明的内存异常增长的检测方法的内存释放的示意图。
具体实施方式
为了能够更清楚地描述本发明的技术内容,下面结合具体实施例来进行进一步的描述。
为了解决特殊情况下出现的内存非泄露性异常增长的情况和系统级生命周期的进程内存泄露的问题,并实现检测内存异常增长,本发明提出了一种内存异常增长的检测系统,请参阅图1所示,该系统包括三个模块:
一、内存记录模块,用于记录所有已经申请的内存的元数据信息,包括内存大小等。
1、基于钩子函数原理,在系统内存申请和释放的同时,记录下相关元数据信息,所谓的钩子函数,就是在正常的调用中插入一个函数或接口,而这个函数或接口可以继续后续的正常调用,也可以预先处理数据,或者直接返回,本发明里,钩子函数实现是预先处理数据,之后继续后续的正常调用。
二、内存监控模块,用于监控目标进程的已使用内存,并在出现内存异常增长并增长达到阈值记录下内存记录模块所保存的数据。
1、由于内存申请的钩子函数并不改动内存申请逻辑,所以该监控模块可以在进程运行时,随时启动和关闭。
2、基于内存增长阈值作为触发条件,该方案可以检测到任意短时间内的内存突发性增长,即使是在内存增长后立即释放。所以,对于内存非泄露性质的异常增长的检测,效果显著。
3、基于内存增长阈值作为触发条件,该方案可以检测与系统生命周期等长的进程内存泄露情况。但是,为了避免第2点的情况带来误差,建议是在进程内存稳定后开启检测,内存增长阈值至少为1M,并且多次抓取内存变化的数据。所以,对于生命周期长的进程的内存泄露,该方案能较准确定位泄露位置并提供可靠的调试数据。
三、数据分析模块,该模块用于分析内存监控模块所导出的所有数据,将所有之前抓取的元数据转换成相应调试信息并生成可视化信息,显示内存异常增长的总大小和各个内存申请点所申请内存的大小和百分比。
1、通过分析任意一次内存增长前后的内存信息,可以获得内存增长点和图表统计数据。
2、通过比对多个图表,在一定程度上排除噪点,增加判断内存异常位置的准确性。
在一种具体的实施方式中,该内存异常增长的检测系统,包括:
内存记录模块,用于注册钩子函数并记录所有已经申请的内存的元数据;
内存监控模块,用于监控目标进程的已使用内存,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据;
数据分析模块,用于分析内存监控模块的所有数据,将元数据转换成调试信息并生成可视化信息,显示内存异常增长的总大小和各个内存申请点所申请内存的大小和百分比。
以上三个模块的信息交互关系和数据流请参阅图2所示,这三个模块在完整的控制流程中的运作方式如下所述:
一、进程启动注册钩子函数,请参阅图3所示:
11、进程启动;
12、注册钩子函数。
二、内存监控模块监控进程内存使用
21、内存申请,请参阅图4所示:
211、应用申请内存,具体是指应用发起内存申请的请求,具体到代码层面是调用内存分配函数;
212、钩子函数记录内存元数据并保存到哈希表,在该方案中使用哈希表的原因是快,内存申请必须要快,最好是在添加“钩子函数”后,尽量不影响内存申请速度,否则可能会造成应用运行异常(比如时序改变,交互响应变慢等),所以,任何足够快的数据结构或者算法,都可以替换掉哈希表的实现;
213、向系统申请内存,具体是指向底层的内存池(如果基础库实现了内存池功能)或者向内核申请内存(如果基础库未实现内存池功能),其中,基础库是指进程运行所必须的库,比如libc等库,在申请完内存后,进程就可以占用和使用相应的内存;
214、检查内存占用是否达到阈值;
215、如果内存达到阈值,则通知内存监控模块记录当前进程内存所有信息,并更新内存阈值,本方案的功能是抓取应用内存的异常增长,而内存的涨跌是最不可预测的,应用可以在某个时间申请很大内存,用完立即释放,更新内存阈值,就可以多次基于不同的阈值情况下抓取相应的数据,数据分析模块可以基于这些数据分析出该单次内存的申请,也可以从统计的信息中,分析出该次内存被正常释放了;更新阈值的方法涉及到具体的实现,可根据需求实现不同的方法,目前有的实现方法是:1、基于最大占用内存(或最小占用内存)的稳步更新,比如说,设定内存增长步长为1M,则每次阈值更新都是基于当前内存占用的基础上增加1M,该实现适用于开发人员了解该应用的内存增长情况;2、基于最大占用内存(或最小占用内存)的梯度更新,比如说,设定内存增长基础步长为1M,则每次更新阈值在当前步长的基础上增加一定的值,比如下次步长变成2M,再下次4M,该实现方法适用于开发人员不清楚应用的内存增长情况。
22、内存释放,请参阅图5所示:
221、钩子函数检查当前释放内存是否被记录;
222、如果记录,则从哈希表中删除相关数据,本方案的目的是检测内存异常增长,而异常增长的原因就是只有内存申请,未有内存释放,而数据分析模块是要分析并生成所有只申请内存未释放的数据并转换成可视化信息,所以,在有内存释放的时候,代表这块被释放的内存不属于异常增长点,就要删除相应的元数据记录,避免被统计到最后的调试信息和可视化信息中;
223、释放内存,即将内存返回给内存池或者是内核,需要注意的是释放内存并不是关闭应用,而是应用发起的跟申请内存相对应的行为。
三、数据分析模块分析并生成可视化数据和调试信息
31、基于内存监控模块获取的数据,任意两次之间进行比较获得内存增加的元数据表;
32、基于步骤31生成的表进一步合并和生成对应的调试信息,并基于内存增长的从大到小排序;
33、基于步骤32生成可视化图标和调试信息表,用于开发人员的分析和快速定位。
在一种具体的实施方式中,本发明还包括一种基于上述系统实现内存异常增长的检测方法,所述的方法包括以下步骤:
(1)在进程启动时通过所述的内存记录模块注册钩子函数;
(2)所述的内存记录模块对进程的内存申请和释放过程进行记录;
(3)所述的内存监控模块对内存的使用情况进行监控,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据;
(4)所述的数据分析模块分析并生成可视化数据和调试信息。
在一种较佳的实施方式中,所述的步骤(3)包括以下步骤:
(3-1)应用发起内存申请的请求;
(3-2)通过所述的钩子函数记录内存元数据并保存到哈希表;
(3-3)向系统申请内存;
(3-4)检查内存占用是否超过阈值,如果是,则继续步骤(3-5),否则,完成本次内存申请的监控;
(3-5)通知内存监控模块记录当前进程的所有内存信息;
(3-6)更新当前进程的内存阈值。
在一种更佳的实施方式中,所述的更新当前进程的内存阈值,具体为:
基于最大占用内存或最小占用内存的稳步更新当前进程的内存阈值,或者基于最大占用内存或最小占用内存的梯度更新当前进程的内存阈值。
在一种较佳的实施方式中,所述的内存记录模块进程的内存释放过程进行记录并监控,具体包括以下步骤:
(3-7)进程申请内存释放;
(3-8)钩子函数检查当前释放的内存的元数据是否被记录,如果是,则删除元数据并继续步骤(3-9),否则,继续步骤(3-9);
(3-9)释放进程的内存。
在一种较佳的实施方式中,所述的步骤(4)包括以下步骤:
(4-1)根据内存监控模块获取的数据,通过比较任意两次内存申请的数据获得内存增加的元数据表;
(4-2)合并所述的元数据表并生成对应的调试信息,对信息进行排序;
(4-3)根据所述的调试信息生成可视化图标和调试信息表。
在具体实现中,钩子函数的内容就是内存记录模块,内存元数据的核心内容有:内存申请调用的堆栈信息和当前申请的内存大小,钩子函数将该这些信息获取,以堆栈和请求的内存大小为依据在哈希表中查找,若对象已存在,则增加内存申请的次数,以表示该堆栈该大小的内存再次被申请了,而哈希表属于全局变量,可以被内存记录模块和内存监控模块共同所访问。
采用了该发明中的内存异常增长的检测系统及方法,实现了内存异常增长的检测和统计,基于钩子函数并不改动内存申请逻辑,可以在进程运行同时自由启动和关闭;可以检测到任意短时间内的内存突发性增长,对于内存非泄露性质的异常增长的检测效果显著;对于生命周期长的进程的内存泄露,该方案能较准确定位泄露位置并提供可靠的调试数据;通过分析任意一次内存增长前后的内存信息,可以获得内存增长点和图表统计数据;通过比对多个图表,在一定程度上排除噪点,增加判断内存异常位置的准确性。
在此说明书中,本发明已参照其特定的实施例作了描述。但是,很显然仍可以作出各种修改和变换而不背离本发明的精神和范围。因此,说明书和附图应被认为是说明性的而非限制性的。

Claims (5)

1.一种内存异常增长的检测系统,其特征在于,所述的系统包括:
内存记录模块,用于注册钩子函数并记录所有已经申请的内存的元数据;
内存监控模块,用于监控目标进程的已使用内存,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据;
数据分析模块,用于分析内存监控模块的所有数据,将元数据转换成调试信息并生成可视化信息,显示内存异常增长的总大小和各个内存申请点所申请内存的大小和百分比;
所述的内存异常增长的检测系统进行内存异常增长的检测操作,其中,所述的内存异常增长的检测操作进行以下处理:
(1)在进程启动时通过所述的内存记录模块注册钩子函数;
(2)所述的内存记录模块对进程的内存申请和释放过程进行记录;
(3)所述的内存监控模块对内存的使用情况进行监控,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据,具体包括以下步骤:
(3-1)应用发起内存申请的请求;
(3-2)通过所述的钩子函数记录内存元数据并保存到哈希表;
(3-3)向系统申请内存;
(3-4)检查内存占用是否超过阈值,如果是,则继续步骤(3-5),否则,完成本次内存申请的监控;
(3-5)通知内存监控模块记录当前进程的所有内存信息;
(3-6)更新当前进程的内存阈值;
(4)所述的数据分析模块分析并生成可视化数据和调试信息。
2.一种基于权利要求1所述的系统实现内存异常增长的检测方法,其特征在于,所述的方法包括以下步骤:
(1)在进程启动时通过所述的内存记录模块注册钩子函数;
(2)所述的内存记录模块对进程的内存申请和释放过程进行记录;
(3)所述的内存监控模块对内存的使用情况进行监控,并在出现内存异常增长且熬过阈值时记录所述的内存记录模块所保存的元数据,具体包括以下步骤:
(3-1)应用发起内存申请的请求;
(3-2)通过所述的钩子函数记录内存元数据并保存到哈希表;
(3-3)向系统申请内存;
(3-4)检查内存占用是否超过阈值,如果是,则继续步骤(3-5),否则,完成本次内存申请的监控;
(3-5)通知内存监控模块记录当前进程的所有内存信息;
(3-6)更新当前进程的内存阈值;
(4)所述的数据分析模块分析并生成可视化数据和调试信息。
3.根据权利要求2所述的内存异常增长的检测方法,其特征在于,所述的更新当前进程的内存阈值,具体为:
基于最大占用内存或最小占用内存的稳步更新当前进程的内存阈值,或者基于最大占用内存或最小占用内存的梯度更新当前进程的内存阈值。
4.根据权利要求2所述的内存异常增长的检测方法,其特征在于,所述的内存记录模块进程的内存释放过程进行记录并监控,具体包括以下步骤:
(3-7)进程申请内存释放;
(3-8)钩子函数检查当前释放的内存的元数据是否被记录,如果是,则删除元数据并继续步骤(3-9),否则,继续步骤(3-9);
(3-9)释放进程的内存。
5.根据权利要求2所述的内存异常增长的检测方法,其特征在于,所述的步骤(4)包括以下步骤:
(4-1)根据内存监控模块获取的数据,通过比较任意两次内存申请的数据获得内存增加的元数据表;
(4-2)合并所述的元数据表并生成对应的调试信息,对信息进行排序;
(4-3)根据所述的调试信息生成可视化图标和调试信息表。
CN201710232891.7A 2017-04-11 2017-04-11 内存异常增长的检测系统及方法 Active CN106997316B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710232891.7A CN106997316B (zh) 2017-04-11 2017-04-11 内存异常增长的检测系统及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710232891.7A CN106997316B (zh) 2017-04-11 2017-04-11 内存异常增长的检测系统及方法

Publications (2)

Publication Number Publication Date
CN106997316A CN106997316A (zh) 2017-08-01
CN106997316B true CN106997316B (zh) 2020-02-21

Family

ID=59434468

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710232891.7A Active CN106997316B (zh) 2017-04-11 2017-04-11 内存异常增长的检测系统及方法

Country Status (1)

Country Link
CN (1) CN106997316B (zh)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110457179A (zh) * 2019-07-29 2019-11-15 Oppo广东移动通信有限公司 系统检测方法、内存监控方法、装置、介质与电子设备
CN110618905B (zh) * 2019-08-06 2023-05-09 晶晨半导体(深圳)有限公司 一种检测ddr内存模块中异常ddr内存的方法
CN112783711A (zh) * 2019-11-01 2021-05-11 福建省天奕网络科技有限公司 NodeJS上程序内存分析的方法、存储介质
CN111190833B (zh) * 2019-11-26 2023-03-24 腾讯云计算(北京)有限责任公司 敏感数据检测方法、装置、存储介质及设备
CN113326120B (zh) * 2020-02-29 2023-12-26 杭州迪普科技股份有限公司 管理内存的装置和方法
CN114253825A (zh) * 2020-09-22 2022-03-29 腾讯科技(深圳)有限公司 内存泄漏检测方法、装置、计算机设备和存储介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20060059759A (ko) * 2004-11-29 2006-06-02 주식회사 안철수연구소 컴퓨터 응용 프로그램의 메모리 데이터 조작 방지 방법
CN101561775A (zh) * 2009-05-12 2009-10-21 华为技术有限公司 内存监控方法和装置
CN103514086A (zh) * 2013-09-22 2014-01-15 广东威创视讯科技股份有限公司 一种软件错误报告的提取方法及装置
CN103617133A (zh) * 2013-12-06 2014-03-05 北京奇虎科技有限公司 一种Windows系统中虚拟内存压缩方法和装置
CN104965861A (zh) * 2015-06-03 2015-10-07 上海新炬网络信息技术有限公司 一种数据访问监控装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20060059759A (ko) * 2004-11-29 2006-06-02 주식회사 안철수연구소 컴퓨터 응용 프로그램의 메모리 데이터 조작 방지 방법
CN101561775A (zh) * 2009-05-12 2009-10-21 华为技术有限公司 内存监控方法和装置
CN103514086A (zh) * 2013-09-22 2014-01-15 广东威创视讯科技股份有限公司 一种软件错误报告的提取方法及装置
CN103617133A (zh) * 2013-12-06 2014-03-05 北京奇虎科技有限公司 一种Windows系统中虚拟内存压缩方法和装置
CN104965861A (zh) * 2015-06-03 2015-10-07 上海新炬网络信息技术有限公司 一种数据访问监控装置

Also Published As

Publication number Publication date
CN106997316A (zh) 2017-08-01

Similar Documents

Publication Publication Date Title
CN106997316B (zh) 内存异常增长的检测系统及方法
US9569338B1 (en) Fingerprint-initiated trace extraction
US10860465B2 (en) Automatically rerunning test executions
US10474565B2 (en) Root cause analysis of non-deterministic tests
CN108038039B (zh) 记录日志的方法及微服务系统
CN107678972B (zh) 一种测试用例的评估方法及相关装置
CN109298987B (zh) 一种检测网络爬虫运行状态的方法及装置
CA2811617C (en) Commit sensitive tests
CN113407419B (zh) 内存泄漏检测方法、装置、计算机设备和存储介质
US20170344461A1 (en) Automated exception resolution during a software development session based on previous exception encounters
US20120124428A1 (en) Method and system for testing software on programmable devices
CN106776255B (zh) 智能电视系统的日志提取方法及装置
CN110417621B (zh) 一种轻量级嵌入式系统异常运行状态检测方法
US10372513B2 (en) Classification of application events using call stacks
US8291389B2 (en) Automatically detecting non-modifying transforms when profiling source code
CN112577664A (zh) 传感器故障检测方法、装置及相关产品
CN115757138A (zh) 脚本异常原因的确定方法、装置、存储介质以及电子设备
CN114546799A (zh) 埋点日志校验方法、装置、电子设备、存储介质及产品
CN113708986B (zh) 服务器监控装置、方法及计算机可读存储介质
CN106610833B (zh) 一种触发重叠html元素鼠标事件的方法及装置
US20180052728A1 (en) Root cause candidate determination in multiple process systems
CN109165127B (zh) 问题接口的定位方法、装置及电子设备
CN109976970B (zh) 一种提高主板芯片使用寿命的方法、系统及存储介质
CN108763092B (zh) 一种基于交叉验证的代码缺陷检测方法及装置
CN108234196B (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