JP6693308B2 - 負荷推定プログラム、負荷推定方法及び負荷推定装置 - Google Patents

負荷推定プログラム、負荷推定方法及び負荷推定装置 Download PDF

Info

Publication number
JP6693308B2
JP6693308B2 JP2016133639A JP2016133639A JP6693308B2 JP 6693308 B2 JP6693308 B2 JP 6693308B2 JP 2016133639 A JP2016133639 A JP 2016133639A JP 2016133639 A JP2016133639 A JP 2016133639A JP 6693308 B2 JP6693308 B2 JP 6693308B2
Authority
JP
Japan
Prior art keywords
load
execution
traveling
processor
predetermined program
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
JP2016133639A
Other languages
English (en)
Other versions
JP2018005688A (ja
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.)
Fujitsu Ltd
Original Assignee
Fujitsu 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 Fujitsu Ltd filed Critical Fujitsu Ltd
Priority to JP2016133639A priority Critical patent/JP6693308B2/ja
Priority to US15/633,808 priority patent/US10983837B2/en
Priority to EP17178325.1A priority patent/EP3267313B1/en
Publication of JP2018005688A publication Critical patent/JP2018005688A/ja
Application granted granted Critical
Publication of JP6693308B2 publication Critical patent/JP6693308B2/ja
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/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3476Data logging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5083Techniques for rebalancing the load in a distributed system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3006Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is distributed, e.g. networked systems, clusters, multiprocessor systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3024Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a central processing unit [CPU]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3414Workload generation, e.g. scripts, playback
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3433Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment for load management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3442Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for planning or managing the needed capacity
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/40Data acquisition and logging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/815Virtual

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Debugging And Monitoring (AREA)
  • Stored Programmes (AREA)

Description

