[发明专利]一种应用程序耗时的分析方法、装置、设备及存储介质在审
| 申请号: | 202010746359.9 | 申请日: | 2020-07-29 |
| 公开(公告)号: | CN114064378A | 公开(公告)日: | 2022-02-18 |
| 发明(设计)人: | 宋金时 | 申请(专利权)人: | 北京字节跳动网络技术有限公司 |
| 主分类号: | G06F11/30 | 分类号: | G06F11/30;G06F11/34 |
| 代理公司: | 北京开阳星知识产权代理有限公司 11710 | 代理人: | 王雪 |
| 地址: | 100041 北京市石景山区*** | 国省代码: | 北京;11 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 应用程序 耗时 分析 方法 装置 设备 存储 介质 | ||
1.一种应用程序耗时的分析方法,其特征在于,所述方法包括:
通过钩子技术代理目标应用程序中的耗时目标函数;其中,所述耗时目标函数包括跨进程调用函数和/或输入输出调用函数族;
基于对所述耗时目标函数的代理,在所述耗时目标函数执行的开始时刻和结束时刻分别插桩;
基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析。
2.根据权利要求1所述的方法,其特征在于,所述基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析之前,还包括:
通过所述钩子技术代理所述目标应用程序中的写函数;其中,所述预设类型数据包括通过所述插桩采集到的追踪数据;
基于对所述写函数的代理,在所述写函数执行的过程中将预设类型数据写入预设追踪文件中;
相应的,所述基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析,包括:
基于所述预设追踪文件中的所述追踪数据,对所述目标应用程序的耗时进行分析。
3.根据权利要求1所述的方法,其特征在于,所述基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析之前,还包括:
将目标应用程序中的虚拟机锁信息开关设置为打开状态;
对所述目标应用程序的锁信息进行采集;
相应的,所述基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析,包括:
基于采集到的锁信息和通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析。
4.根据权利要求1所述的方法,其特征在于,所述通过钩子技术代理目标应用程序中的耗时目标函数之前,还包括:
将目标应用程序中的插桩开关设置为打开状态;其中,所述插桩开关为打开状态表示所述目标应用程序允许插桩操作。
5.根据权利要求1所述的方法,其特征在于,所述基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析之前,还包括:
在预设函数执行的开始时刻和结束时刻分别插桩;
通过所述插桩采集所述预设函数对应的追踪数据;
相应的,所述基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析,包括:
基于所述预设函数对应的追踪数据和通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析。
6.一种应用程序耗时的分析装置,其特征在于,所述装置包括:
第一代理模块,用于通过钩子技术代理目标应用程序中的耗时目标函数;其中,所述耗时目标函数包括跨进程调用函数和/或输入输出调用函数族;
插桩模块,用于基于对所述耗时目标函数的代理,在所述耗时目标函数执行的开始时刻和结束时刻分别插桩;
分析模块,用于基于通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析。
7.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第二代理模块,用于通过所述钩子技术代理所述目标应用程序中的写函数;其中,所述预设类型数据包括通过所述插桩采集到的追踪数据;
写入模块,用于基于对所述写函数的代理,在所述写函数执行的过程中将预设类型数据写入预设追踪文件中;
相应的,所述分析模块,具体用于:
基于所述预设追踪文件中的所述追踪数据,对所述目标应用程序的耗时进行分析。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第一设置模块,用于将目标应用程序中的虚拟机锁信息开关设置为打开状态;
采集模块,用于对所述目标应用程序的锁信息进行采集;
相应的,所述分析模块,具体用于:
基于采集到的锁信息和通过所述插桩采集到的追踪数据,对所述目标应用程序的耗时进行分析。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京字节跳动网络技术有限公司,未经北京字节跳动网络技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010746359.9/1.html,转载请声明来源钻瓜专利网。





