基于关系模型分析系统性能采样数据的方法、设备和系统的利记博彩app

文档序号:6562471阅读:240来源:国知局
专利名称:基于关系模型分析系统性能采样数据的方法、设备和系统的利记博彩app
技术领域
本发明总体上涉及计算机系统性能分析和优化领域,并且尤其涉 及在计算机系统中对系统性能采样数据进行分析的技术领域。
背景技术
随着信息技术以及计算机技术的迅猛发展,计算机用户对计算机 系统的性能要求越来越高。因此,为了避免计算机系统中出现性能瓶 颈(包括硬件瓶颈和软件瓶颈),需要对计算机系统进行性能评估和 分析,以便提供相应的性能优化方案,对系统的硬件和软件进行升级 和/或改进系统体系结构,从而达到合理的硬件和软件配置,使系统资 源的使用达到平衡。
通常情况下,为了评估计算机系统的性能,需J^L行系统性能釆样
(profiling)处理,以便收集诸如系统的进程状态、以及不同的处理、 模块和线程分别使用多少CPU资源之类的信息。这种信息可以被合称为 系统性能采样数据(profiling data)。在计算机系统的用户、系统管理员、 或者系统性能分析员利用现有性能分析工具对系统性能釆样数据进行分 析之后,能够对计算机系统中某些重要的组件、例如可共享的运行时间库
(runtime library)或者编译器进行改进。取决于系统性能采样的持续时 间以及系统中当前正在运行的处理、线程等的数目,系统性能采样所得 到的数据文件的大小可能在从几兆字节到几百兆字节的大小范围内变 化。
由于系统性能分析往往基于经过汇总的采样数据,所以需要对系统 性能采样数据进行读取、计算、组织、或者甚至对其进行转换,在现有 的计算机系统性能分析技术中,为了满足上述要求,依照传统的方式,
分析工具需要预先读取系统性能釆样数据的全部内容,然后才能够根据 需要在存储器中创建目标数据模型用于后续分析。
然而,这样做将会导致很多问题。例如,由于需要将系统性能釆样 数据文件转变成数据模型存放在存储器中,因此,随着系统性能采样数 据文件的大小增加,存储器的占用量也极大地增加了。而且,对于某些 非常大的系统性能采样数据文件来说,由于受到存储器容量的限制,要 全部打开这些文件、读取其全部内容并且进而在存储器中创建目标数据 模型几乎是不可能实现的。
此夕卜,计算机系统的系统性能采样数据文件在多数情况下采用"进
程/线程/模块(Process/Thread/Module)"的分级结构来组织系统性能 采样数据,该分级结构反映了系统运行时环境下的结构,并且在大多数 情况下也都是十分有用的。但是,除了最有用的、大家所熟知的"进程/ 线程/模块"的分级结构之外,在实际的系统性能分析过程中,用户往往 也需要构造其它的分级树结构(也可以将其称之为透视图)从其它不同 的角度来分析数据,例如,用户可能需要在"模块/进程"的分级结构中 查看一个模块在不同进程中的被使用情况。这时,就需要有另外的、用 于在对全部系统性能采样数据进行重新计算之后对系统性能采样数据进 行重新组织的数据模型。因此,为了表示多个分级树结构,需要定义多 个分级结构,产生不同的目标数据模型,因而需要占用更多的存储器空间。 因此,需要这样一种技术,其能够根据计算机系统中的系统性能采 样数据的采样对象和数据种类建立预定的关系模型,并且基于该预定关 系模型,根据不同的分级结构对所述计算机系统性能采样数据进行重新 组织,从而生成不同的分级树结构,以便使用户和系统性能分析员能够 根据实际需要自由地查看目标分级树结构,并获得在该目标分级树结构 下的相应采样对象的系统性能采样信息。