本発明は、動作中のプログラムの負荷を計測する技術に関する。
例えば、サーバ装置で動作しているアプリケーションの負荷を特定できれば、当該アプリケーションに割り当てられている資源が足りているか否かを判断することに役立つ。
一般的には、オペレーティングシステムにおいて計測されたアプリケーションのCPU(Central Processing Unit)使用率によって、負荷の程度を把握できる。但し、オペレーティングシステムにおいてCPU使用率を計測できないタイプのアプリケーションの負荷を把握するためには、オペレーティングシステムによる計測以外の手段が求められる。
国際公開第2014/050254号 特開2008−310470号公報 特開2014−170482号公報
本発明の目的は、一側面では、所定プログラムの負荷を、より簡便に把握することである。
一態様に係る負荷推定方法は、プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶するコンピュータに、(A)所定プログラムを実行中のプロセッサにおける走行データを収集する処理と、(B)走行データに基づいてプロセッサの走行状況を集計する処理と、(C)走行状況と走行パターンとの比較結果に基づいて、所定プログラムの負荷を推定する推定処理とを実行させる。
更に、一態様に係る負荷推定方法は、プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における所定プログラムのルーチンの実行パターンとを対応付けて記憶するコンピュータに、(D)所定プログラムを実行中のプロセッサにおける走行データを収集する処理と、(E)走行データに基づいてルーチンの実行状況を集計する処理と、(F)実行状況と実行パターンとの比較結果に基づいて、所定プログラムの負荷を推定する推定処理とを実行させる。
一側面としては、所定プログラムの負荷を、より簡便に把握することができる。
図1は、システム構成の例を示す図である。 図2は、サーバ装置のモジュール構成例を示す図である。 図3は、CPU使用率の例を示す図である。 図4は、サーバ装置のモジュール構成例を示す図である。 図5は、CPU使用率の例を示す図である。 図6は、実行アドレスの度数分布の例を示す図である。 図7は、サーバ装置のモジュール構成例を示す図である。 図8は、シーケンスの例を示す図である。 図9は、ログテーブルの例を示す図である。 図10は、開始処理フローを示す図である。 図11は、ハンドラ処理フローを示す図である。 図12は、分析エージェントのモジュール構成例を示す図である。 図13は、度数分布テーブルの例を示す図である。 図14は、走行状況データの例を示す図である。 図15は、走行パターンテーブルの例を示す図である。 図16は、分析処理フローを示す図である。 図17は、集計処理(A)フローを示す図である。 図18は、推定処理(A)フローを示す図である。 図19は、類似度算出処理フローを示す図である。 図20は、推定処理(B)フローを示す図である。 図21は、実施の形態3におけるブロックの例を示す図である。 図22は、実施の形態3における度数分布テーブルの例を示す図である。 図23Aは、集計処理(B)フローを示す図である。 図23Bは、集計処理(B)フローを示す図である。 図23Cは、集計処理(B)フローを示す図である。 図23Dは、集計処理(B)フローを示す図である。 図24は、実施の形態4における走行パターンテーブルの例を示す図である。 図25は、実施の形態4における分析エージェントのモジュール構成例を示す図である。 図26は、関数テーブルの例を示す図である。 図27は、実行状況テーブルの例を示す図である。 図28は、集計処理(C)フローを示す図である。 図29は、実行パターンテーブルの例を示す図である。 図30は、重みデータの例を示す図である。 図31は、推定処理(C)フローを示す図である。 図32は、グループテーブルの例を示す図である。 図33は、実施の形態5における実行状況テーブルの例を示す図である。 図34は、集計処理(D)フローを示す図である。 図35は、実施の形態5における実行パターンテーブルの例を示す図である。 図36は、実施の形態5における重みデータの例を示す図である。 図37は、推定処理(D)フローを示す図である。 図38は、コンピュータの機能ブロック図である。
[実施の形態1]
例えば、図1に示したシステム構成を想定する。この例におけるシステムのLAN(ローカルエリアネットワーク)には、複数のサーバ装置101a乃至101c及び管理装置103が接続されている。複数のサーバ装置101a乃至101cは、連携して所定のサービスを提供する。管理装置103は、サーバ装置101a乃至101cの状況を監視する。
図2に、サーバ装置101のモジュール構成例を示す。この例では、ホストOS(オペレーティングシステム)201の環境において、複数のアプリケーション203a,203bが動作している。また、複数の仮想マシン205a,205bが設けられ、各仮想マシン205a,205bにおいてアプリケーション203c,203dが動作している。
ホストOS201において計測されるCPU使用率の例を図3に示す。システムモードによるCPU使用率及びユーザモードによるCPU使用率が計測される。そして、システムモードによるCPU使用率及びユーザモードによるCPU使用率の残余が、アイドル状態の割合に相当する。
上段にアプリケーション203の負荷が高い場合の計測結果を示す。システムモードによるCPU使用率及びユーザモードによるCPU使用率が大きく、アイドル状態の割合は小さい。
一方、下段に示すように、アプリケーション203の負荷が低い場合には、システムモードによるCPU使用率及びユーザモードによるCPU使用率が小さく、アイドル状態の割合は大きい。
このように計測されるCPU使用率を監視すれば、例えば資源配分の調整に役立てることができる。尚、サーバ装置101において、ホストOS201に代えてハイパーバイザーを動作させる場合も同様である。
上述した通常のアプリケーション203は、例えばホストOS201のカーネルを介してドライバとデータをやり取りする。従って、ホストOS201においてシステムモードの動作時間とユーザモードの動作時間と区別することができる。
一方、ホストOS201のカーネルを介さずにドライバとデータをやり取りするアプリケーション203の場合には、ホストOS201においてシステムモードの動作時間とユーザモードの動作時間と区別することができない。
図4に、別のモジュール構成例を示す。仮想スイッチ401は、例えばDPDK(Data Plane Development Kit)ライブラリ及びDPDKドライバを用いて、仮想化基盤において仮想マシン205及びNIC(ネットワークインターフェースカード)403の間で伝送されるパケットを中継する。DPDKライブラリは、主にパケット処理の高速化を図る目的で使用される。そのため、DPDKドライバは、ポーリング方式を採用し、ネットワークインターフェース及び仮想マシンインターフェースを提供している。
ここでは、サーバ装置101が有する複数のCPUのうち一部のCPUが、仮想スイッチ401に独占的に割り当てられるものとする。従って、仮想スイッチ401が一部のCPUを専有する。仮想スイッチ401によって専有されるCPUの使用率をホストOS201で計測した例を図5に示す。このような動作態様では、常にユーザモードによってCPUが100%使用しているように見える。つまり、仮想スイッチ401に係る負荷が高い場合と低い場合とを区別できない。
本実施の形態では、ホストOS201でアプリケーション203によるCPU使用率を正しく計測できない場合にも、アプリケーション203の負荷をより正しく推測できるようにする。尚、仮想スイッチ401は、アプリケーション203の一態様である。他のアプリケーション203に、本実施の形態を適用するようにしてもよい。
本実施の形態では、CPUにおける実行アドレスの度数分布に着目する。図6に、実行アドレスの度数分布の例を示す。仮想スイッチ401の負荷が低い場合には、処理待ちに係るルーチンの実行がメインになる。従って、下段に示すように、実行アドレスが一箇所に集中する。一方、仮想スイッチ401の負荷が高い場合には、処理待ちに係るルーチンの他に、パケットの転送処理に係るルーチンが実行される割合が多くなる。従って、上段に示すように、実行アドレスが複数の箇所に分散する。このように、負荷に応じてCPUの走行状況が異なるという特性を活かす。
図7に、本実施の形態に係るサーバ装置101のモジュール構成例を示す。ホストOS201に設けられた収集ドライバ701は、仮想スイッチ401が専有しているCPUのプログラムカウンタ値(つまり、実行アドレス)をサンプリングする。実行アドレスは、ログテーブルとして走行データ記憶部703に記憶される。分析エージェント705は、ログテーブルを分析して、仮想スイッチ401の負荷を推測する。尚、収集ドライバ701は、タイマ707のハードウエア割り込みのタイミングで実行アドレス値を取得する。
図8に、シーケンスの例を示す。この例では、2つのログテーブルを交互に使用して、絶え間なくサンプリング及び分析を行うようにする。
まず、分析エージェント705は、収集ドライバ701へサンプリング開始の指示を送る(S801)。収集ドライバ701が書き込むログテーブルは、当該指示において指定されているものとする。例えば、テーブルID:1が指定されているものとする。
収集ドライバ701は、サンプリング開始の指示を受けると、実行アドレス値のサンプリングを行う(S803)。1回のサンプリング期間は、例えば1秒である。この例で、収集ドライバ701は、その間に1000個のサンプルを採取するものとする。そのため、タイマ707は、1ミリ秒の周期でハードウエア割り込みを発生させる。
サンプリング終了のタイミングに至ると、収集ドライバ701は、分析エージェント705へサンプリング終了の通知を送る(S805)。尚、サンプリングを終える時点で、ログテーブルへの書き込みは完了している。
分析エージェント705は、サンプリング終了の通知を受けると、2回目のサンプリング開始の指示を収集ドライバ701へ送る(S807)。このときの指示に、別のログテーブルが指定されている。この例では、テーブルID:2が指定されているものとする。
続いて、分析エージェント705は、テーブルID:1に係るログテーブルの分析を行う(S809)。このとき、複数の負荷レベルの各々に対応するCPU走行パターンに基づいて、現状における負荷レベルを特定する。CPU走行パターンのデータは、予め用意されているものとする。
ログテーブルの分析を終えると、分析エージェント705は、管理装置103へ分析結果(例えば、現状の負荷レベル)の通知を送る(S811)。
一方、収集ドライバ701は、この間2回目のサンプリングを行う(S813)。2回目のサンプリングの結果は、テーブルID:2のログテーブルに書き込まれる。そして、2回目のサンプリングを終えると、収集ドライバ701は、分析エージェント705へサンプリング終了の通知を送る(S815)。
分析エージェント705は、2回目のサンプリング終了の通知を受けると、3回目のサンプリング開始の指示を収集ドライバ701へ送る(S817)。このときの指示で、テーブルID:1が指定される。
続いて、分析エージェント705は、テーブルID:2に係るログテーブルの分析を行う(S819)。そして、ログテーブルの分析を終えると、分析エージェント705は、管理装置103へ分析結果の通知を送る(S821)。以降、同様の処理を繰り返す。尚、分析エージェント705は、複数回の分析結果をまとめて、管理装置103へ送るようにしてもよい。
図9に、ログテーブルの例を示す。この例におけるログテーブルは、サンプルに対応するレコードを有している。ログテーブルのレコードは、サンプル番号が格納されるフィールドと、実行アドレス値が格納されるフィールドとを有している。
サンプル番号は、サンプル採取の順番を示し、サンプルを識別する。実行アドレス値は、このサンプリングにおけるサンプルに相当する。この例では、1000個のサンプルが格納されている。
続いて、収集ドライバ701における処理について説明する。収集ドライバ701は、開始処理及びハンドラ処理を行う。開始処理において、サンプリングが開始する。ハンドラ処理において、サンプリングが行われる。
図10に、開始処理フローを示す。収集ドライバ701は、待機して、分析エージェント705からサンプリング開始の指示を受け付ける(S1001)。収集ドライバ701は、サンプリング開始の指示に含まれるテーブルIDで指定されるログテーブルを初期化する。更に、収集ドライバ701は、ログテーブルの書き込み先レコードを指すポインタとサンプル数とを初期化する(S1003)。具体的には、初期状態のポインタは1であり、同じくサンプル数は0である。ポインタ及びサンプル数は、内部パラメータである。
収集ドライバ701は、タイマ割り込みの周期を設定する(S1005)。この例におけるタイマ割り込みの周期は、1ミリ秒である。そして、収集ドライバ701は、タイマ割り込みを起動する(S1007)。その後、S1001の処理に戻る。
次に、ハンドラ処理について説明する。ハンドラ処理は、タイマ割り込みが発生した時に起動される。図11に、ハンドラ処理フローを示す。まず、収集ドライバ701は、タイマ割り込み発生時点におけるレジスタ値を退避させる(S1101)。
次に、収集ドライバ701は、タイマ割り込み発生時点における実行アドレス値を取得し(S1103)、ポインタが指すレコードに当該実行アドレス値を格納する(S1105)。そして、収集ドライバ701は、ポインタ及びサンプル数を更新する(S1107)。具体的には、収集ドライバ701は、ポインタに1を加え、サンプル数に1を加える。
収集ドライバ701は、サンプリング期間を終えたか否かを判定する(S1109)。具体的には、収集ドライバ701は、S1001においてサンプリング開始の指示を受け付けた時点から所定時間(この例では、1秒)が経過したか否かを判定する。或いは、収集ドライバ701は、サンプル数が所定数(この例では、1000)に至ったか否かを判定するようにしてもい。
サンプリング期間を終えていないと判定した場合には、収集ドライバ701は、レジスタ値を元に戻し(S1115)、ハンドラ処理を終える。
一方、サンプリング期間を終えたと判定した場合には、収集ドライバ701は、タイマ割り込みを停止させ(S1111)、分析エージェント705へサンプリング終了の通知を送る(S1113)。収集ドライバ701は、レジスタ値を元に戻し(S1115)、ハンドラ処理を終える。以上で、収集ドライバ701についての説明を終える。
続いて、分析エージェント705について説明する。図12に、分析エージェント705のモジュール構成例を示す。分析エージェント705は、指示部1201、集計部1203、推定部1205、送信部1207、度数分布記憶部1221、走行状況記憶部1223及び走行パターン記憶部1225を有する。
指示部1201は、収集ドライバ701へサンプリングの開始を指示する。集計部1203は、走行データ(この例では、ログテーブル)に基づいてCPUの走行状況を集計する。つまり、集計結果として、CPUの走行状況が特定される。推定部1205は、アプリケーション203の負荷を推定する。送信部1207は、分析結果を管理装置103へ送信する。
度数分布記憶部1221は、度数分布テーブルを記憶する。度数分布テーブルについては、図13を用いて後述する。走行状況記憶部1223は、走行状況データを記憶する。走行状況データについては、図14を用いて後述する。走行パターン記憶部1225は、走行パターンテーブルを記憶する。走行パターンテーブルについては、図15を用いて後述する。
上述した指示部1201、集計部1203、推定部1205及び送信部1207は、ハードウエア資源(例えば、図38)と、以下で述べる処理をプロセッサに実行させるプログラムとを用いて実現される。
上述した度数分布記憶部1221、走行状況記憶部1223及び走行パターン記憶部1225は、ハードウエア資源(例えば、図38)を用いて実現される。
図13に、度数分布テーブルの例を示す。この度数分布における階級は、実行アドレスの範囲に相当する。以下では、この実行アドレスの範囲をブロックという。この例における度数分布テーブルは、ブロックに対応するレコードを有している。度数分布テーブルのレコードは、ブロック範囲が格納されるフィールドと、サンプル数が格納されるフィールドと、占有率が格納されるフィールドとを有している。
この例では、ブロックを指定するデータとしてブロック範囲(つまり、開始アドレスと終了アドレス)を示しているが、本実施の形態におけるブロックは固定サイズであるので、ブロックを指定するデータとして、ブロックの開始アドレス或いは終了アドレスのいずれか一方のみを用いるようにしてもよい。サンプル数は、当該ブロック範囲に含まれる実行アドレス値の数である。占有率は、総サンプル数に対する当該ブロックのサンプル数の割合である。
例えば、図示した1番目のレコードは、アドレス「0x004062c0〜0x004062ff」に相当するブロックに含まれる実行アドレス値の数が「160」あることを示している。また、当該サンプルの割合は「16%」である。
図14に、走行状況データの例を示す。走行状況データは、上述した度数分布に基づいて生成される。図14の例では、サンプル数が最も多いブロック、サンプル数が2番目に多いブロック及びサンプル数が3番目に多いブロックにおける各占有率が抽出されている。また、サンプル数が基準を超えるブロックの数がカウントされている。これらの占有率やブロック数は、度数分布に関する特徴の例である。尚、度数分布に関する他の特徴を走行状況データとして用いるようにしてもよい。
図15に、走行パターンテーブルの例を示す。走行パターンテーブルは、事前に用意されているものとする。走行パターンテーブルの内容は、例えば管理装置103が既知の負荷に係る要求をアプリケーション203に送った場合のCPUの走行状況などを参考に設定される。
この例における走行パターンテーブルは、走行パターンに対応するレコードを有している。走行パターンテーブルのレコードは、負荷レベルが格納されるフィールドと、アプリケーション203のCPU使用率が格納されるフィールドと、第1特徴ブロック乃至第3特徴ブロックについて、ブロック範囲が格納されるフィールド及び占有率が格納されるフィールドとを有している。当該レコードは、更に、サンプル数が基準を超えるブロックの数が格納されるフィールドも有している。
負荷レベルは、当該走行パターンにおける負荷の程度を「1」乃至「7」の段階で表す。この例では、昇順に負荷が大きいものとする。また、各負荷レベルは、図示したアプリケーション203のCPU使用率に相当する。例えば、負荷レベル「3」は、アプリケーション203のCPU使用率「40%」に相当する。尚、負荷レベル「7」は、アプリケーション203の負荷が限界を超えた状態に相当する。
続いて、分析エージェント705における分析処理について説明する。図16に、分析処理フローを示す。指示部1201は、最初に使用するログテーブルを選択する(S1601)。指示部1201は、収集ドライバ701へサンプリング開始の指示(選択されたログテーブルのIDを含む。)を送る(S1603)。
その後、指示部1201は、待機して、収集ドライバ701からサンプリング終了の通知を受ける(S1605)。そして、指示部1201は、ログテーブルを切り替えて(S1607)、収集ドライバ701へサンプリング開始の指示(切り替えられたログテーブルのIDを含む。)を送る(S1609)。
続いて、集計部1203は、集計処理を実行する(S1611)。本実施の形態では、集計処理(A)を実行する。図17に、集計処理(A)フローを示す。集計部1203は、サンプリングによって記録されたログテーブルにおけるサンプルを1つ選択する(S1701)。例えば、集計部1203は、採取された順番に従ってサンプルを選択する。
集計部1203は、当該サンプルの実行アドレス値が属するブロックを選択する(S1703)。例えば、実行アドレス値における所定の下位ビットをマスクすることによって、属するブロックの開始アドレスを特定する。
集計部1203は、度数分布テーブルに、特定されたブロックのレコードがあるか否かを判定する(S1705)。度数分布テーブルに当該ブロックのレコードがないと判定した場合には、集計部1203は、度数分布テーブルに、当該ブロックのレコードを新たに設ける(S1707)。そして、集計部1203は、当該レコードのサンプル数を格納するためのフィールドに1を設定する(S1709)。
一方、度数分布テーブルに当該ブロックのレコードがあると判定した場合には、集計部1203は、当該レコードにおけるサンプル数に1を加える(S1711)。
そして、集計部1203は、S1701において未だ集計されていないサンプルが残っているか否かを判定する(S1713)。未選択のサンプルが残っていると判定した場合には、S1701に示した処理に戻って、上述した処理を繰り返す。
一方、未集計のサンプルがないと判定した場合には、集計部1203は、各ブロックにおける占有率を算出する(S1715)。具体的には、当該ブロックにおけるサンプル数を総サンプル数で除することによって、占有率が求められる。占有率は、度数分布テーブルのレコードに設定される。
集計部1203は、占有率が高い順にブロックを3つ抽出する(S1717)。そして、集計部1203は、これらのブロックの範囲及び占有率を、走行状況記憶部1223で記憶する走行状況データに設定する。更に、集計部1203は、占有率が基準を超えるブロックを数える(S1719)。占有率が基準を超えるブロックの数も、走行状況記憶部1223で記憶する走行状況データに設定される。集計処理(A)を終えると、呼び出し元の分析処理に復帰する。
図16の説明に戻る。推定部1205は、推定処理を実行する(S1613)。本実施の形態では、推定処理(A)を実行する。図18に、推定処理(A)フローを示す。推定部1205は、走行パターンテーブルにおける負荷レベルパターンについて順次比較処理を行う(S1801)。例えば、推定部1205は、昇順に負荷レベルパターンを処理する。
推定部1205は、走行状況データに対し、比較対象として選択した負荷レベルとの類似度算出処理を実行する(S1803)。類似度算出処理では、走行状況と当該走行パターンとの類似度を算出する。
図19に、類似度算出処理フローを示す。推定部1205は、各指標の差を求める(S1901)。この例では、サンプル数が最も多いブロックにおける占有率、サンプル数が2番目に多いブロックにおける占有率、サンプル数が3番目に多いブロックにおける占有率及び占有率が基準を超えるブロック数が、指標に相当する。各指標について、走行状況における指標と走行パターンにおける同種の指標の差を算出する。但し、ブロック数を除き、各占有率のみを指標として用いるようにしてもよい。
推定部1205は、各指標の差に基づいて全体的な差を求める(S1903)。各指標の差に基づいて全体的な差を算出する方法は、従来技術であってもよい。例えば、各差の二乗和を求め、当該二乗和の平方根を算出するようにしてもよい。全体的な差が小さい場合に、類似度が高くなることを意味する。類似度算出処理を終えると、呼び出し元の推定処理(A)に復帰する。
図18の説明に戻る。推定部1205は、未処理の負荷レベルがあるか否かを判定する(S1805)。未処理の負荷レベルがあると判定した場合には、S1801に示した処理に戻って、上述した処理を繰り返す。
一方、未処理の負荷レベルがないと判定した場合には、推定部1205は、類似度が最も高い負荷レベルを選択する(S1807)。推定処理(A)を終えると、呼び出し元の分析処理に復帰する。
図16の説明に戻る。送信部1207は、分析結果の通知を送信する(S1615)。具体的には、負荷レベル(或いは負荷レベルに対応するアプリケーションCPU使用率)が通知される。そして、S1605に示した処理に戻る。
本実施の形態によれば、所定プログラムの負荷を、より簡便に把握できる。
また、負荷の大小によって実行箇所が異なるという特性に基づき、より正しく負荷を推測できる面もある。
[実施の形態2]
上述した実施の形態では、最も近似する負荷レベルを推定する例について説明したが、本実施の形態では、2つの負荷レベルの内分点に相当する負荷の程度(アプリケーションCPU使用率)を推定する例について説明する。
本実施の形態では、推定処理(A)に代えて、推定処理(B)を実行する。図20に、推定処理(B)フローを示す。また、推定処理(A)の場合、走行パターンテーブルのパターンの順序は必ずしも図15の昇順に並んでいる必要はないが、推定処理(B)では、昇順(あるいは降順)に並んでいる必要がある。推定部1205は、走行状況データに対し、比較対象として選択した負荷レベルとの類似度算出処理を実行する(S2001,S2003)。この類似度算出処理は、前記推定処理(A)の場合と同様である。
推定部1205は、パターンテーブルの負荷レベルすべてに対し類似度算出処理を終えたか否かを判定する(S2005)。未処理の指標があると判定した場合には、S2001に示した処理に戻って、上述した処理を繰り返す。一方、未処理の指標がないと判定した場合には、推定部1205は、類似度がもっとも高いレベルのひとつ前のレベルとひとつ後のレベルの類似度を比較する(S2007)。たとえば、レベル4の類似度がもっとも高かった場合、レベル3とレベル5の類似度を比較する。比較の結果、前のレベルが高かったら類似度がもっとも高かったレベルと、その前のレベルを選択する(S2009)。また、後のレベルが高かったら類似度がもっとも高かったレベルと、その次のレベルを選択する(S2011)。
次に推定部1205は、選択した2つのレベルの走行パターンが示すCPU使用率を、それぞれのレベルに対する類似度で内分した値を走行状況データに対するCPU使用率として算出する。たとえば、もっとも類似度が高かったレベルが4でそのCPU使用率がSで類似度がX、またS2007の比較で選択されたレベルが5でそのCPU使用率がTで類似度がYとすると、走行状況におけるアプリケーションCPU使用率Tは、X×S+Y×Uを(X+Y)で除することによって求められる。
推定処理(B)を終えると、呼び出し元の分析処理に復帰する。
本実施の形態によれば、より細かい精度でアプリケーション203の負荷を把握できる。
[実施の形態3]
上述した実施の形態では、ブロックが均等に分割された範囲とした例について説明したが、本実施の形態では、ブロックが所定の上限幅内に含まれる実行アドレスの広がりに応じて設定される例について説明する。
図21に、実施の形態3におけるブロックの例を示す。矢印2101は、実行アドレスを示している。この例では、ブロックの上限幅を、第1基準サイズ及び第2基準サイズで表す。
第1基準サイズは、例えばコードサイズが比較的小さい関数の大きさを基準として設定される。そして、第1基準サイズを超えない距離に納まる実行アドレス群の広がりをブロックと看做す。このブロックを小タイプのブロックという。この例で、矢印2101a乃至矢印2101dの範囲を1番目の小タイプのブロックとする。同じく矢印2101e乃至矢印2101iの範囲を2番目の小タイプのブロックとする。同じく矢印2101j乃至矢印2101mの範囲を3番目の小タイプのブロックとする。
第2基準サイズは、例えばコードサイズが比較的大きい関数の大きさを基準として設定される。そして、第2基準サイズを超えない距離に納まる実行アドレス群の広がりを大タイプのブロックと看做す。この例で、矢印2101a乃至矢印2101gの範囲を1番目の大タイプのブロックとする。同じく矢印2101h乃至矢印2101mの範囲を2番目の大タイプのブロックとする。
図22に、実施の形態3における度数分布テーブルの例を示す。この例における度数分布テーブルは、小タイプのブロック及び大タイプのブロックに対応するレコードを有している。度数分布テーブルのレコードは、タイプを示すコード値が格納されるフィールドと、開始アドレスが格納されるフィールドと、サイズが格納されるフィールドと、サンプル数が格納されるフィールドと、占有率が格納されるフィールドとを有している。
タイプを示すコード値によって、ブロックのタイプが区別される。開始アドレスは、ブロックの開始位置を示す。サイズの代わりに、終了アドレスを格納するようにしてもよい。サンプル数は、当該ブロック範囲に含まれる実行アドレス値の数である。占有率は、総サンプル数に対する当該ブロックのサンプル数の割合である。
本実施の形態では、集計処理(A)に代えて、集計処理(B)を実行する。図23A乃至図23Dに、集計処理(B)フローを示す。集計部1203は、ログテーブルのレコードを実行アドレス値の昇順にソートする(S2301)。
集計部1203は、ソート結果における先頭の実行アドレス値から処理を開始する(S2303)。集計部1203は、度数分布テーブルに新たなレコードを生成し、当該レコードにおけるタイプのフィールドに「小」を設定する(S2305)。集計部1203は、先頭の実行アドレス値を、当該レコードにおける開始アドレスのフィールドに設定する(S2307)。また、集計部1203は、当該レコードにおけるサンプル数のフィールドに1を設定する(S2309)。端子Aを介して、図23Bに示したS2311の処理に移る。
図23Bの説明に移る。集計部1203は、末尾の実行アドレス値であるかどうかを判定する(S2311)。
末尾の実行アドレス値でない場合には、集計部1203は、次の実行アドレス値を選択し(S2313)、当該実行アドレス値と開始アドレスとの差を求める(S2315)。そして、集計部1203は、当該差が第1基準サイズを超えたか否かを判定する(S2317)。
S2313で選択した実行アドレス値と開始アドレスとの差が第1基準サイズを超えていないと判定した場合には、集計部1203は、生成中のレコード(図23AのS2305で設定されたレコード又は後述するS2325で設定されたレコード)におけるサンプル数に1を加える(S2319)。その後、S2311に示した処理に戻って、上述した処理を繰り返す。
一方、S2313で選択した実行アドレス値と開始アドレスとの差が第1基準サイズを超えたと判定した場合には、集計部1203は、その実行アドレス値を当該ブロックの終了アドレスとする(S2321)。当該ブロックの終了アドレスは、直近のS2313の処理で選択した実行アドレス値より1つ遡った実行アドレス値である。集計部1203は、終了アドレスと開始アドレスとの差を、生成中のレコードにおけるサイズのフィールドに設定する(S2323)。
集計部1203は、度数分布テーブルに新たなレコードを設け、当該レコードにおけるタイプのフィールドに「小」を設定する(S2325)。集計部1203は、直近のS2313の処理で選択した実行アドレス値を、新たなレコードにおける開始アドレスのフィールドに設定する(S2327)。集計部1203は、当該レコードにおけるサンプル数のフィールドに1を設定する(S2329)。その後、S2311に示した処理に戻って、上述した処理を繰り返す。
S2311の説明に戻る。S2311において、次の実行アドレス値がないと判定した場合、つまり最大の実行アドレス値に関する処理を終えた場合には、集計部1203は、最大の実行アドレス値と開始アドレスとの差を、生成中のレコードにおけるサイズのフィールドに設定する(S2331)。
そして、集計部1203は、小タイプの各ブロックにおける占有率を算出する(S2333)。具体的には、当該ブロックにおけるサンプル数を総サンプル数で除することによって、当該ブロックにおける占有率が求められる。占有率は、度数分布テーブルのレコードに設定される。
集計部1203は、占有率が高い順に小タイプのブロックを3つ抽出する(S2335)。そして、集計部1203は、これらのブロックの範囲及び占有率を、走行状況記憶部1223で記憶する走行状況データに設定する。以上で、小タイプのブロックに関する処理を終える。そして、端子Bを介して、図23Cに示したS2337の処理に移る。尚、この例における走行状況データは、占有率が高い小タイプのブロック3個分のデータと、占有率が高い大タイプのブロック3個分のデータとを抽出している。この走行状況データの例は、図示していない。
図23Cの説明に移る。以下では、大タイプのブロックに関する処理を行う。集計部1203は、再度ソート結果における先頭の実行アドレス値から順に選択し処理を行う(S2337)。集計部1203は、度数分布テーブルに新たなレコードを設け、当該レコードにおけるタイプのフィールドに「大」を設定する(S2339)。集計部1203は、先頭の実行アドレス値を、当該レコードにおける開始アドレスのフィールドに設定する(S2341)。集計部1203は、当該レコードにおけるサンプル数のフィールドに1を設定する(S2343)。端子Cを介して、図23Dに示したS2345の処理に移る。
図23Dの説明に移る。S2345乃至S2349の処理は、図23Bに示したS2311乃至S2315の処理の場合と同様である。
集計部1203は、S2347で選択した実行アドレス値と開始アドレスとの差が第2基準サイズを超えたか否かを判定する(S2351)。当該差が第2基準サイズを超えていないと判定した場合には、集計部1203は、生成中のレコード(図23CのS2339で設定されたレコード又は後述するS2359で設定されたレコード)におけるサンプル数に1を加える(S2353)。そして、S2345に示した処理に戻って、上述した処理を繰り返す。
一方、当該差が第2基準サイズを超えたと判定した場合におけるS2355及びS2357の処理は、図23Bに示したS2321及びS2323の処理の場合と同様である。
集計部1203は、度数分布テーブルに新たなレコードを設け、当該レコードにおけるタイプのフィールドに「大」を設定する(S2359)。集計部1203は、直近のS2347の処理で選択した実行アドレス値を、新たなレコードにおける開始アドレスのフィールドに設定する(S2361)。S2363の処理は、図23Bに示したS2329の処理の場合と同様である。その後、S2345に示した処理に戻って、上述した処理を繰り返す。
S2345において、次の実行アドレス値がないと判定した場合、つまり最大の実行アドレス値に関する処理を終えた場合には、集計部1203は、最大の実行アドレス値と開始アドレスとの差を、生成中のレコードにおけるサイズのフィールドに設定する(S2365)。
集計部1203は、大タイプの各ブロックにおける占有率を算出する(S2367)。具体的には、当該ブロックにおけるサンプル数を総サンプル数で除することによって、占有率が求められる。当該ブロックにおける占有率は、度数分布テーブルのレコードに設定される。
集計部1203は、占有率が高い順に大タイプのブロックを3つ抽出する(S2369)。そして、集計部1203は、これらのブロックの範囲及び占有率を、走行状況記憶部1223で記憶する走行状況データに設定する。集計処理(B)を終えると、呼び出し元の分析処理に復帰する。
図24に、実施の形態3における走行パターンテーブルの例を示す。この例における走行パターンテーブルは、走行パターンに対応するレコードを有している。走行パターンテーブルのレコードは、負荷レベルが格納されるフィールドと、アプリケーション203のCPU使用率が格納されるフィールドと、第1特徴ブロック乃至第3特徴ブロックについてタイプが格納されるフィールド、開始アドレスが格納されるフィールド、サイズが格納されるフィールド及び占有率が格納されるフィールドを有している。各占有率が、指標に相当する。
本実施の形態では、推定処理(A)又は推定処理(B)のいずれを適用するようにしてもよい。いずれの場合であっても、同種の指標、つまり共通のブロックにおける占有率を比較対象とする。
本実施の形態によれば、アプリケーション203の関数と見込まれる箇所の実行頻度に基づいて、負荷状態を判別し易くなる。
また、コードサイズが大きい関数と見込まれる箇所及び小さい関数と見込まれる箇所における実行頻度に基づいて、負荷状態を判別し易くなる。
[実施の形態4]
上述した実施の形態では、実行アドレスの度数分布に基づいて分析を行う例について説明したが、本実施の形態では、関数の実行頻度に基づいて分析を行う例について説明する。
図25に、実施の形態4における分析エージェント705のモジュール構成例を示す。分析エージェント705は、指示部1201、集計部1203、推定部1205、送信部1207、関数テーブル記憶部2551、実行状況記憶部2553、重み記憶部2555、実行パターン記憶部2557及びグループテーブル記憶部2559を有する。
関数テーブル記憶部2551は、関数テーブルを記憶する。関数テーブルについては、図26を用いて後述する。実行状況記憶部2553は、実行状況テーブルを記憶する。実行状況テーブルについては、図27を用いて後述する。重み記憶部2555は、重みデータを記憶する。重みデータについては、図30を用いて後述する。実行パターン記憶部2557は、実行パターンテーブルを記憶する。実行パターンテーブルについては、図29を用いて後述する。グループテーブル記憶部2559は、グループテーブルを記憶する。グループテーブルについては、実施の形態5において図32を用いて後述する。
上述した関数テーブル記憶部2551、実行状況記憶部2553、重み記憶部2555、実行パターン記憶部2557及びグループテーブル記憶部2559は、ハードウエア資源(例えば、図38)を用いて実現される。
図26に、関数テーブルの例を示す。この例における関数テーブルは、関数に対応するレコードを有している。関数テーブルのレコードは、関数名が格納されるフィールドと、先頭アドレスが格納されるフィールドと、サイズが格納されるフィールドとを有している。
先頭アドレスは、当該関数のプログラムが始まる位置を示す。サイズは、当該関数のプログラムの大きさである。関数テーブルに代えて、アプリケーション203に含まれるプログラム配置のデータを用いるようにしてもよい。
図27に、実行状況テーブルの例を示す。この例における実行状況テーブルは、実行された関数に対応するレコードを有している。実行状況テーブルのレコードは、関数名が格納されるフィールドと、サンプル数が格納されるフィールドと、占有率が格納されるフィールドとを有している。
関数名は、実行された関数を識別する。サンプル数は、当該関数のプログラム範囲に含まれる実行アドレス値の数である。占有率は、総サンプル数に対する当該関数のサンプル数の割合である。
本実施の形態では、図16に示したS1611において集計処理(C)を実行する。図28に、集計処理(C)フローを示す。集計部1203は、先頭から順次サンプルを選択し(S2801)、関数テーブルに基づいて、当該サンプルの実行アドレス値が属する関数を特定する(S2803)。
集計部1203は、実行状況テーブルに当該関数のレコードがあるか否かを判定する(S2805)。実行状況テーブルに当該関数のレコードがないと判定した場合には、集計部1203は、実行状況テーブルに、当該関数のレコードを追加する(S2807)。集計部1203は、当該レコードのサンプル数を格納するためのフィールドに1を設定する(S2809)。
一方、実行状況テーブルに当該関数のレコードがあると判定した場合には、集計部1203は、当該レコードにおけるサンプル数に1を加える(S2811)。
そして、集計部1203は、S2801において処理対象のサンプルの末尾まで終えたかを判定する(S2813)。処理対象のサンプルの末尾まで終わっていない場合には、S2801に示した処理に戻って、上述した処理を繰り返す。
一方、処理対象のサンプルの末尾まで終えたと判定した場合には、集計部1203は、各関数における占有率を算出する(S2815)。具体的には、当該関数におけるサンプル数を総サンプル数で除することによって、占有率が求められる。占有率は、実行状況テーブルのレコードに設定される。集計処理(C)を終えると、呼び出し元の分析処理に復帰する。
図29に、実行パターンテーブルの例を示す。この例における実行パターンテーブルのレコードは、負荷レベルが格納されるフィールドと、アプリケーション203のCPU使用率が格納されるフィールドと、着目する関数の占有率が格納されるフィールドとを有している。
負荷レベルは、当該実行パターンにおける負荷の程度を「1」乃至「6」の段階で示す。各負荷レベルは、図示したアプリケーション203のCPU使用率に相当する。アプリケーション203の負荷が限界を超えた状態に相当する負荷レベル「7」を設けるようにしてもよい。
図30に、重みデータの例を示す。重みデータには、着目する関数に対する重みが設定されている。
本実施の形態では、図16に示したS1613において、推定処理(C)を実行する。図31に、推定処理(C)フローを示す。推定部1205は、着目する関数、つまり実行パターンテーブルで占有率が設定されている関数を順次選択する(S3101)。
推定部1205は、当該関数の占有率に基づき推定されるアプリケーションCPU使用率を算出する(S3103)。
ここでは、実行状況テーブルにおける当該関数の占有率Yが、アプリケーションCPU使用率Sに相当する実行パターンAにおける当該関数の占有率Xと、アプリケーションCPU使用率Uに相当する別の実行パターンBにおける当該関数の占有率Zとの中間であるものとする。2つの占有率XとYの内分点に当たる占有率Zに関して、占有率の差に関する比をアプリケーションCPU使用率の差に適用して、内分点に該当するアプリケーションCPU使用率Tを求めるようにする。具体的には、推定部1205は、実行状況テーブルにおける当該関数の占有率と実行パターンAにおける当該関数の占有率との差(Y−X)を求める。また、推定部1205は、実行パターンBにおける当該関数の占有率と走行状況における当該関数の占有率との差(Z−Y)を求める。そして、実行状況におけるアプリケーションCPU使用率Tは、(Y−X)U+(Z−Y)Sを(Z−X)で除することによって求められる。
推定部1205は、未処理の関数があるか否かを判定する(S3105)。未処理の関数があると判定した場合には、S3101に示した処理に戻って、上述した処理を繰り返す。
一方、未処理の関数がないと判定した場合には、推定部1205は、重みデータに基づいて、アプリケーション203のCPU使用率の加重平均を算出する(S3107)。
更に、推定部1205は、アプリケーション203のCPU使用率の上限に対する現状のCPU使用率の割合を算出する(S3109)。アプリケーション203のCPU使用率の上限は、予め設定されているものとする。当該上限は、例えば資源不足や動作不良などの異常事態に至る恐れがある負荷のレベルに相当する。当該上限は、100%より低いCPU使用率に相当することもある。推定処理(C)を終えると、呼び出し元の分析処理に復帰する。
本実施の形態によれば、アプリケーション203の負荷を、より簡便に把握できる。特に、機能的な単位で実行頻度を比較できるという面がある。
また、内分点に相当するアプリケーションCPU使用率を使用するので、実行パターンテーブルのレコード数が少なくても推定の精度が高まる。
また、アプリケーションCPU使用率の加重平均を求めるので、各関数の重要性に応じて、より正しく負荷を把握できる。
また、負荷の限界に相当するアプリケーションCPU使用率に対する現状のアプリケーションCPU使用率の割合を算出するので、異常事態に関する切迫の度合いを把握し易くなる。
[実施の形態5]
本実施の形態では、関数のグループにおける実行頻度に基づいて分析を行う例について説明する。
図32に、グループテーブルの例を示す。グループテーブルは、グループに属する関数を定義する。この例におけるグループテーブルは、グループに対応するレコードを有している。グループテーブルのレコードは、グループ名が格納されるフィールドと、関数名が格納される複数のフィールドとを有している。グループ名は、グループを識別する。関数名は、その関数が当該グループのメンバーであることを示す。
図33に、実施の形態5における実行状況テーブルの例を示す。この例における実行状況テーブルは、実行された関数のグループに対応するレコードを有している。実行状況テーブルのレコードは、グループ名が格納されるフィールドと、サンプル数が格納されるフィールドと、占有率が格納されるフィールドとを有している。
グループ名は、実行された関数が属するグループを示す。サンプル数は、当該グループに属するいずれかの関数について、当該関数のプログラム範囲に含まれる実行アドレス値の数である。占有率は、総サンプル数に対する当該グループのサンプル数の割合である。
本実施の形態では、図16に示したS1611において、集計処理(D)を実行する。図34に、集計処理(D)フローを示す。集計部1203は、サンプルを順次選択し(S3401)、集計部1203は、関数テーブルに基づいて、当該サンプルの実行アドレス値が属する関数を特定する(S3403)。更に、集計部1203は、グループテーブルに基づいて、当該関数のグループを特定する(S3405)。
集計部1203は、実行状況テーブルに当該グループのレコードがあるか否かを判定する(S3407)。実行状況テーブルに当該グループのレコードがないと判定した場合には、集計部1203は、実行状況テーブルに、当該グループのレコードを新たに設ける(S3409)。集計部1203は、当該レコードのサンプル数を格納するためのフィールドに1を設定する(S3411)。
一方、実行状況テーブルに当該関数のレコードがあると判定した場合には、集計部1203は、当該レコードにおけるサンプル数に1を加える(S3413)。
そして、集計部1203は、S3401において未処理のサンプルがあるか否かを判定する(S3415)。未処理のサンプルがあると判定した場合には、S3401に示した処理に戻って、上述した処理を繰り返す。
一方、すべてのサンプルについて処理を終えた場合には、集計部1203は、各グループにおける占有率を算出する(S3417)。具体的には、当該グループにおけるサンプル数を総サンプル数で除することによって、占有率が求められる。占有率は、実行状況テーブルのレコードに設定される。集計処理(D)を終えると、呼び出し元の分析処理に復帰する。
図35に、実施の形態5における実行パターンテーブルの例を示す。この例における実行パターンテーブルのレコードは、負荷レベルが格納されるフィールドと、アプリケーション203のCPU使用率が格納されるフィールドと、着目するグループの占有率が格納されるフィールドとを有している。
負荷レベルは、当該実行パターンにおける負荷の程度を「1」乃至「6」の段階で示す。各負荷レベルは、図示したアプリケーション203のCPU使用率に相当する。アプリケーション203の負荷が限界を超えた状態に相当する負荷レベル「7」を設けるようにしてもよい。
図36に、実施の形態5における重みデータの例を示す。重みデータには、着目するグループに対する重みが設定されている。
本実施の形態では、図16に示したS1613において、推定処理(D)を実行する。図37に、推定処理(D)フローを示す。推定部1205は、着目するグループ、つまり実行パターンテーブルで占有率が設定されているグループを順次選択する(S3701)。
推定部1205は、当該グループの占有率に基づき推定されるアプリケーションCPU使用率を算出する(S3703)。
ここでは、実行状況テーブルにおける当該グループの占有率Yが、アプリケーションCPU使用率Sに相当する実行パターンAにおける当該グループの占有率Xと、アプリケーションCPU使用率Uに相当する別の実行パターンBにおける当該グループの占有率Zとの中間であるものとする。2つの占有率XとYの内分点に当たる占有率Zに関して、占有率の差に関する比をアプリケーションCPU使用率の差に適用して、内分点に該当するアプリケーションCPU使用率Tを求めるようにする。具体的には、推定部1205は、実行状況テーブルにおける当該グループの占有率と実行パターンAにおける当該グループの占有率との差(Y−X)を求める。また、推定部1205は、実行パターンBにおける当該グループの占有率と走行状況における当該グループの占有率との差(Z−Y)を求める。そして、実行状況におけるアプリケーションCPU使用率Tは、(Y−X)U+(Z−Y)Sを(Z−X)で除することによって求められる。
推定部1205は、未処理のグループがあるか否かを判定する(S3705)。未処理のグループがあると判定した場合には、S3701に示した処理に戻って、上述した処理を繰り返す。
一方、未処理のグループがないと判定した場合には、推定部1205は、重みデータに基づいて、アプリケーション203のCPU使用率の加重平均を算出する(S3707)。
更に、推定部1205は、アプリケーション203のCPU使用率の上限に対する現状のCPU使用率の割合を算出する(S3709)。アプリケーション203のCPU使用率の上限は、予め設定されているものとする。推定処理(D)を終えると、呼び出し元の分析処理に復帰する。
本実施の形態によれば、上位機能の単位で実行頻度を比較できる。
尚、図11に示したS1103の処理において、収集ドライバ701は、タイマ割り込み発生時点における実行アドレス値と共に付属データを取得し、S1105において、ポインタが指すレコードに当該実行アドレス値と共に付属データを格納するようにしてもよい。
付属データは、例えばシステムモードとユーザモードとを区別するための情報である。この場合には、各集計処理において集計対象とするサンプルとして、ユーザモードに係るサンプルのみを選ぶようにしてもよい。
また、付属データは、例えばセグメントを特定するレジスタ又はセレクタであってもよい。この場合には、各集計処理においてサンプルのアドレスや関数を、セグメントによって別々に集計するようにしてもよい。
以上本発明の実施の形態を説明したが、本発明はこれに限定されるものではない。例えば、上述の機能ブロック構成はプログラムモジュール構成に一致しない場合もある。
また、上で説明した各記憶領域の構成は一例であって、上記のような構成でなければならないわけではない。さらに、処理フローにおいても、処理結果が変わらなければ、処理の順番を入れ替えることや複数の処理を並列に実行させるようにしても良い。
なお、上で述べたサーバ装置101は、コンピュータ装置であって、図38に示すように、メモリ2501とCPU2503とハードディスク・ドライブ(HDD:Hard Disk Drive)2505と表示装置2509に接続される表示制御部2507とリムーバブル・ディスク2511用のドライブ装置2513と入力装置2515とネットワークに接続するための通信制御部2517とがバス2519で接続されている。オペレーティングシステム(OS:Operating System)及び本実施例における処理を実施するためのアプリケーション・プログラムは、HDD2505に格納されており、CPU2503により実行される際にはHDD2505からメモリ2501に読み出される。CPU2503は、アプリケーション・プログラムの処理内容に応じて表示制御部2507、通信制御部2517、ドライブ装置2513を制御して、所定の動作を行わせる。また、処理途中のデータについては、主としてメモリ2501に格納されるが、HDD2505に格納されるようにしてもよい。本発明の実施例では、上で述べた処理を実施するためのアプリケーション・プログラムはコンピュータ読み取り可能なリムーバブル・ディスク2511に格納されて頒布され、ドライブ装置2513からHDD2505にインストールされる。インターネットなどのネットワーク及び通信制御部2517を経由して、HDD2505にインストールされる場合もある。このようなコンピュータ装置は、上で述べたCPU2503、メモリ2501などのハードウエアとOS及びアプリケーション・プログラムなどのプログラムとが有機的に協働することにより、上で述べたような各種機能を実現する。
以上述べた本発明の実施の形態をまとめると、以下のようになる。
本実施の形態に係る負荷推定方法は、プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶するコンピュータに、(A)所定プログラムを実行中のプロセッサにおける走行データを収集する処理と、(B)走行データに基づいてプロセッサの走行状況を集計する処理と、(C)走行状況と走行パターンとの比較結果に基づいて、所定プログラムの負荷を推定する推定処理とを実行させる。
このようにすれば、所定プログラムの負荷を、より簡便に把握できる。
更に、走行状況及び走行パターンは、プロセッサにおける実行アドレスの度数分布に基づく特徴を含むようにしてもよい。
このようにすれば、負荷の大小によって実行箇所が異なるという特性に基づき、より正しく負荷を推測できる。
更に、度数分布における階級の範囲は、所定の上限幅内に含まれる実行アドレスの広がりに応じて設定されるようにしてもよい。
このようにすれば、所定プログラムのルーチンと見込まれる箇所の実行頻度に基づいて、負荷状態を判別し易くなる。
更に、走行状況及び走行パターンは、所定の上限幅の異なる2種類の度数分布の各々に基づく特徴を含むようにしてもよい。
このようにすれば、大きいルーチンと見込まれる箇所及び小さいルーチンと見込まれる箇所における実行頻度に基づいて、負荷状態を判別し易くなる。
更に、推定処理において、走行状況に近似する走行パターンに対応する負荷のレベルを特定するようにしてもよい。
このようにすれば、所定の段階に分けて負荷を捉えることができる。
更に、推定処理において、走行状況に含まれる指標と、2つの走行パターンの各々に含まれる同種の指標との各差の比に基づき、当該2つの走行パターンに対応する負荷のレベルの内分点に相当する負荷の程度を特定するようにしてもよい。
このようにすれば、より細かい精度で負荷を把握できる。
本実施の形態に係る負荷推定方法は、プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における所定プログラムのルーチンの実行パターンとを対応付けて記憶するコンピュータに、(D)所定プログラムを実行中のプロセッサにおける走行データを収集する処理と、(E)走行データに基づいてルーチンの実行状況を集計する処理と、(F)実行状況と実行パターンとの比較結果に基づいて、所定プログラムの負荷を推定する推定処理とを実行させる。
このようにすれば、所定プログラムの負荷を、より簡便に把握できる。
更に、実行状況と実行パターンは、プロセッサにおける実行アドレスがルーチンに該当した頻度を含むようにしてもよい。
このようにすれば、機能的な単位で実行頻度を比較できる。
更に、実行状況と実行パターンは、プロセッサにおける実行アドレスがルーチンのグループに該当した頻度を含むようにしてもよい。
このようにすれば、上位機能の単位で実行頻度を比較できる。
更に、推定処理において、実行状況に含まれる指標と、2つの実行パターンの各々に含まれる同種の指標との各差の比に基づき、当該2つの実行パターンに対応する負荷のレベルの内分点に相当する負荷の程度を算出するようにしてもよい。
このようにすれば、より細かい精度で負荷を把握できる。
更に、推定処理において、複数種類の指標の各々について算出した負荷の程度の加重平均を算出するようにしてもよい。
このようにすれば、各指標の重要性に応じて、より正しく負荷を把握できる。
更に、推定処理において、所定プログラムの負荷の限界に対する現状の負荷の割合を算出するようにしてもよい。
このようにすれば、例えば資源不足や動作不良などの異常事態に関する切迫の度合いを把握し易くなる。
なお、上記方法による処理をコンピュータに行わせるためのプログラムを作成することができ、当該プログラムは、例えばフレキシブルディスク、CD−ROM、光磁気ディスク、半導体メモリ、ハードディスク等のコンピュータ読み取り可能な記憶媒体又は記憶装置に格納されるようにしてもよい。尚、中間的な処理結果は、一般的にメインメモリ等の記憶装置に一時保管される。
以上の実施例を含む実施形態に関し、さらに以下の付記を開示する。
(付記1)
プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶するコンピュータに、
前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
前記走行データに基づいて前記プロセッサの走行状況を集計する処理と、
前記走行状況と前記走行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
を実行させる負荷推定プログラム。
(付記2)
前記走行状況及び前記走行パターンは、前記プロセッサにおける実行アドレスの度数分布に基づく特徴を含む
付記1記載の負荷推定プログラム。
(付記3)
前記度数分布における階級の範囲は、所定の上限幅内に含まれる前記実行アドレスの広がりに応じて設定される
付記2記載の負荷推定プログラム。
(付記4)
前記走行状況及び前記走行パターンは、前記所定の上限幅の異なる2種類の前記度数分布の各々に基づく前記特徴を含む
付記3記載の負荷推定プログラム。
(付記5)
前記推定処理において、前記走行状況に近似する前記走行パターンに対応する前記負荷のレベルを特定する
付記1乃至4のいずれか1つ記載の負荷推定プログラム。
(付記6)
前記推定処理において、前記走行状況に含まれる指標と、2つの前記走行パターンの各々に含まれる同種の指標との各差の比に基づき、当該2つの前記走行パターンに対応する前記負荷のレベルの内分点に相当する負荷の程度を算出する
付記1乃至4のいずれか1つ記載の負荷推定プログラム。
(付記7)
プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における前記所定プログラムのルーチンの実行パターンとを対応付けて記憶するコンピュータに、
前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
前記走行データに基づいて前記ルーチンの実行状況を集計する処理と、
前記実行状況と前記実行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
を実行させる負荷推定プログラム。
(付記8)
前記実行状況と前記実行パターンは、前記プロセッサにおける実行アドレスが前記ルーチンに該当した頻度を含む
付記7記載の負荷推定プログラム。
(付記9)
前記実行状況と前記実行パターンは、前記プロセッサにおける実行アドレスが前記ルーチンのグループに該当した頻度を含む
付記7記載の負荷推定プログラム。
(付記10)
前記推定処理において、前記実行状況に含まれる指標と、2つの前記実行パターンの各々に含まれる同種の指標との各差の比に基づき、当該2つの前記実行パターンに対応する前記負荷のレベルの内分点に相当する負荷の程度を算出する
付記7乃至9のいずれか1つ記載の負荷推定プログラム。
(付記11)
前記推定処理において、複数種類の指標の各々について算出した前記負荷の程度の加重平均を算出する
付記10記載の負荷推定プログラム。
(付記12)
前記推定処理において、前記所定プログラムの負荷の限界に対する現状の負荷の割合を算出する
付記7乃至11のいずれか1つ記載の負荷推定プログラム。
(付記13)
プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶するコンピュータにより実行される負荷推定方法であって、
前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
前記走行データに基づいて前記プロセッサの走行状況を集計する処理と、
前記走行状況と前記走行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
を含む負荷推定方法。
(付記14)
プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における前記所定プログラムのルーチンの実行パターンとを対応付けて記憶するコンピュータにより実行される負荷推定方法であって、
前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
前記走行データに基づいて前記ルーチンの実行状況を集計する処理と、
前記実行状況と前記実行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
を含む負荷推定方法。
(付記15)
プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶する記憶部と、
前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する収集部と、
前記走行データに基づいて前記プロセッサの走行状況を集計する集計部と、
前記走行状況と前記走行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定部と
を有する負荷推定装置。
(付記16)
プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における前記所定プログラムのルーチンの実行パターンとを対応付けて記憶する記憶部と、
前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する収集部と、
前記走行データに基づいて前記ルーチンの実行状況を集計する集計部と、
前記実行状況と前記実行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定部と
を有する負荷推定装置。
101 サーバ装置 103 管理装置
201 ホストOS 203 アプリケーション
205 仮想マシン 401 仮想スイッチ
403 NIC 701 収集ドライバ
703 走行データ記憶部 705 分析エージェント
707 タイマ 1201 指示部
1203 集計部 1205 推定部
1207 送信部 1221 度数分布記憶部
1223 走行状況記憶部 1225 走行パターン記憶部
2101 矢印 2551 関数テーブル記憶部
2553 実行状況記憶部 2555 重み記憶部
2557 実行パターン記憶部 2559 グループテーブル記憶部

