进程查找方法和装置的制造方法

xiaoxiao2021-2-28  191

进程查找方法和装置的制造方法
【技术领域】
[0001 ]本公开涉及通信领域,尤其涉及进程查找方法和装置。
【背景技术】
[0002]在Android系统优化的过程中,往往需要查看系统的各项指标,比如CPU占用,内存消耗等等。但是,系统运行缓慢的瓶颈往往都是由于某些进程占用10过高导致的,因此查找占用10最高的进程对于Android系统优化具有重要意义。

【发明内容】

[0003]为克服相关技术中存在的问题,本公开提供一种进程查找方法和装置。
[0004]根据本公开实施例的第一方面,提供一种进程查找方法,所述方法包括:
[0005]检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0006]针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0007]查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0008]可选的,所述在预设时间段内的进程日志中检索携带预设关键词的进程日志之前,所述方法还包括:
[0009]基于用户输入的命令输出各进程的进程日志;
[0010]获取用户设置的预设时间段;
[0011 ]从输出的进程日志中读取所述预设时间段内各进程的进程日志。
[0012]可选的,所述针对检索到的所述进程日志中进程号相同的日志条目进行数量统计之前,所述方法还包括:
[0013]基于预设策略清除检索到的所述进程日志中的无效进程日志。
[0014]可选的,所述基于预设策略清除检索到的所述进程日志中的无效进程日志包括:
[0015]遍历检索到的所述进程日志;
[0016]筛选所述进程日志中携带非字母字符的日志条目;
[0017]将筛选出的所述携带非字母字符的日志条目作为无效进程日志清除。
[0018]可选的,所述针对检索到的所述进程日志中进程号相同的日志条目进行数量统计包括:
[0019]基于进程号对检索到的所述进程日志进行排序;
[0020]针对排序后的所述进程日志中进程号相同的日志条目进行数量统计并进行计数。
[0021]可选的,所述方法还包括:
[0022]将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出。
[0023]可选的,所述方法还包括:
[0024]将所述计数最大的计数值作为10资源占用数量与所述计数最大的进程号关联输出。
[0025]可选的,所述预设关键词包括:READ、WRITE以及dirtied中的一个或者多个。
[0026]根据本公开实施例的第二方面,提供一种进程查找装置,所述装置包括:
[0027]检索模块,被配置为检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0028]统计模块,被配置为针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0029]查找模块,被配置查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0030]可选的,所述装置还包括:
[0031]第一输出模块,被配置为基于用户输入的命令输出各进程的进程日志;
[0032]获取模块,被配置为获取用户设置的预设时间段;
[0033]读取模块,被配置为从输出的进程日志中读取所述预设时间段内各进程的进程日
ν.、ι、ο
[0034]可选的,所述装置还包括:
[0035]清除模块,被配置为在所述统计模块针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数之前,基于预设策略清除检索到的所述进程日志中的无效进程日志。
[0036]可选的,所述清除模块包括:
[0037]遍历子模块,被配置为遍历检索到的所述进程日志;
[0038]筛选子模块,被配置为筛选所述进程日志中携带非字母字符的日志条目;
[0039]清除子模块,被配置为将筛选出的所述携带非字母字符的日志条目作为无效进程日志清除。
[0040]可选的,所述统计模块包括:
[0041 ]排序子模块,被配置为基于进程号对检索到的所述进程日志进行排序;
[0042]统计子模块,被配置为针对排序后的所述进程日志中进程号相同的日志条目进行数量统计并进行计数。
[0043]可选的,所述装置还包括:
[0044]第二输出模块,被配置为将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出。
[0045]可选的,所述装置还包括:
[0046]第三输出模块,被配置为将所述计数最大的计数值作为10资源占用数量与所述计数最大的进程号关联输出。
[0047]可选的,所述预设关键词包括:READ、WRITE以及dirtied中的一个或者多个。
[0048]根据本公开实施例的第三方面,提供一种进程查找装置,包括:
[0049]处理器;
[0050]用于存储处理器可执行指令的存储器;
[0051 ]其中,所述处理器被配置为:
[0052]检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0053]针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0054]查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0055]本公开的实施例提供的技术方案可以包括以下有益效果:
[0056]本公开的以上实施例中,通过检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号,可以实现为用户查找当前系统中占用10资源最高的进程,从而为用户的系统优化提供依据。
[0057]应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
【附图说明】
[0058]此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
[0059]图1是根据一示例性实施例示出的一种进程查找方法的流程示意图;
[0060]图2是根据一示例性实施例示出的另一种进程查找方法的流程示意图;
[0061 ]图3是根据一示例性实施例示出的一种进程查找装置的示意框图;
[0062]图4是根据一示例性实施例示出的另一种进程查找装置的示意框图;
[0063]图5是根据一示例性实施例示出的另一种进程查找装置的示意框图;
[0064]图6是根据一示例性实施例示出的另一种进程查找装置的示意框图;
[0065]图7是根据一示例性实施例示出的另一种进程查找装置的示意框图;
[0066]图8是根据一示例性实施例示出的另一种进程查找装置的示意框图;
[0067]图9是根据一示例性实施例示出的另一种进程查找装置的示意框图;
[0068]图10是根据一示例性实施例示出的一种用于进程查找装置的一结构示意图;
[0069]图11是根据一示例性实施例示出的另一种用于进程查找装置的一结构示意图。
【具体实施方式】
[0070]这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
[0071]在本公开使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本公开。在本公开和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包含一个或多个相关联的列出项目的任何或所有可能组合。
[0072]应当理解,尽管在本公开可能采用术语第一、第二、第三等来描述各种信息,但这些信息不应限于这些术语。这些术语仅用来将同一类型的信息彼此区分开。例如,在不脱离本公开范围的情况下,第一信息也可以被称为第二信息,类似地,第二信息也可以被称为第一信息。取决于语境,如在此所使用的词语“如果”可以被解释成为“在……时”或“当……时”或“响应于确定”。
[0073]在相关技术中,在针对系统(例如Android系统)进行优化的过程中,在各项系统指标正常的情况下,通常需要找出当前系统最占用10(Input Output输入输出)的进程。然而,目前系统并未提供简单方便的监控当前系统中占用10过高的进程的实现方法。
[0074]有鉴于此,本公开提出一种进程查找方法,通过检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号,可以实现为用户查找当前系统中占用10资源最高的进程,从而为用户的系统优化提供依据。
[0075]如图1所示,图1是根据一示例性实施例示出的一种进程查找方法,该进程查找方法用于客户端中,包括以下步骤:
[0076]在步骤101中,检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0077]在步骤102中,针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0078]在步骤103中,查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0079]上述客户端可以包括面向系统维护人员提供进程查找服务的客户端软件;例如,以android系统为例,该客户端软件可以是面向android系统维护人员提供进程查找服务的查找工具,开发人员可以通过该查找工具来查找android系统中当前占用10资源最多的进程。
[ 0080]其中,承载上述客户端软件的硬件环境,在本实施例中不进行特别限定;例如,可以是PC主机、移动终端或者服务器。
[0081]在本实施例中,系统维护人员在对系统进行优化的过程中,往往需要查看系统的各项运行指标,比如系统的CPU占用率,内存消耗率等等。然而,在实际应用中,系统运行缓慢的瓶颈往往都是由于某些进程占用10资源过高导致的,因此查找系统中当前占用10资源最高的进程,对于系统的优化就变的十分有必要。
[0082]目前,系统维护人员在需要查找系统进程时,通常都是通过使用诸如blockdump等系统工具,在block dump界面中编辑特定的输出命令来完成的。当block dump工具检测到用户编辑的输出命令后,则可以在界面中将系统中当前正在运行的各进程的日志文件(log文件)在界面中向系统维护人员输出。
[0083]例如,对于block dump工具来说,系统维护人员通常可以在block dump工具的界面中编辑dmesg命令,来触发block dump工具输出系统当前各进程的log文件。
[0084]然而,系统维护人员通过使用blockdump等系统工具,虽然可以很方便的查看系统中各进程的日志文件,然后现有的诸如block dump等系统工具并未提供查找系统中当前占用10最高的进程的功能,因此当系统维护人员需要对系统进行优化时,不得不逐条手动的分析block dump工具输出的日志文件。
[0085]在本实施例中,为解决上述问题,可以在现有的block dump工具中引入如上述步骤101至步骤103所示出的查找逻辑,使得现有的block dump工具具有查找系统中当前占用10资源最高的进程的这一新功能,从而系统维护人员可以使用block dump工具快捷的查找出系统中当前占用10资源最高的进程,为系统优化提供依据。
[0086]以下以上述客户端软件为具有查找系统中当前占用10资源最高的进程功能的block dump工具为例进行说明。
[0087]当然,以上以上述客户端软件为具有查找系统中当前占用10资源最高进程的功能的block dump工具为例仅为示例性说明,在实际应用中,也可以基于步骤101至步骤103的查找逻辑开发出新的系统工具。即,上述客户端软件可以是具有查找系统中当前占用10资源最高进程的这一新功能的现有系统工具,也可以是重新开发的新的系统工具。
[0088]在初始状态下,当系统维护人员需要查找某一时间段内,系统中最占用10资源的进程,可以运行block dump工具,在block dump工具的界面中编辑dmesg命令,来触发blockdump工具输出系统当前各进程的log文件。
[0089]其中,上述时间段可以由系统维护人员自定义设置。
[°09°]在实现时,block dump工具中可以面向系统维护人员提供一个用于设置上述时间段的用户选项,系统维护人员可以在该用户选项中设置预设的时间段,当该预设的时间段设置完成后,此时block dump工具可以运行上述查找逻辑来查找在这一预设的时间段内,系统中最占用10资源的进程。
[0091]例如,假设用户设置的上述预设时间段为30分钟,那么block dump工具可以运行上述查找逻辑来查找,从当前时间开始到30分钟以后,系统中最占用10资源的进程。
[0092]在本实施例中,当输出系统当前各进程的log文件后,此时blockdump工具可以在后台获取用户设置的上述预设的时间段,然后从输出的log文件中读取该预设时间段内各进程的log文件。
[0093]例如,仍假设用户设置的上述预设时间段为30分钟,那么block dump工具可以在后台从输出的各进程的log文件中,读取从当前时间开始,30分钟以内的各进程的log文件。
[0094]当blockdump工具读取到在上述预设的时间段内的各进程的log文件后,此时block dump工具可以在读取到的这些log文件中,检索携带预设关键词的log文件。其中,该预设关键词可以表征当前进程占用10资源,即该预设关键词可以包括那些表征当前进程占用10资源的关键词。
[0095]对于block dump工具来说,输出的log文件中通常包括进程号、Inode号(数据读写的索引节点编号)、该进程执行的动作、文件名、磁盘名以及设备名等信息,而该log文件中携带的该进程执行的动作通常可以表征该进程是否正在占用10资源。例如,进程占用10资源时所生成的log文件中,通常可以包括READ、WRITE和dirtied等动作,READ表示当前进程参与了数据读取,WRITE表示当前进程参与了数据写入,而dirtied则表示当前进程参与了数据回写。
[0096]因此,在实际应用中,上述可以表征当前进程占用10资源的预设关键词则可以包括READ、WRITE和dirtied等关键词中的一个或者多个。block dump工具在从读取到的上述预设的时间段内的各进程的log文件中,检索携带预设关键词的log文件时,可以检索读取到的log文件中携带READ、WRITE和dirtied等关键词的log文件。
[0097]在本实施例中,当blockdump工具检索到携带上述预设关键词的log文件后,由于这些log文件中还可能包括一些无效log文件,因此block dump工具还可以基于预设策略清除检索到的这些log文件中的无效log文件。
[0098]其中,在blockdump工具中,进程占用10资源时所生成的log文件通常只包含字母,而不存在非字母的字符,因此如果block dump工具检索到的log文件中包含非字母的字符,那么该log文件很可能为无效log文件。
[0099]因此,在示出的一种实施方式中,上述预设策略可以包括:遍历检索到的log文件,筛选检索到的log文件中携带非字母字符的log条目,然后将筛选出的携带非字母字符的log条目作为无效log文件清除。
[0100]可见,通过这种方式,可以有效清除检索到的log文件中的无效log文件,从而在后续对检索到的log文件进行数量统计来查找占用10资源最高的进程时,可以避免由于无效log文件对最终查找结果造成干扰,而导致的查找结果不理想的情况。
[0101]在本实施例中,由于log文件中通常可以包括进程号,而某一个进程占用10资源越多时,block dump工具检索到的这些log文件中包含该进程的进程号的log文件也越多。
[0102]因此,当blockdump工具基于预设策略清除了检索到的log文件中的无效log文件后,block dump工具可以针对检索到的这些log文件中进程号相同的log条目进行数量统计并进行计数,并查找计数最大的进程号作为预设时间段内占用10资源最多的进程号,然后将查找到的计数最大的进程号输出。此时输出的该进程号则为预设时间段内占用10资源最多的进程号。
[0?03]其中,block dump工具在针对检索到的这些log文件中进程号相同的log条目进行数量统计并进行计数时,可以基于进程号对检索到的这些log文件进行排序,然后针对排序后这些log文件中进程号相同的log条目进行数量统计并进行计数。通过这种方式,可以降低block dump工具在进行数量统计时的复杂度。
[0104]block dump在将计数最大的进程号输出时,可以输出一个也可以输出多个。即block dump在输出进程号时,可以将统计出的计数最大的一个进程号向系统维护人员输出,也可以将统计出的计数最大的多个进程号向系统维护人员输出。
[0105]另外,blockdump在将计数最大的进程号输出时,具体输出的进程号的个数也可以由系统维护人员基于实际的需求进行设定。
[0106]例如,系统维护人员在进行系统优化时,如果当前系统的运行状态尚可,此时系统维护人员可能只需要针对占用10最高的一个进程进行优化,此时系统维护人员可以将上述输出的进程号的个数设置为1。如果当前系统的运行缓慢,此时系统维护人员可能需要针对占用10最高的多个进程进行优化,此时系统维护人员可以将上述输出的进程号的个数设置为多个。
[0107]在本实施例中,blockdump除了可以将计数最大的进程号向系统维护人员输出以夕卜,还可以将计数最大的计数值与上述进程号进行关联输出。其中,block dump在计数最大的计数值与上述计数最大的进程号关联输出时,仍然可以输出一个也可以输出多个。
[0108]例如,假设blockdump对检索到的log文件中进程号相同的log条目进行数量统计后得出,这些log文件中进程号相同的log条目的最大计数为100,对应的相同进程号为1,那么block dump可以将该进程号1作为预设时间段内占用10资源最多的进程号向系统维护人员输出,同时将该进程号1对应的最大计数100,作为该进程的10资源占用数量与该进程号1关联输出。从而,系统维护人员通过查看block dump输出的内容,既可以了解到当前最占用10资源的进程号,也可以了解到该进程具体占用的10资源数量。
[0109]可见,通过这种方式,系统维护人员可以使用blockdump工具快捷的查找出系统中当前占用10资源最高的进程,为系统优化提供依据。
[0110]当blockdump向系统维护人员输出了在预设的时间段内占用10资源最多的进程号以及关联的10资源占用数量后,此时系统维护人员可以将block dump输出的内容作为系统优化的依据,对系统进行优化。例如,如果系统当前运行缓慢,系统维护人员可以选择结束当前占用10资源最高的一个或者多个进程,以释放系统的处理压力达到系统优化的目的。
[0111]在以上实施例中,通过检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号,可以实现为用户查找当前系统中占用10资源最高的进程,从而为用户的系统优化提供依据。
[0112]如图2所示,图2是根据一示例性实施例示出的另一种进程查找方法,该进程查找方法用于客户端中,所述方法包括以下步骤:
[0113]在步骤201中,基于用户输入的命令输出各进程的进程日志;
[0114]在步骤202中,获取用户设置的预设时间段;
[0115]在步骤203中,从输出的进程日志中读取所述预设时间段内各进程的进 程日志;
[0116]在步骤204中,检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0117]在步骤205中,基于进程号对检索到的所述进程日志进行排序;
[0118]在步骤206中,针对排序后的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0119]在步骤207中,查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号,并将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出,以及将所述计数最大的计数值作为10资源占用数量与所述计数最大的进程号关联输出。
[0120]上述客户端可以包括面向系统维护人员提供进程查找服务的客户端软件;例如,以android系统为例,该客户端软件可以是面向android系统维护人员提供进程查找服务的查找工具,开发人员可以通过该查找工具来查找android系统中当前占用10资源最多的进程。
[0121]其中,承载上述客户端软件的硬件环境,在本实施例中不进行特别限定;例如,可以是PC主机、移动终端或者服务器。
[0122]在本实施例中,系统维护人员在对系统进行优化的过程中,往往需要查看系统的各项运行指标,比如系统的CPU占用率,内存消耗率等等。然而,在实际应用中,系统运行缓慢的瓶颈往往都是由于某些进程占用10资源过高导致的,因此查找系统中当前占用10资源最高的进程,对于系统的优化就变的十分有必要。
[0123]目前,系统维护人员在需要查找系统进程时,通常都是通过使用诸如blockdump等系统工具,在block dump界面中编辑特定的输出命令来完成的。当block dump工具检测到用户编辑的输出命令后,则可以在界面中将系统中当前正在运行的各进程的日志文件(log文件)在界面中向系统维护人员输出。
[0124]例如,对于block dump工具来说,系统维护人员通常可以在block dump工具的界面中编辑dmesg命令,来触发block dump工具输出系统当前各进程的log文件。
[0125]然而,系统维护人员通过使用blockdump等系统工具,虽然可以很方便的查看系统中各进程的日志文件,然后现有的诸如block dump等系统工具并未提供查找系统中当前占用10最高的进程的功能,因此当系统维护人员需要对系统进行优化时,不得不逐条手动的分析block dump工具输出的日志文件。
[0126]在本实施例中,为解决上述问题,可以在现有的block dump工具中引入如上述步骤201至步骤207所示出的查找逻辑,使得现有的block dump工具具有查找系统中当前占用10资源最高的进程的这一新功能,从而系统维护人员可以使用block dump工具快捷的查找出系统中当前占用10资源最高的进程,为系统优化提供依据。
[0127]以下以上述客户端软件为具有查找系统中当前占用10资源最高的进程功能的block dump工具为例进行说明。
[0128]当然,以上以上述客户端软件为具有查找系统中当前占用10资源最高进程的功能的block dump工具为例仅为示例性说明,在实际应用中,也可以基于步骤201至步骤207的查找逻辑开发出新的系统工具。即,上述客户端软件可以是具有查找系统中当前占用10资源最高进程的这一新功能的现有系统工具,也可以是重新开发的新的系统工具。
[0129]在初始状态下,当系统维护人员需要查找某一时间段内,系统中最占用10资源的进程,可以运行block dump工具,在block dump工具的界面中编辑dmesg命令,来触发blockdump工具输出系统当前各进程的log文件。
[0130]其中,上述时间段可以由系统维护人员自定义设置。
[0131]在实现时,blockdump工具中可以面向系统维护人员提供一个用于设置上述时间段的用户选项,系统维护人员可以在该用户选项中设置预设的时间段,当该预设的时间段设置完成后,此时block dump工具可以运行上述查找逻辑来查找在这一预设的时间段内,系统中最占用10资源的进程。
[0132]例如,假设用户设置的上述预设时间段为30分钟,那么block dump工具可以运行上述查找逻辑来查找,从当前时间开始到30分钟以后,系统中最占用10资源的进程。
[0133]在本实施例中,当输出系统当前各进程的log文件后,此时blockdump工具可以在后台获取用户设置的上述预设的时间段,然后从输出的log文件中读取该预设时间段内各进程的log文件。
[0134]例如,仍假设用户设置的上述预设时间段为30分钟,那么block dump工具可以在后台从输出的各进程的log文件中,读取从当前时间开始,30分钟以内的各进程的log文件。
[0135]当blockdump工具读取到在上述预设的时间段内的各进程的log文件后,此时block dump工具可以在读取到的这些log文件中,检索携带预设关键词的log文件。其中,该预设关键词可以表征当前进程占用10资源,即该预设关键词可以包括那些表征当前进程占用10资源的关键词。
[0136]对于blockdump工具来说,输出的log文件中通常包括进程号、Inode号(数据读写的索引节点编号)、该进程执行的动作、文件名、磁盘名以及设备名等信息,而该log文件中携带的该进程执行的动作通常可以表征该进程是否正在占用10资源。例如,进程占用10资源时所生成的log文件中,通常可以包括READ、WRITE和dirtied等动作,READ表示当前进程参与了数据读取,WRITE表示当前进程参与了数据写入,而dirtied则表示当前进程参与了数据回写。
[0137]因此,在实际应用中,上述可以表征当前进程占用10资源的预设关键词则可以包括READ、WRITE和dirtied等关键词中的一个或者多个。block dump工具在从读取到的上述预设的时间段内的各进程的log文件中,检索携带预设关键词的log文件时,可以检索读取到的log文件中携带READ、WRITE和dirtied等关键词的log文件。
[0138]在本实施例中,当blockdump工具检索到携带上述预设关键词的log文件后,由于这些log文件中还可能包括一些无效log文件,因此block dump工具还可以基于预设策略清除检索到的这些log文件中的无效log文件。
[0139]其中,在blockdump工具中,进程占用10资源时所生成的log文件通常只包含字母,而不存在非字母的字符,因此如果block dump工具检索到的log文件中包含非字母的字符,那么该log文件很可能为无效log文件。
[0140]因此,在示出的一种实施方式中,上述预设策略可以包括:遍历检索到的log文件,筛选检索到的log文件中携带非字母字符的log条目,然后将筛选出的携带非字母字符的log条目作为无效log文件清除。
[0141]可见,通过这种方式,可以有效清除检索到的log文件中的无效log文件,从而在后续对检索到的log文件进行数量统计来查找占用10资源最高的进程时,可以避免由于无效log文件对最终查找结果造成干扰,而导致的查找结果不理想的情况。
[0142]在本实施例中,由于log文件中通常可以包括进程号,而某一个进程占用10资源越多时,block dump工具检索到的这些log文件中包含该进程的进程号的log文件也越多。
[0143]因此,当blockdump工具基于预设策略清除了检索到的log文件中的无效log文件后,block dump工具可以针对检索到的这些log文件中进程号相同的log条目进行数量统计并进行计数,并查找计数最大的进程号作为预设时间段内占用10资源最多的进程号,然后将查找到的计数最大的进程号输出。此时输出的该进程号则为预设时间段内占用10资源最多的进程号。
[0144]其中,blockdump工具在针对检索到的这些log文件中进程号相同的log条目进行数量统计并进行计数时,可以基于进程号对检索到的这些log文件进行排序,然后针对排序后这些log文件中进程号相同的log条目进行数量统计并进行计数。通过这种方式,可以降低block dump工具在进行数量统计时的复杂度。
[0145]block dump在将计数最大的进程号输出时,可以输出一个也可以输出多个。即block dump在输出进程号时,可以将统计出的计数最大的一个进程号向系统维护人员输出,也可以将统计出的计数最大的多个进程号向系统维护人员输出。
[0146]另外,blockdump在将计数最大的进程号输出时,具体输出的进程号的个数也可以由系统维护人员基于实际的需求进行设定。
[0147]例如,系统维护人员在进行系统优化时,如果当前系统的运行状态尚可,此时系统维护人员可能只需要针对占用10最高的一个进程进行优化,此时系统维护人员可以将上述输出的进程号的个数设置为1。如果当前系统的运行缓慢,此时系统维护人员可能需要针对占用10最高的多个进程进行优化,此时系统维护人员可以将上述输出的进程号的个数设置为多个。
[0148]在本实施例中,blockdump除了可以将计数最大的进程号向系统维护人员输出以夕卜,还可以将计数最大的计数值与上述进程号进行关联输出。其中,block dump在计数最大的计数值与上述计数最大的进程号关联输出时,仍然可以输出一个也可以输出多个。
[0149]例如,假设blockdump对检索到的log文件中进程号相同的log条目进行数量统计后得出,这些log文件中进程号相同的log条目的最大计数为100,对应的相同进程号为1,那么block dump可以将该进程号1作为预设时间段内占用10资源最多的进程号向系统维护人员输出,同时将该进程号1对应的最大计数100,作为该进程的10资源占用数量与该进程号1关联输出。从而,系统维护人员通过查看block dump输出的内容,既可以了解到当前最占用10资源的进程号,也可以了解到该进程具体占用的10资源数量。
[0150]可见,通过这种方式,系统维护人员可以使用blockdump工具快捷的查找出系统中当前占用10资源最高的进程,为系统优化提供依据。
[0151]当blockdump向系统维护人员输出了在预设的时间段内占用10资源最多的进程号以及关联的10资源占用数量后,此时系统维护人员可以将block dump输出的内容作为系统优化 的依据,对系统进行优化。例如,如果系统当前运行缓慢,系统维护人员可以选择结束当前占用10资源最高的一个或者多个进程,以释放系统的处理压力达到系统优化的目的。
[0152]在以上实施例中,通过检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出,可以实现为用户查找当前系统中占用10资源最高的进程,从而为用户的系统优化提供依据。
[0153]与前述进程查找方法实施例相对应,本公开还提供了进程查找装置的实施例。
[0154]图3是根据一示例性实施例示出的一种进程查找装置的示意框图。
[0155]如图3所示,根据一示例性实施例示出的一种进程查找装置30,包括:检索模块301、统计模块302和查找模块303;其中:
[0156]所述检索模块301,被配置为检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0157]所述统计模块302,被配置为针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0158]所述查找模块303,被配置为将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出。
[0159]其中,上述预设关键词可以包括:READ、WRITE以及dirtied中的一个或者多个。
[0160]在以上实施例中,通过检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出,可以实现为用户查找当前系统中占用10资源最高的进程,从而为用户的系统优化提供依据。
[0161]请参见图4,图4是本公开根据一示例性实施例示出的另一种进程查找装置框图,该实施例在前述图3所示实施例的基础上,所述装置30还可以包括第一输出模块304、获取模块305和读取模块306;其中:
[0162]所述第一输出模块304,被配置为基于用户输入的命令输出各进程的进程日志;
[0163]所述获取模块305,被配置为获取用户设置的预设时间段;
[0164]所述读取模块306,被配置为从输出的进程日志中读取所述预设时间段内各进程的进程日志。
[0165]请参见图5,图5是本公开根据一示例性实施例示出的另一种进程查找装置框图,该实施例在前述图4所示实施例的基础上,所述装置还包括清除模块307;其中:
[0166]所述清除模块307,被配置为在所述统计模块302针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数之前,基于预设策略清除检索到的所述进程日志中的无效进程日志。
[0167]需要说明的是,上述图5所示的装置实施例中示出的清除模块307的结构也可以包含在前述图3的装置实施例中,对此本公开不进行限制。
[0168]请参见图6,图6是本公开根据一示例性实施例示出的另一种进程查找装置框图,该实施例在前述图5所示实施例的基础上,所述清除模块307可以包括遍历子模块307A、筛选子模块307B和清除子模块307C;其中:
[0169]所述遍历子模块307A,被配置为遍历检索到的所述进程日志;
[0170]所述筛选子模块307B,被配置为筛选所述进程日志中携带非字母字符的日志条目;
[0171]所述清除子模块307C,被配置为将筛选出的所述携带非字母字符的日志条目作为无效进程日志清除。
[0172]需要说明的是,上述图6所示的装置实施例中示出的遍历子模块307A、筛选子模块307B和清除子模块307C的结构也可以包含在前述图3-4的装置实施例中,对此本公开不进行限制。
[0173]请参见图7,图7是本公开根据一示例性实施例示出的另一种进程查找装置框图,该实施例在前述图5所示实施例的基础上,所述统计模块302可以包括排序子模块302A和统计子模块302B;其中:
[0174]所述排序子模块302A,被配置为基于进程号对检索到的所述进程日志进行排序;
[0175]所述统计子模块302B,被配置为针对排序后的所述进程日志中进程号相同的日志条目进行数量统计并进行计数。
[0176]需要说明的是,上述图7所示的装置实施例中示出的排序子模块302A和统计子模块302B的结构也可以包含在前述图3-4或6的装置实施例中,对此本公开不进行限制。
[0177]请参见图8,图8是本公开根据一示例性实施例示出的另一种进程查找装置框图,该实施例在前述图5所示实施例的基础上,所述装置还包括第二输出模块308;其中:
[0178]所述第二输出模块308,被配置为将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出。
[0179]需要说明的是,上述图8所示的装置实施例中示出的第二输出模块308的结构也可以包含在前述图3-4或6-7的装置实施例中,对此本公开不进行限制。
[0180]请参见图9,图9是本公开根据一示例性实施例示出的另一种进程查找装置框图,该实施例在前述图5所示实施例的基础上,所述装置还可以包括第三输出模块309;其中:
[0181]所述第三输出模块309,被配置为将所述计数最大的计数值作为10资源占用数量与所述计数最大的进程号关联输出。
[0182]需要说明的是,上述图9所示的装置实施例中示出的第三输出模块309的结构也可以包含在前述图3-4或6-8的装置实施例中,对此本公开不进行限制。
[0183]上述装置中各个模块的功能和作用的实现过程具体详见上述方法中对应步骤的实现过程,在此不再赘述。
[0184]对于装置实施例而言,由于其基本对应于方法实施例,所以相关之处参见方法实施例的部分说明即可。以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理模块,即可以位于一个地方,或者也可以分布到多个网络模块上。可以根据实际的需要选择其中的部分或者全部模块来实现本公开方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
[0185]相应的,本公开还提供一种进程查找装置,所述进程查找装置包括:
[0186]处理器;
[0187]用于存储处理器可执行指令的存储器;
[0188]其中,所述处理器被配置为:
[0189]检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0190]针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0191]查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0192]相应的,本公开还提供一种终端,所述终端包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于进行以下操作的指令:
[0193]检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0194]针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0195]查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0196]图10是根据一示例性实施例示出的一种进程查找装置的结构示意图。
[0197]如图10所示,根据一示例性实施例示出的一种进程查找装置1000,该装置1000可以是计算机,移动电话,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
[0198]参照图10,装置1000可以包括以下一个或多个组件:处理组件1001,存储器1002,电源组件1003,多媒体组件1004,音频组件1005,输入/输出(I/O)的接口 1006,传感器组件1007,以及通信组件1008。
[0199]处理组件1001通常控制装置1000的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件1001可以包括一个或多个处理器1009来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件1001可以包括一个或多个模块,便于处理组件1001和其它组件之间的交互。例如,处理部件1001可以包括多媒体模块,以方便多媒体组件1004和处理组件1001之间的交互。
[0200]存储器1002被配置为存储各种类型的数据以支持在装置1000的操作。这些数据的示例包括用于在装置1000上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器1002可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPR0M),可擦除可编程只读存储器(EPR0M),可编程只读存储器(PR0M),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
[0201]电源组件1003为装置1000的各种组件提供电力。电源组件1003可以包括电源管理系统,一个或多个电源,及其它与为装置1000生成、管理和分配电力相关联的组件。
[0202]多媒体组件1004包括在所述装置1000和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件1004包括一个前置摄像头和/或后置摄像头。当装置1000处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
[0203]音频组件1005被配置为输出和/或输入音频 信号。例如,音频组件1005包括一个麦克风(MIC),当装置1000处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器1002或经由通信组件1008发送。在一些实施例中,音频组件1005还包括一个扬声器,用于输出音频信号。
[0204]I/O接口 1002为处理组件1001和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
[0205]传感器组件1007包括一个或多个传感器,用于为装置1000提供各个方面的状态评估。例如,传感器组件1007可以检测到装置1000的打开/关闭状态,组件的相对定位,例如所述组件为装置1000的显示器和小键盘,传感器组件1007还可以检测装置1000或装置1000—个组件的位置改变,用户与装置1000接触的存在或不存在,装置1000方位或加速/减速和装置1000的温度变化。传感器组件1007可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件1007还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件1007还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
[0206]通信组件1008被配置为便于装置1000和其它设备之间有线或无线方式的通信。装置1000可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信组件1008经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件1008还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其它技术来实现。
[0207]在示例性实施例中,装置1000可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其它电子元件实现,用于执行上述方法。
[0208]在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器1002,上述指令可由装置1000的处理器1009执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是R0M、随机存取存储器(RAM)、CD-R0M、磁带、软盘和光数据存储设备等。
[0209]其中,当所述存储介质中的指令由移动终端的处理器执行时,使得移动终端能够执行一种进程查找方法,包括:
[0210]检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0211 ]针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0212]查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0213]相应的,本公开还提供一种进程查找装置,所述装置包括:
[0214]处理器;
[0215]用于存储处理器可执行指令的存储器;
[0216]其中,所述处理器被配置为:
[0217]检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源;
[0218]针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;
[0219]查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
[0220]图11是根据一示例性实施例示出的一种用于进程查找装置1000的框图。例如,装置1100可以被提供为一服务器。
[0221]参照图11,装置1100包括处理组件1122,其进一步包括一个或多个处理器,以及由存储器1132所代表的存储器资源,用于存储可由处理部件1122的执行的指令,例如应用程序。存储器1132中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1122被配置为执行指令,以执行上述设备绑定方法。
[0222]装置1100还可以包括一个电源组件1126被配置为执行装置1100的电源管理,一个有线或无线网络接口 1150被配置为将装置1100连接到网络,和一个输入输出(I/O)接口1158。装置1100可以操作基于存储在存储器1132的操作系统,例如Windows ServerTM,MacOS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
[0223]本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
[0224]应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
【主权项】
1.一种进程查找方法,其特征在于,所述方法包括: 检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源; 针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数; 查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。2.如权利要求1所述的方法,其特征在于,所述在预设时间段内的进程日志中检索携带预设关键词的进程日志之前,所述方法还包括: 基于用户输入的命令输出各进程的进程日志; 获取用户设置的预设时间段; 从输出的进程日志中读取所述预设时间段内各进程的进程日志。3.如权利要求1所述的方法,其特征在于,所述针对检索到的所述进程日志中进程号相同的日志条目进行数量统计之前,所述方法还包括: 基于预设策略清除检索到的所述进程日志中的无效进程日志。4.如权利要求3所述的方法,其特征在于,所述基于预设策略清除检索到的所述进程日志中的无效进程日志包括: 遍历检索到的所述进程日志; 筛选所述进程日志中携带非字母字符的日志条目; 将筛选出的所述携带非字母字符的日志条目作为无效进程日志清除。5.如权利要求1所述的方法,其特征在于,所述针对检索到的所述进程日志中进程号相同的日志条目进行数量统计包括: 基于进程号对检索到的所述进程日志进行排序; 针对排序后的所述进程日志中进程号相同的日志条目进行数量统计并进行计数。6.如权利要求1所述的方法,其特征在于,所述方法还包括: 将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出。7.如权利要求6所述的方法,其特征在于,所述方法还包括:将所述计数最大的计数值作为10资源占用数量与所述计数最大的进程号关联输出。8.如权利要求1所述的方法,其特征在于,所述预设关键词包括:READ、WRITE以及dirtied中的一个或者多个。9.一种进程查找装置,其特征在于,所述装置包括: 检索模块,被配置为检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源; 统计模块,被配置为针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数; 查找模块,被配置查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。10.如权利要求9所述的装置,其特征在于,所述装置还包括: 第一输出模块,被配置为基于用户输入的命令输出各进程的进程日志; 获取模块,被配置为获取用户设置的预设时间段; 读取模块,被配置为从输出的进程日志中读取所述预设时间段内各进程的进程日志。11.如权利要求9所述的装置,其特征在于,所述装置还包括: 清除模块,被配置为在所述统计模块针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数之前,基于预设策略清除检索到的所述进程日志中的无效进程日志。12.如权利要求11所述的装置,其特征在于,所述清除模块包括: 遍历子模块,被配置为遍历检索到的所述进程日志; 筛选子模块,被配置为筛选所述进程日志中携带非字母字符的日志条目; 清除子模块,被配置为将筛选出的所述携带非字母字符的日志条目作为无效进程日志清除。13.如权利要求9所述的装置,其特征在于,所述统计模块包括: 排序子模块,被配置为基于进程号对检索到的所述进程日志进行排序; 统计子模块,被配置为针对排序后的所述进程日志中进程号相同的日志条目进行数量统计并进行计数。14.如权利要求9所述的装置,其特征在于,所述装置还包括: 第二输出模块,被配置为将所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号向用户输出。15.如权利要求14所述的装置,其特征在于,所述装置还包括: 第三输出模块,被配置为将所述计数最大的计数值作为10资源占用数量与所述计数最大的进程号关联输出。16.如权利要求9所述的装置,其特征在于,所述预设关键词包括:READ、WRITE以及dirtied中的一个或者多个。17.一种进程查找装置,其特征在于,包括: 处理器; 用于存储处理器可执行指令的存储器; 其中,所述处理器被配置为: 检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用10资源; 针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数; 查找所述计数最大的进程号作为所述预设时间段内占用10资源最多的进程号。
【专利摘要】本公开提出一种进程查找方法,所述方法包括:检索预设时间段内各进程的进程日志中携带预设关键词的进程日志;所述预设关键词表征当前进程占用IO资源;针对检索到的所述进程日志中进程号相同的日志条目进行数量统计并进行计数;查找所述计数最大的进程号作为所述预设时间段内占用IO资源最多的进程号。本公开可以实现为用户查找当前系统中占用IO资源最高的进程,从而为用户的系统优化提供依据。
【IPC分类】G06F11/34, G06F17/30
【公开号】CN105488119
【申请号】CN201510819304
【发明人】李明浩, 王乐, 刘吕平
【申请人】小米科技有限责任公司
【公开日】2016年4月13日
【申请日】2015年11月23日

最新回复(0)