发明内容
在下文中给出了关于本发明的简要概述,以便提供关于本发明的 某些方面的基本理解。应当理解,这个概述并不是关于本发明的穷举
性概述。它并不是意图确定本发明的关键或重要部分,也不是意困描 述本发明的范围。其目的仅仅是以简化的形式给出某些概念,以此作 为稍后论述的更详细描述的前序。
为了解决现有技术中的上述问题,本发明的一个目的是,提供一
建立预定关系模型,并且基于该预定关系模型,根据不同的分级结构, 将所述系统性能采样数据重新组织为目标分级树结构的技术。
本发明的另一个目的是提供一种用于根据预定的关系模型、为计 算机系统的系统性能采样数据动态构造分级树结构的一部分,从而方 便用户随意查看整个分级树结构或者其一部分的方法、设备和系统。
本发明的再一个目的是提供一种包含用于实现上述方法的处理 步槺的计算机程序代码的计算机可读存储介质和计算机程序产品,
为了实现上述目的,根据本发明的一个方面,提供了一种用于根 据预定的关系模型、对计算机系统的系统性能采样数据动态构造目标 分级树结构,从而获得其中某一选定节点的系统性能采样信息的方法, 其中,所述预定关系模型是根据所述系统性能采样数据的采样对象定 义的,并且其中包括该分级树结构中各节点的系统性能采样信息,所
述方法包括以下步骤(a)根据所述预定关系模型和所述目标分级树 结构的定义,确定所述目标分级树结构中从根节点到所述选定节点的 路径上的各级实体,以便获得实体阵列;(b)根据所述实体阵列,获 得所述目标分级树结构中从根节点到选定节点的各条路径上的所有节 点、包括所述选定节点的标识信息,以便获得一个或多个相应的标识 阵列;(c)根据所述获得的实体阵列和标识阵列,从所述预定关系模 型中选择所有的、在表示相应实体的各列中具有上述标识阵列的相应 值的行,以便确定行集合;(d)对于所述行集合中的所有行,根据所 述目标分级树结构中所迷选定节点的下一级节点的实体类型,将所述
预定关系模型中、在表示所述下一级节点的实体的列中具有相同标识 信息的行分为一组,从而将所述行集合分为一个或多个分组;(e)对 于所述预定关系模型中的上述每一分组中的所有行,对各行中所包含
的系统性能釆样信息进行汇总,以便获得各个分组的汇总的系统性能
采样信息;以及(f)对所获得的各个分组的汇总的系统性能采样信息 进行处理,以便获得所述目标分级树结构中所述节点的系统性能采样 信息。
根据本发明的另一个方面,还提供了一种用于根据预定的关系模 型、对计算机系统的性能采样数据重新构造目标分级树结构,从而获 得某一选定节点的系统性能采样信息的设备,其中,所述预定关系模 型是根据所述系统性能采样数据的分级树结构定义的,并且其中包括 该分级树结构中各节点的系统性能采样信息,所述设备包括(a)实 体阵列获取装置,用于根据所述预定关系模型和所述目标分级树结构 的定义,确定所述目标分级树结构中从根节点到所述选定节点的路径 上的各级实体,以便获得实体阵列;(b)标识阵列获取装置,用于根 据所述实体阵列,获得所述目标分级树结构中从根节点到选定节点的 各条路径上的所有节点、包括所述选定节点的标识信息,以便获得一
个或多个相应的标识阵列;(c)行集合确定装置,用于根据所述获得 的实体阵列和标识阵列,从所述预定关系模型中选择所有的、在表示
相应实体的各列中具有上述标识阵列的相应值的行,以便确定行集合; (d)分组装置,用于针对所述行集合中的所有行,根据所述目标分级 树结构中所述选定节点的下一级节点的实体类型,将所述预定关系模 型中、在表示所述下 一级节点的实体的列中具有相同标识信息的行分 为一组,从而将所述行集合分为一个或多个分组;(e)系统性能采样 信息汇总装置,用于针对所述预定关系模型中的上述每一分组中的所 有行,对各行中所包含的系统性能釆样信息进行汇总,以便获得各个 分组的汇总的系统性能采样信息;以及(f)系统性能采样信息获得装 置,用于对所获得的各个分组的汇总的系统性能采样信息进行处理, 以获得所述目标分级树结构中所述节点的系统性能采样信息。
根据本发明的另一个方面,还提供了一种用于根据预定的关系模 型、对计算机系统的性能采样数据重新构造目标分级树结构,从而获 得某一选定节点的系统性能采样信息的系统,包括关系橫型建立装
置,用于根据所述系统性能采样数据的分级树结构,建立预定关系棋
型;存储系统,用于存储所述预定关系模型;以及上迷用于根据预定 的关系模型、对计算机系统的性能采样数据重新构造目标分级树结构, 从而获得某一选定节点的系统性能采样信息的设备,
依据本发明的其它方面,还提供了相应的计算机可读存储介质和 计算机程序产 品。
通过利用本发明的上述方法、设备和系统,可以在一个外部存储 系统中建立和存储关系模型来表示系统性能采样数据,并且可以允许 用户根据实际需要基于所述关系模型为系统性能采样数据动态地构造
不同的分级树结构,以方便用户对大量系统性能采样数据的查看.
此外,本发明的另一优点在于,可以将关系模型存储在一个外部 存储系统,而且通过动态构造分级树,以避免在计算机系统内部存储 整个的分级树,从而显著地改善了存储器的使用效率,大大降低了对 分析大规模系统性能采样数据的硬件要求,提高了对;UC模系统进行性 能采样分析的能力。
通过以下结合附图对本发明的最佳实施例的详细说明,本发明的 这些以及其他优点将更加明显。