Claims (16)

  1. プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶するコンピュータに、
    前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
    前記走行データに基づいて前記プロセッサの走行状況を集計する処理と、
    前記走行状況と前記走行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
    を実行させる負荷推定プログラム。
  2. 前記走行状況及び前記走行パターンは、前記プロセッサにおける実行アドレスの度数分布に基づく特徴を含む
    請求項1記載の負荷推定プログラム。
  3. 前記度数分布における階級の範囲は、所定の上限幅内に含まれる前記実行アドレスの広がりに応じて設定される
    請求項2記載の負荷推定プログラム。
  4. 前記走行状況及び前記走行パターンは、前記所定の上限幅の異なる2種類の前記度数分布の各々に基づく前記特徴を含む
    請求項3記載の負荷推定プログラム。
  5. 前記推定処理において、前記走行状況に近似する前記走行パターンに対応する前記負荷のレベルを特定する
    請求項1乃至4のいずれか1つ記載の負荷推定プログラム。
  6. 前記推定処理において、前記走行状況に含まれる指標と、2つの前記走行パターンの各々に含まれる同種の指標との各差の比に基づき、当該2つの前記走行パターンに対応する前記負荷のレベルの内分点に相当する負荷の程度を算出する
    請求項1乃至4のいずれか1つ記載の負荷推定プログラム。
  7. プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における前記所定プログラムのルーチンの実行パターンとを対応付けて記憶するコンピュータに、
    前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
    前記走行データに基づいて前記ルーチンの実行状況を集計する処理と、
    前記実行状況と前記実行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
    を実行させる負荷推定プログラム。
  8. 前記実行状況と前記実行パターンは、前記プロセッサにおける実行アドレスが前記ルーチンに該当した頻度を含む
    請求項7記載の負荷推定プログラム。
  9. 前記実行状況と前記実行パターンは、前記プロセッサにおける実行アドレスが前記ルーチンのグループに該当した頻度を含む
    請求項7記載の負荷推定プログラム。
  10. 前記推定処理において、前記実行状況に含まれる指標と、2つの前記実行パターンの各々に含まれる同種の指標との各差の比に基づき、当該2つの前記実行パターンに対応する前記負荷のレベルの内分点に相当する負荷の程度を算出する
    請求項7乃至9のいずれか1つ記載の負荷推定プログラム。
  11. 前記推定処理において、複数種類の指標の各々について算出した前記負荷の程度の加重平均を算出する
    請求項10記載の負荷推定プログラム。
  12. 前記推定処理において、前記所定プログラムの負荷の限界に対する現状の負荷の割合を算出する
    請求項7乃至11のいずれか1つ記載の負荷推定プログラム。
  13. プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶するコンピュータにより実行される負荷推定方法であって、
    前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
    前記走行データに基づいて前記プロセッサの走行状況を集計する処理と、
    前記走行状況と前記走行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
    を含む負荷推定方法。
  14. プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における前記所定プログラムのルーチンの実行パターンとを対応付けて記憶するコンピュータにより実行される負荷推定方法であって、
    前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する処理と、
    前記走行データに基づいて前記ルーチンの実行状況を集計する処理と、
    前記実行状況と前記実行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定処理と
    を含む負荷推定方法。
  15. プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における当該プロセッサの走行パターンとを対応付けて記憶する記憶部と、
    前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する収集部と、
    前記走行データに基づいて前記プロセッサの走行状況を集計する集計部と、
    前記走行状況と前記走行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定部と
    を有する負荷推定装置。
  16. プロセッサで実行される所定プログラムの負荷のレベルと、当該負荷の状態における前記所定プログラムのルーチンの実行パターンとを対応付けて記憶する記憶部と、
    前記所定プログラムを実行中の前記プロセッサにおける走行データを収集する収集部と、
    前記走行データに基づいて前記ルーチンの実行状況を集計する集計部と、
    前記実行状況と前記実行パターンとの比較結果に基づいて、前記所定プログラムの負荷を推定する推定部と
    を有する負荷推定装置。