本发明可以通过参考下文中结合附困所进行的描述而得到更好 的理解,其中在所有附图中使用了相同或相似的附困标记来表示相同 或者相似的部件。所述附图连同下面的详细说明一起包含在本说明书 中并且形成本说明书的一部分,而且用来进一步举例说明本发明的优 选实施例和解释本发明的原理和优点。在附图中
图1示出了根据本发明一个实施例的系统性能采样数据的分级树结 构和关系模型(也可以被称为分M)之间的映射关系;
图2示出了系统性能采样数据的一个例子,它本身是按照运行时环 境下采样对象的层次结构组织的;
图3示出了与图2所示的系统性能采样数据示例相对应的分級树结
构;
图4示出了将图2所示的系统性能采样数据经过映射(或者转换) 而得到的关系模型;
图5示出了在图3所示的系统性能采样数据的分级树结构中的一 条路径与图4所示的关系棋型中的一行之间的映射关系;
图6示出了困4所示的关系模型可根据其定义的三个分级结构生 成三个不同的分级树;
图7的流程图示出了如何根据预定的关系模型动态地构造新的分级 树结构(即,目标树结构)中第r级上的选定节点A的子节点、并且获 得其系统性能采斧ff息的方法的处理过程;以及
图8示出了用户针对图2所示的系统性能釆样数据示例希望获得的 目标分级树结构。
本领域技术人员应当理解,附图中的单元或元件仅仅是为了简单 和清楚起见而示出的,而且不一定是按比例绘制的,例如,附图中某 些元件的尺寸可能相对于其他元件被放大了 ,以便有助于提高对本发 明实施例的理解。
具体实施例方式
以下将结合附图进行描述,为了清楚和简明起见,在说明书中并 未描述实际实施方式的所有特征。然而,应该了解,在开发任何这种 实际实施例的过程中必须做出很多特定于实施方式的决定,以便实现 开发人员的具体目标,例如符合那些与系统及业务相关的限制条件, 其中这些限制条件会随着实施方式的不同而改变。此外,还应该了解, 虽然开发工作有可能非常复杂和费时,但对得益于本申请公开内容的 本领域技术人员来说,这种开发工作仅仅是例行的任务。
在此,需要说明的一点是,为了避免因不必要的细节而模糊了本 发明,在附图中仅仅示出了与根据本发明的方案密切相关的装置结构 和/或处理步骤,而省略了与本发明关系不大的其他细节。
系统性能采样数据在通常情况下可以被生成作为多个原始跟踪事
件。包含原始跟踪事件的文件通常也可以被称为",文件(trace file )"。 表示跟踪事件的另一种方式是将原始跟踪事件重新组织为静态的、用于
表示被采样系统的快照的分级树结构,因此,不管生成的系统性能釆样 数据的方式和文件格式如何,系统性能采样数据都可以用 一个正确地表 示了被采样系统的快照的分级树结构来表示。
图1示出了根据本发明一个实施例的系统性能采样数据和关系模型 (也可以将其称之为分^J之间的映射关系。
假定系统性能采样系统包含n级系统性能采样对象(也可以将其称 之为进行系统性能采样的实体),为了简单起见,将它们分别用Levels Level2、... 、Leveln来表示,或者也可以将它们分别称之为实体l( Entity )、
实体2 (Entity2).....实体n (EntityJ 。该系统生成的采样数据按照
某种分级层次关系、例如采样对象运行时的分级层次关系进行组织,其
性能采样数据的分级树结构如图1的左半部分所示,其中IDp ID2.....
IDn表示每一级中的节点的标识信息,例如,ID2表示第2级中的节点的 标识信息。
为了将上述分级树结构映射为一个关系模型,假定将上述树结构中 从根节点(Root)起至每个叶节点的每条完整路径存储为关系模型中的 一行,并且其中的每一列用属于与该列相对应的那 一级上的节点的标识 信息来填充,如图l的右半部分所示,从而构成了关系模型的前n列、 即L" L2.....Ln列.
此外,在关系模型中,如图l的右半部分所示,除了上述分级树结 构中的每条路径信息之外,还可以根据需要在关系模型的第n列之后的 各列中存储各种系统性能采样信息,例如,不同的CPU性能计数器值等, 从而构成了关系模型的d、 C2.....Cm列。
下面以 一个系统性能采样数据为例进行说明。
为了简单起见,假定该系统性能采样数据的一个示例如困2所示。 如困2所示,-该系统性能采样数据结构是用"进程/线程/模块(Process/ Thread/Module)"的分级结构来组织的,该分级结构与运行时环境下的 结构是相同的.
在图2所示的分级结构示例中, 一个计算机系统中可能同时运行多 个进程,在每个进程下包含一个或多个线程,在线程下包含一个或多个 模块,而模块下可能进而包括一个或多个符号。此外,该分级结构的每 一级中都包含一个由性能计数器计数得到的值、例如Ticks (Ticks在此 表示计算机系统中使用的处理器时间)。在该分级结构示例中,进程 (Process)、线程(Thread)、模块(Module)等均为可进行系统性能 采样的实体(或者对象),也可以将其称之为实体l (Entity,)、实体2
(Entity2).....实体n (Entityn),它们至少包衬如Ticks之类的系
统性能采样信息d,并且彼此之间具有分级关系。
与困2所示的系统性能釆样数据示例相对应的分级树结构如困3所 示,其中进程(Process)、线程(Thread)、模块(Module)分别与困 1中的系统性能采样数据树结构中的Leveh、 Level2、…、Levd相对应。
需要说明的是,为了简单起见,在图2中仅示出了进程、线程、模 块、符号共四种系统性能采样对象,但是显然根据需要可以有更多或更 少的系统性能采样对象。
根据图l所示的系统性能采样数据和关系模型之间的映射关系,可 以将图2所示的系统性能采样数据映射(或者转换)成一个关系模型, 其如图4所示,并且可以将其用关系代数语言R (PROCESS, THREAD, MODULE, SYMBOL, TICKS)来表示。
在该关系模型中的每一行表示系统性能采样数据的分级树结构中 从根节点到叶节点的一条路径。例如,图5示出了该关系模型中的第一 行与图3所示的分级树结构中的路径Processl/ThreadlModulel/ Symboll之间的映射关系。
为了减少计算机系统中对存储器的占用量,可以将上述关系模型存 储在计算机系统的一个外部存储系统中。这种外部存储系统通常在列上
建立了索引,并且提供有诸如分组、选择、投影、汇总等之类的关系操 作。这类外部存储系统的实现方式可以是多种多样的。关系数据库是其 中最便利的一种实现方式。显然,提供有索引的其它存储系统也是可能 的,例如,提供有索引的基于文件的数据存储系统也是其中的一个例子.
在实际的应用中,用户或者系统性能分析员可能而且经常需要构造
与图3所示的分级树结构不同的树结构,即,需要动态地构造系统性能 采样数据的分级树结构。例如,对于如图2所示的系统性能釆样数据, 可能希望获得由各个模块在计算机系统中运行的各种进程或所有进程下 的系统性能采样信息、或者是各个线程在所运行的各种进程或所有进程 下的系统性能采样信息等。这时,根据需要,可以定义不同的分级结构、 基于上述定义的关系模型来构造不同的分级树结构,并计算在不同分级 树结构下各个节点的系统性能采样信息,例如Ticks值等。
例如,如图6所示,对于图2所示的系统性能采样数据示例,用户 或者系统性能分析员可以根据需要定义以下三个分级结构来分析这些经 过系统性能采样所得到的数据"进程/线程/模块","模块/进程",以 及"线程/模块"。当然,也可以定义其它的分级结构。
以下,描述根据本发明的实施例、如何构造新的分級树结构(目标 树结构)的方法的处理流程。
在此,假定用户希望构造的新的分级树结构用一个矢量Z)- (Lpl, Lp2,...,Lpn)表示,其中(pl,p2,…,pn)是n级系统性能采样对象的数 1到n的排列。
图7的流程图示出了根据本发明的一个实施例、如何根据预定的关 系模型动态地构造新的分级树结构(即,目标树结构)中第r级上的选 定节点A的子节点并获得其系统性能采样倌息的方法100的处理过程。
所述方法100在步骤S110中开始。然后,在步骤S120中,对于笫 r级上的所述选定节点A,根据该目标树结构的定义,确定从根节点到该 选定节点A的各级节点(即从第1级节点到第r级节点的各级节点)的 实体类型,从而获得一个实体阵列(Lpl,Lp2,...,Lpr)。
例如,以图6的下半部分所示的三种分级结构为例.对于模块级上 的某一节点Modulel而言,其实体阵列分别为(Process, Thread, Module) ; (Module);和(Thread, Module).显然,根据需要也 可以定义其它的分级树结构,从而可以确定出不同的实体阵列。
随后,在步骤130中,根据上述获得的实体阵列,获得上述目标树结构中与上述实体阵列相对应的相应标识信息,即,获得在上述目标树
结构中从根节点到这个所选节点A的所有路径上的所有节点(包括选定
节点A在内)的标识信息,从而获得一个标识阵列(IDpblDp2,…,IDpr)。
该标识阵列和上面得到的实体阵列可以唯一确定节点A。
例如,仍以图6的下半部分所示的三种分级结构1、 2、和3为例。 对于其中的选定节点Modulel而言,可以获得的标识阵列分别为(1) (Processl , Threadl , Modulel); (2 ) (Modulel) ,和(3) (Threadl , Modulel)。而对于其中的模块Module2而言,可以获得的标识阵列分 另'J为(1) (Processl, Threadl, Module2)或(Processl, Thread2, Module2)(取决于用户选择哪个Module2) ; (2) (Module2);以 及(3) (Threadl, Module2 )或(Thread2, Module2)(取决于用户 选择哪个Module2)。
在步骤S140中,从所述预定关系模型(即分级表)中选择所有满 足以下约束的行
V(Lpl) = IDpl, V(Lp2"IDp2,…,以及V(Lpr)-IDp" 其中,V(LO表示预定关系模型中的代表Li的列中的ID值,并且将所选 择的这些行标记为行集合S。
也就是说,在该步骤中,根据所获得的实体阵列和标识阵列,从预 定的关系模型(例如,如图4所示的关系模型)中,选择所有在表示相 应实体的各列中具有上述标识阵列的各相应值的行,从而确定行集合S。
接下来,在步骤S150中,对于所获得的行集合S,将其中在所述目 标分级树结构中第Lp(r+D级中具有相同标识的行分为一组,从而可以将所 述行集合S分组为一个和多个分组,其可以用(Gi,G2…,G。)来表示。 应当注意的是,在目标分级树结构中节点A有几个子节点,就可以有几 个相应分组。
随后,在步骤S160中,对于上述步骤S150中所确定的每一组,将 该分组中每一行的系统性能采样信息、例如Ticks值进行求和,从而计算 出各组的系统性能采样信息(也可以将其称之为汇总信息).经过上述 计算后所得到的各个汇总信息即为在所期望的目标树结构中所述选定节
点A的各个子节点的系统性能采样信息。
然后,方法100的处理流程进行到步骤S170,其中将计算得到的各 组的汇总系统性能采样信息相加,从而获得节点A的系统性能采样汇总 信息。
然后,方法100在步骤S180中结束。
通过使用上述方法100从目标分级树结构中的根节点起进行迭代, 就可以才艮据任意的分级树结构定义构造出相应的树节点,由此可以构造 出所期望的目标分级树。
下面通过一个具体的示例来对上述方法的处理流程进行进一步的 具体说明。
例如,假定预定的关系模型如图4所示,并且用户或者系统性能分 析员希望知晓(或获得)当前计算机系统中模块Module2在Processl中
此时,可以确定用户或系统性能分析员希望获得的分级结构为"模 块/进程/线程(Module / Process / Thread)",即,所期望的目标树结构 如图8所示,并且选定节点A如图中所示。
才艮据上述图7所示的方法的处理,对于其中的节点A,依据图8所 示的树结构,确定其中从根节点到所选节点A的路径,从而获得节点A 的实体阵列为(Module, Process),其相应的标识阵列为(Module2, Process 1)。
然后,在预定关系模型(如图4所示)中选择所有在与实体阵列相 对应的各列中具有上述标识阵列的相应值的行,即选择其中所有满足以 下约束的行在Entityi列(即,Process列)中具有ID = Process 1,在 Entity3 (即,Module列)中具有ID = Module2。即,选择图4所示的关 系模型中的第3、 4和5行,从而构成了一个行集合S。
对于该行集合S中的所有行,由于在图8所示的目标树结构中节点 A的下一级节点为线程(Thread)级,因此,才艮据困4所示的关系模型 中的Thread列中的ID值,将Thread列中具有相同ID值的 一行或多行 分为一组。即,将困4所示的关系模型中的第3行确定为第一组(Gi),
其在Thread列中的ID值为Threadl,并且将上述关系模型中的第4和 5行确定为第二组(G2),其Thread列中的ID值均为Thread2。
随后,对于上述所确定的每一组中的所有行,将图4所示的关系模 型中的d列(即Ticks列)的值进行求和,以便计算出每组的相应汇总 信息。即,对于分组G"计算后所得到的Ticks值"c"即为在图8中所 示的树结构中节点B的Ticks值,其表示在当前计算机系统中由Module2 在Processl和Threadl中所使用的处理器时间。而对于分组G2,将图4 的关系模型中第4和5行的Ticks值求和而得到的值"d+e",是图8所 示的树结构中节点C的Ticks值,其表示在当前计算机系统中由Modnle2 在Processl和Thread2中所使用的处理器时间。
然后,将上述两组中所计算的Ticks值、即节点B和C的Ticks值 相加,就可以得到节点A的Ticks值、即"c+d+e",其表示在当前计算 机系统中由Module2在Processl中所使用的处理器时间。
从上述的示例中可以看出,使用图7所示的方法100,不需要构造 整个目标树结构。无论用户何时希望查看目标树结构中的哪一个或者哪 些节点,都可以根据需要利用存储在外部存储系统中的预定关系模型, 构造用户希望查看的那一部分树结构以及其相应树节点,即构造动态分 级树结构的所需的那一部分,从而方^1用户随意地查看有关系统性能采 样数据。而且,也没有必要再像现有技术中那样在计算机系统的存储器
而显著地减少了存储器的占用量,加快树结构的显示时间。因此,从理 论上来说,不管原始的系统性能采样数据文件有多大,都可以将存储器 的占用量保持为 一个相对固定的值。
在此需要说明的是,在以上结合图2-8所述的实施例中,为了简 单和清&^见,以如图2所示的系统性能采样数据为例进行了说明,并 且仅仅描述了该系统性能采样数据的四个采样对象,即进程(Process)、 线程(Thread)、模块(Module)和符号(Symbol),而且也仅仅以 Ticks为例说明了分级树结构中每一级节点所包含的系统性能采样信息。 但是,显然应当理解,根据实际应用的不同,系统性能采样数据可以具 有不同的采样对象类型、不同的关系模型、不同的分级结构以及不同的 系统性能采样信息,而且可以根据需要构造出不同的目标分,结构, 以获得不同目标分级树结构下不同节点的系统性能采样信息.因此,根 据本发明实施例的方法可以向用户(或者系统性能分析员)提供通过构 造动态分级树结构自由地查看系统性能采样数据的能力。
根据本发明的其它实施例,还提供了用于执行结合图7所述的方 法的处理步骤的设备和系统。
在此,为了说明书的简洁起见,未结合附图对所述设备和系统进 行具体描述,而仅仅给出了下述文字描述。但是,显然本领域技术人 员根据下述描述可以很容易绘制出相应的结构框图。
根据本发明,提供了一种用于根据预定的关系模型、对计算机系 统的性能采样数据重新构造目标分级树结构,从而获得某一选定节点 的系统性能采样信息的设备,其中,所述预定关系模型是根据所述系 统性能采样数据的分级树结构定义的,并且其中包括该分级树结构中 各节点的系统性能采样信息,所述设备包括(a)实体阵列获取装置, 用于根据所述预定关系模型和所述目标分级树结构的定义,确定所述 目标分级树结构中从根节点到所述选定节点的路径上的各级实体,以 便获得实体阵列;(b)标识阵列获取装置,用于根据所述实体阵列, 获得所述目标分级树结构中从根节点到选定节点的各条路径上的所有 节点、包括所述选定节点的标识信息,以便获得一个或多个相应的标 识阵列;(c)行集合确定装置,用于根据所述获得的实体阵列和标识 阵列,从所述预定关系模型中选择所有的、在表示相应实体的各列中 具有上述标识阵列的相应值的行,以便确定行集合;(d)分组装置, 用于针对所述行集合中的所有行,根据所述目标分级树结构中所述选 定节点的下一级节点的实体类型,将所述预定关系模型中、在表示所 述下一级节点的实体的列中具有相同标识信息的行分为一组,从而将
所述行集合分为一个或多个分组;(e)系统性能采样信息汇总装置, 用于针对所述预定关系模型中的上述每一分组中的所有行,对各行中 所包含的系统性能采样信息进行汇总,以便获得各个分组的汇总的系
统性能采样信息;以及(f)系统性能采样信息获得装置,用于对所获 得的各个分组的汇总的系统性能采样信息进行处理,以获得所迷目标 分级树结构中所述节点的系统性能采样信息。
在所述设备中,所述系统性能采样数据的分级树结构中从根节点
到每一个叶节点的一条路径被表示为所述预定关系模型中的一行,并 且所述预定关系模型中的每一行中还包括所述系统性能采样数据的分 级树结构中相应叶节点的系统性能采样信息。
其中,所述系统性能采样信息至少包括计算机系统中所使用的处 理器时间信息。
在所述设备中,所述系统性能采样信息汇总装置将所述预定关系 模型中所确定的每一分组中的各行中所包含的处理器使用时间相加, 以获得各组的总的处理器使用时间信息。
在所述设备中,通过对所述目标分级树结构中从根节点起的所有 节点进行迭代,获得所述目标分级树结构中所有节点的系统性能采样 信息。
其中,所述预定关系模型可以是从一个关系数据库中读取的.或 者,所述预定关系模型可以是从计算机系统的外部存储系统中读取的。 此外,作为选择,所述预定关系模型可以是从任何可实现关系模型的 存储系统中读取的。
此外,根据本发明的实施例,还提供了一种用于根据预定的关系 模型、对计算机系统的性能采样数据重新构造目标分级树结构,从而 获得某一选定节点的系统性能采样信息的系统,包括关系模型建立 装置,用于根据所述系统性能采样数据的分级树结构,建立预定关系 模型;存储系统,用于存储所述预定关系模型;以及上述用于根据预 定的关系模型、对计算机系统的性能采样数据重新构造目标分级树结 构,从而获得某一选定节点的系统性能采样信息的设备。
在所述系统中,所述关系模型建立装置将所述系统性能采样数据 的分级树结构中从根节点到每一个叶节点的一条路径表示为所述预定 关系模型中的一行,并且在每一行中还包含相应叶节点的系统性能采
样信息。
在所述系统中,所述系统性能采样信息至少包括计算机系统中所 使用的处理器时间信息。
根据本发明实施例的设备和系统也可以向用户(或者系统管理员) 提供通过构造动态分级树结构自由地查看系统性能釆样数据的能力,从 而大大地提高对大,系统进行性能采样和分析的能力。
此外,显然,根据本发明的上述方法的各个操作过程也可以以存 储在各种机器可读的存储介质中的计算机可执行程序的方式实现。
而且,本发明的目的也可以通过下述方式实现将存储有上述可 执行程序代码的存储介质直接或者间接地提供给系统或设备,并且该 系统或设备中的计算机或者中央处理单元(CPU)读出并执行上述程 序代码,
此时,只要该系统或者设备具有执行程序的功能,則实施的方式 不局限于程序,并且该程序也可以是任意的形式,例如,目标程序、 解释器执行的程序或者提供给操作系统的脚本程序等。
上述这些机器可读存储介质包括但不限于各种存储器和存储单 元,半导体设备,磁盘单元例如光、磁和磁光盘,以及其它适于存储 信息的介质等,
另外,客户计算机通过连接到因特网上的相应网站,并且将依据 本发明的计算机程序代码下栽和安装到计算机中、然后执行该程序代 码,也可以实现本发明。
最后,还需要说明的是,在本文中,诸如左和右、第一和笫二等 之类的关系术语仅仅用来将一个实体或者操作与另 一个实体或搮作区 分开来,而不一定要求或者暗示这些实体或搮作之间存在任何这种实 际的关系或者顺序。而且,术语"包括"、"包含"或者其任何其他 变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方 法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其 他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要 素。在没有更多限制的情况下,由语句"包括一个……"限定的要素,
并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外 的相同要素。
以上虽然结合附图详细描述了本发明的实施例,但是应当明白, 上面所描述的实施方式只是用于说明本发明,而并不构成对本发明的 限制,对于本领域的技术人员来说,可以对上述实施方式做出各种修 改和变更而没有背离本发明的实质和范围。因此,本发明的范围仅由 所附权利要求及其等效含义来限定。
权利要求
1.一种用于根据预定的关系模型、对计算机系统的系统性能采样数据动态构造目标分级树结构,从而获得其中某一选定节点的系统性能采样信息的方法,其中,所述预定关系模型是根据所述系统性能采样数据的采样对象定义的,并且其中包括该分级树结构中各节点的系统性能采样信息,所述方法包括以下步骤(a)根据所述预定关系模型和所述目标分级树结构的定义,确定所述目标分级树结构中从根节点到所述选定节点的路径上的各级实体,以便获得实体阵列;(b)根据所述实体阵列,获得所述目标分级树结构中从根节点到选定节点的各条路径上的所有节点、包括所述选定节点的标识信息,以便获得一个或多个相应的标识阵列;(c)根据所述获得的实体阵列和标识阵列,从所述预定关系模型中选择所有的、在表示相应实体的各列中具有上述标识阵列的相应值的行,以便确定行集合;(d)对于所述行集合中的所有行,根据所述目标分级树结构中所述选定节点的下一级节点的实体类型,将所述预定关系模型中、在表示所述下一级节点的实体的列中具有相同标识信息的行分为一组,从而将所述行集合分为一个或多个分组;(e)对于所述预定关系模型中的上述每一分组中的所有行,对各行中所包含的系统性能采样信息进行汇总,以便获得各个分组的汇总的系统性能采样信息;以及(f)对所获得的各个分组的汇总的系统性能采样信息进行处理,以便获得所述目标分级树结构中所述节点的系统性能采样信息。
2. 根据权利要求1所述的方法,其中,所述系统性能采样数据 的分级树结构中从根节点到每一个叶节点的 一条路径被表示为所述预 定关系模型中的一行,并且所述预定关系模型中的每一行中还包括所 述系统性能采样数据的分级树结构中相应叶节点的系统性能采样信息。
3. 根据权利要求2所述的方法,其中,所述系统性能采样信息 至少包括计算机系统中所使用的处理器时间信息。
4. 根据权利要求3所述的方法,其中,所述步跺(e)进一步包 括步骤将所述预定关系模型中所确定的每一分组中的各行中所包含 的处理器使用时间相加,以获得各组的总的处理器使用时间信息。
5. 根据权利要求1至4中任何一项权利要求所述的方法,进一 步包括步骤对于所述目标分级树结构中从根节点起的所有节点,重复执行所 述(a) - (f)步骤,以便获得所述目标分级树结构中所有节点的系 统性能采样信息。
6. 根据权利要求1至4中任何一项权利要求所述的方法,其中, 所述预定关系模型存储在任何可实现关系模型的存储系统中。
7. 根据权利要求1至4中任何一项权利要求所述的方法,其中, 所述预定关系模型存储在关系数据库中。
8. 根据权利要求1至4中任何一项权利要求所述的方法,其中, 所述预定关系模型存储在计算机系统的外部存储系统中。
9. 一种用于根据预定的关系模型、对计算机系统的性能采样数 据重新构造目标分级树结构,从而获得某一选定节点的系统性能釆样 信息的设备,其中,所述预定关系模型是根据所述系统性能采样数据 的分级树结构定义的,并且其中包括该分级树结构中各节点的系统性 能采样信息,所述设备包括(a) 实体阵列获取装置,用于根据所述预定关系模型和所述目 标分级树结构的定义,确定所述目标分级树结构中从根节点到所述选 定节点的路径上的各级实体,以便获得实体阵列;(b) 标识阵列获取装置,用于根据所述实体阵列,获得所述目 标分级树结构中从根节点到选定节点的各条路径上的所有节点、包括 所述选定节点的标识信息,以便获得一个或多个相应的标识阵列;(c) 行集合确定装置,用于根据所述获得的实体阵列和标识阵列,从所述预定关系模型中选择所有的、在表示相应实体的各列中具有上述标识阵列的相应值的行,以便确定行集合;(d) 分組装置,用于针对所述行集合中的所有行,根据所述目 标分级树结构中所述选定节点的下一级节点的实体类型,将所述预定 关系模型中、在表示所述下一级节点的实体的列中具有相同标识信息 的行分为一组,从而将所述行集合分为一个或多个分组;(e) 系统性能采样信息汇总装置,用于针对所述预定关系模型 中的上述每一分组中的所有行,对各行中所包含的系统性能采样信息 进行汇总,以便获得各个分组的汇总的系统性能采样信息;以及(f) 系统性能采样倌息获得装置,用于对所获得的各个分组的 汇总的系统性能采样信息进行处理,以获得所述目标分级树结构中所 述节点的系统性能采样信息。
10. 根据权利要求9所述的设备,其中,所述系统性能采样数据 的分级树结构中从根节点到每一个叶节点的一条路径被表示为所述预 定关系模型中的一行,并且所述预定关系模型中的每一行中还包括所 述系统性能采样数据的分级树结构中相应叶节点的系统性能采样信 息。
11. 根据权利要求10所述的设备,其中,所述系统性能采样信 息至少包括计算机系统中所使用的处理器时间信息。
12. 根据权利要求11所述的设备,其中,所述系统性能采样信 息汇总装置将所述预定关系模型中所确定的每一分组中的各行中所包 含的处理器使用时间相加,以获得各组的总的处理器使用时间信息。
13. 根据权利要求9至12中任何一项权利要求所述的设备,其 中,所述设备通过对所述目标分级树结构中从根节点起的所有节点进 行迭代,获得所述目标分级树结构中所有节点的系统性能采样信息。
14. 根据权利要求9至12中任何一项权利要求所述的设备,其 中,所述预定关系模型是从一个关系数据库中读取的。
15. 根据权利要求9至12中任何一项权利要求所述的设备,其 中,所述预定关系模型是从计算机系统的外部存储系统中读取的.
16. 根据权利要求9至12中任何一项权利要求所述的设备,其 中,所述预定关系模型是从任何可实现关系模型的存储系统中读取的,
17. —种计算机程序产品,其上编码有计算机程序代码,该计算 机程序代码在计算设备上执行时,用于使所述计算设备执行根据权利 要求1至8中任何一项所述的方法步骤。
全文摘要
本发明提供了一种用于根据预定的关系模型、对计算机系统的性能采样数据重新构造目标分级树结构,从而获得某一选定节点的系统性能采样信息的方法、设备和系统。所述预定关系模型是根据所述系统性能采样数据的分级树结构预先定义的,并且存储在一个外部存储系统中。通过利用本发明,可以根据需要构造动态的分级树结构,从而减少了存储器的占用量,并且便于用户随意查看系统性能采样数据。
文档编号G06F11/34GK101162437SQ20061014235
公开日2008年4月16日 申请日期2006年10月10日 优先权日2006年10月10日
发明者房一飞, 璞 杨, 祺 梁, 龙 程, 许一震 申请人:国际商业机器公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1