JP2016133639A 2016-07-05 2016-07-05 負荷推定プログラム、負荷推定方法及び負荷推定装置 Active JP6693308B2 (ja)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2016133639A JP6693308B2 (ja) 2016-07-05 2016-07-05 負荷推定プログラム、負荷推定方法及び負荷推定装置
US15/633,808 US10983837B2 (en) 2016-07-05 2017-06-27 Method and apparatus for load estimation
EP17178325.1A EP3267313B1 (en) 2016-07-05 2017-06-28 Method and apparatus for load estimation

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2016133639A JP6693308B2 (ja) 2016-07-05 2016-07-05 負荷推定プログラム、負荷推定方法及び負荷推定装置

Publications (2)

Publication Number Publication Date
JP2018005688A JP2018005688A (ja) 2018-01-11
JP6693308B2 true JP6693308B2 (ja) 2020-05-13

Family

ID=59298198

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2016133639A Active JP6693308B2 (ja) 2016-07-05 2016-07-05 負荷推定プログラム、負荷推定方法及び負荷推定装置

Country Status (3)

Country Link
US (1) US10983837B2 (ja)
EP (1) EP3267313B1 (ja)
JP (1) JP6693308B2 (ja)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111143199B (zh) * 2019-12-11 2022-08-05 烽火通信科技股份有限公司 一种云平台中检测dpdk应用程序内存越界访问的方法

Family Cites Families (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5784554A (en) * 1993-05-28 1998-07-21 Apple Computer, Inc. Dynamic sampling profiler
US6112317A (en) * 1997-03-10 2000-08-29 Digital Equipment Corporation Processor performance counter for sampling the execution frequency of individual instructions
US5974536A (en) * 1997-08-14 1999-10-26 Silicon Graphics, Inc. Method, system and computer program product for profiling thread virtual memory accesses
US7103877B1 (en) * 2000-11-01 2006-09-05 International Business Machines Corporation System and method for characterizing program behavior by sampling at selected program points
EP1468524A1 (en) 2002-01-22 2004-10-20 Siemens Medical Solutions Health Services Corporation System for estimating network traffic characteristics of executable software applications
EP1495417A4 (en) * 2002-03-14 2007-10-03 Unisys Corp SYSTEM AND METHOD FOR ESTIMATING RESOURCE USE
US7802236B2 (en) 2002-09-09 2010-09-21 The Regents Of The University Of California Method and apparatus for identifying similar regions of a program's execution
JP4701611B2 (ja) * 2004-01-15 2011-06-15 株式会社日立製作所 動的変換方式のエミュレータ向けメモリ管理方法
US8214819B2 (en) * 2004-07-09 2012-07-03 Hewlett-Packard Development Company, L.P. Determining call counts in a program
US8881114B2 (en) * 2005-05-16 2014-11-04 Texas Instruments Incorporated Stored program writing stall information when a processor stalls waiting for another processor
US7577875B2 (en) * 2005-09-14 2009-08-18 Microsoft Corporation Statistical analysis of sampled profile data in the identification of significant software test performance regressions
JP5167589B2 (ja) * 2006-02-13 2013-03-21 富士通株式会社 アプリケーションサーバ装置および仮想マシンプログラム
JP4681491B2 (ja) * 2006-03-31 2011-05-11 富士通株式会社 プロファイリングプログラムおよびプロファイリング方法
US8255628B2 (en) * 2006-07-13 2012-08-28 International Business Machines Corporation Structure for multi-level memory architecture with data prioritization
JP2008242731A (ja) * 2007-03-27 2008-10-09 Oki Electric Ind Co Ltd マイクロプロセッサ設計プログラム、マイクロプロセッサ設計装置及びマイクロプロセッサ
JP2008310470A (ja) 2007-06-13 2008-12-25 Hitachi Ltd 計算機システムの異常監視方法
JP5029245B2 (ja) * 2007-09-20 2012-09-19 富士通セミコンダクター株式会社 プロファイリング方法及びプログラム
US7720643B1 (en) * 2007-09-24 2010-05-18 United Services Automobile Association (Usaa) Estimating processor usage
WO2009050768A1 (ja) * 2007-10-15 2009-04-23 Fujitsu Limited シミュレート方法、電子装置の設計方法、シミュレートプログラムおよびシミュレーション装置
JP4906686B2 (ja) 2007-11-19 2012-03-28 三菱電機株式会社 仮想マシンサーバサイジング装置及び仮想マシンサーバサイジング方法及び仮想マシンサーバサイジングプログラム
US8024458B1 (en) * 2008-05-16 2011-09-20 Amazon Technologies, Inc. Tracking the frequency distribution of streaming values
JP5326374B2 (ja) * 2008-06-19 2013-10-30 富士通セミコンダクター株式会社 プロセッサ、性能プロファイリング装置、性能プロファイリングプログラムおよび性能プロファイリング方法
JP5386905B2 (ja) * 2008-09-25 2014-01-15 富士通セミコンダクター株式会社 プロファイリング方法およびプロファイリングプログラム
CN101937397B (zh) * 2009-06-29 2012-06-13 深圳富泰宏精密工业有限公司 移动智能终端及其内存动态管理方法
US8966087B2 (en) * 2009-12-08 2015-02-24 Nec Corporation Load characteristic estimation system, load characteristic estimation method, and program
US8635381B2 (en) * 2010-08-26 2014-01-21 International Business Machines Corporation System, method and computer program product for monitoring memory access
US8615742B2 (en) * 2010-11-16 2013-12-24 International Business Machines Corporation Autonomic hotspot profiling using paired performance sampling
CN102955719B (zh) * 2011-08-31 2016-06-22 国际商业机器公司 疑似内存泄漏的确定方法及装置
WO2014050254A1 (ja) 2012-09-25 2014-04-03 日本電気株式会社 ボトルネック検出装置、方法及びプログラム
JP6079317B2 (ja) 2013-03-05 2017-02-15 富士通株式会社 仮想計算機システム及びその管理方法並びに仮想計算機システムの管理プログラム
JP6503774B2 (ja) * 2015-02-17 2019-04-24 富士通株式会社 プログラム実行解析方法、情報処理装置及びプログラム実行解析プログラム
JP6540340B2 (ja) * 2015-07-31 2019-07-10 富士通株式会社 関数呼び出し情報収集方法及び関数呼び出し情報収集プログラム
JP6904049B2 (ja) * 2017-05-16 2021-07-14 富士通株式会社 情報処理装置、情報処理方法、およびプログラム

Also Published As

Publication number Publication date
US20180011747A1 (en) 2018-01-11
EP3267313B1 (en) 2023-06-21
EP3267313A1 (en) 2018-01-10
US10983837B2 (en) 2021-04-20
JP2018005688A (ja) 2018-01-11

Similar Documents

Publication Publication Date Title
Kalavri et al. Three steps is all you need: fast, accurate, automatic scaling decisions for distributed streaming dataflows
CN108595301B (zh) 一种基于机器学习的服务器能耗预测方法和系统
JP7004902B2 (ja) 性能評価プログラム、および性能評価方法
EP3457336B1 (en) Method and device for acquiring traffic light duration data
Zhang et al. {OSCA}: An {Online-Model} Based Cache Allocation Scheme in Cloud Block Storage Systems
Reussner et al. SKaMPI: A comprehensive benchmark for public benchmarking of MPI
CN106293881B (zh) 一种基于非一致性i/o访问构架的性能监控器及其监控方法
CN102222034A (zh) 基于程序轮廓分析的虚拟化平台性能评测方法
JP6636214B1 (ja) 診断装置、診断方法及びプログラム
US20160077860A1 (en) Virtual machine placement determination device, virtual machine placement determination method, and virtual machine placement determination program
JP6693308B2 (ja) 負荷推定プログラム、負荷推定方法及び負荷推定装置
JP2018194988A (ja) 情報処理装置、情報処理方法、およびプログラム
CN115269108A (zh) 一种数据处理方法、装置及设备
Badia et al. Performance prediction in a grid environment
Islam et al. Exploring the capabilities of the new MPI_T interface
CN110750498A (zh) 对象访问方法、装置及存储介质
Dietrich et al. Pika: Center-wide and job-aware cluster monitoring
Groot et al. Modeling i/o interference for data intensive distributed applications
KR102456150B1 (ko) 실제 환경에서 대용량 시스템에 대한 포괄적 성능평가를 수행하는 방법 및 이를 지원하는 장치
JP2018014000A (ja) テスト支援プログラム、テスト支援装置、及びテスト支援方法
CN111158974B (zh) 一种面向云服务器的硬件感知cpu能耗测算方法
JP2019046407A (ja) 性能管理システム、管理装置および性能管理方法
Llopis et al. Analyzing the energy consumption of the storage data path
CN113238974A (zh) 一种总线带宽效率统计方法、装置、和设备及介质
Chen et al. Metrics for ranking the performance of supercomputers

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20190409

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20200228

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20200317

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20200330

R150 Certificate of patent or registration of utility model

Ref document number: 6693308

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150