JP6756048B2 - コンピュータリソースのための予測的資産最適化 - Google Patents

コンピュータリソースのための予測的資産最適化 Download PDF

Info

Publication number
JP6756048B2
JP6756048B2 JP2019534881A JP2019534881A JP6756048B2 JP 6756048 B2 JP6756048 B2 JP 6756048B2 JP 2019534881 A JP2019534881 A JP 2019534881A JP 2019534881 A JP2019534881 A JP 2019534881A JP 6756048 B2 JP6756048 B2 JP 6756048B2
Authority
JP
Japan
Prior art keywords
computer system
network servers
performance
variables
time
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
JP2019534881A
Other languages
English (en)
Other versions
JP2020504382A (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.)
Morgan Stanley Services Group Inc
Original Assignee
Morgan Stanley Services Group Inc
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 Morgan Stanley Services Group Inc filed Critical Morgan Stanley Services Group Inc
Publication of JP2020504382A publication Critical patent/JP2020504382A/ja
Application granted granted Critical
Publication of JP6756048B2 publication Critical patent/JP6756048B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N5/00Computing arrangements using knowledge-based models
    • G06N5/04Inference or reasoning models
    • 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/5061Partitioning or combining of resources
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2458Special types of queries, e.g. statistical queries, fuzzy queries or distributed queries
    • G06F16/2474Sequence data queries, e.g. querying versioned data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/28Databases characterised by their database models, e.g. relational or object models
    • G06F16/284Relational databases
    • G06F16/285Clustering or classification
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/14Fourier, Walsh or analogous domain transformations, e.g. Laplace, Hilbert, Karhunen-Loeve, transforms
    • G06F17/141Discrete Fourier transforms
    • G06F17/142Fast Fourier transforms, e.g. using a Cooley-Tukey type algorithm
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • G06Q10/063Operations research, analysis or management
    • G06Q10/0631Resource planning, allocation, distributing or scheduling for enterprises or organisations
    • G06Q10/06313Resource planning in a project environment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/5019Workload prediction
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Business, Economics & Management (AREA)
  • Human Resources & Organizations (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Economics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Computational Linguistics (AREA)
  • Computational Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Strategic Management (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Operations Research (AREA)
  • Biodiversity & Conservation Biology (AREA)
  • Discrete Mathematics (AREA)
  • Development Economics (AREA)
  • Computing Systems (AREA)
  • Educational Administration (AREA)
  • Evolutionary Computation (AREA)
  • Game Theory and Decision Science (AREA)
  • Artificial Intelligence (AREA)
  • Marketing (AREA)
  • Algebra (AREA)
  • Quality & Reliability (AREA)
  • Tourism & Hospitality (AREA)
  • General Business, Economics & Management (AREA)
  • Fuzzy Systems (AREA)
  • Probability & Statistics with Applications (AREA)
  • Debugging And Monitoring (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Computer And Data Communications (AREA)
  • Complex Calculations (AREA)

Description

今日、大規模なコンピュータインフラストラクチャを使用している企業は、任意の所与の日にその企業のアプリケーションの使用を想定している最大同時ユーザ数に容易に対応するように、仮想デスクトップ/アプリケーションインフラストラクチャの要件を超大規模にする傾向がある。これは、ユーザがパフォーマンスの低下または不当なダウンタイムを被らないことを保証するための手段とみなされている。この手法は合理的に思えるだろうが、残念ながら、ほとんど未使用のまま、または長期間にわたって十分に活用されていないサーバの急増につながっている。この過剰プロビジョニングは、いくつかの例を挙げるだけでも、ライセンス、電力、熱、冷却、およびデータセンターのスペースに関して、企業が年間を通して不必要に増加した設備投資および運用経費を負担することを最終的に意味する。
企業のコンピュータインフラストラクチャのニーズを予想するために、時系列予想のいくつかの異なる手法がこれまでに提案されている。この先行研究は、線形回帰、指数平滑法、自己回帰積分移動平均(ARIMA)などの古典的なモデルの使用から、サポートベクターマシン(SVM)、人工ニューラルネットワーク(ANN)、およびファジーロジックなど、より高度な計算知能の非線形手法にまで及んでいる。k最近傍(k−NN)アルゴリズムも時系列予想に最近拡張されているが、この分野における既存の研究では、いかなる追加の関連メトリクスも参照せずに、個々の履歴データに焦点が当てられている。したがって、ほとんどのアプリケーションは、過去の類似した最近傍を識別するために1次元の荷重曲線の形状のみを使用して、1次元の一変量時系列に制約される一方で、大きな次元特徴空間間の相関はしばしば無視される。しかしながら、測定されたコンピュータハードウェアメトリクスの多くは、互いに密接に関連しているため、1次元から抽出された履歴に関する知識は、同様の動作を共有する時系列のグループから収集されたものと比較すると不適切である。
一般的な一態様では、本発明は、ネットワークユーザによって要求されるリソース(アプリケーション、データなど)をホストするためにネットワークサーバを採用する企業コンピュータシステムのための、ネットワークリソースおよび/またはインフラストラクチャのニーズを予想するためのコンピュータ実装システムおよび方法に関する。予想に基づいて、ネットワークリソースは、それに応じてスケーリングまたはプロビジョニングすることができる。すなわち、例えば、ネットワークサーバの状態は、過剰な容量を削減しながら、ユーザの要求ニーズを満たすように動的に調整することができる。本発明の予想技法は、クラウドコンピューティング環境にも適用可能である。予想に基づいて、クラウドサーバプールを動的にスケーリングし、そのため、システムの規模は、変化する要求を満たし、システムの負荷が低いときにリソースを浪費することを回避する。
予想は、ネットワークリソースに対するユーザの要求に関する履歴データに基づいて生成される。あるシナリオでは、相関分析に従ってそれらのメトリクスに基づいてグループ化された要求のバリアントのグループ化に基づいて多変量k最近傍(k−NN)予想が使用されるので、同じグループ内のメトリクス間の依存性は高くなる。次いで、多変量k−NNアルゴリズムが各グループに対して実行され、多段階先予測が生成される。この手法は、予測速度とともに予測性能が改善されるように、他の無関係なメトリクスの影響を低減させる。別の予想技法は、予測およびストライプサンプリング手法を使用する。単位時間内の未来の要求数を予測し、要求の特徴を分析し、それに従って要求を分類し、スライスサンプリング戦略を決定することによって、未来の詳細なワークロードデータを生成することができる。さらに別の手法は、要求パターン予測に基づく適応スケジューリングアルゴリズムである。このアルゴリズムは、様々なワークロードに対するシステムの適応能力を決定し、履歴と現在のシステム負荷に基づいてシステムが使用するクラウドリソースを調整することで、システムが動的負荷を満たしながら無駄を削減することができるようにする。
本発明の実施形態からのこれらおよび他の利点は、以下の記載から明らかになるであろう。
本発明の様々な実施形態は、添付の図面に関連した実施例として本明細書に記載される。
本発明の様々な実施形態による企業コンピュータシステムのブロック図である。
本発明の様々な実施形態による図1の企業コンピュータシステムのためのサーバ数推奨を決定するためのプロセスフローのフローチャートである。
本発明の様々な実施形態による単変量k−NN手法のための予測方法の一例を図示するグラフである。
本発明の様々な実施形態による図1の予測コンピュータシステムのブロック図である。
本発明の様々な実施形態による図3のコンピュータシステムによって実行されるプロセスフローのフローチャートである。
本発明の様々な実施形態による図1のリソース予測コンピュータシステムのコントローラの一例を図示する。
1日にわたる企業コンピュータシステムのネットワークサーバに対する典型的な負荷(例えば、要求数)の例を示す。
本発明の様々な実施形態による図6のコントローラのための伝達関数の図である。
一般的な一態様では、本発明の実施形態を使用して、企業に対する未来のコンピュータリソースのニーズを予測することができる。1つの例示的な企業コンピュータシステム10が図1に図示されている。図1に図示されている企業コンピュータシステム10は、広域ネットワーク(WAN)14と相互接続された、いくつかのローカルエリアネットワーク(LAN)12を含む。各LAN12は、いくつかのクライアントコンピュータ16およびいくつかのネットワークサーバ18を含むことができる。ネットワークサーバ18は、実装態様に応じて、例えば、そのLAN12内の、または他のLAN12からのクライアントコンピュータ16用のコンピュータプログラム、データ、記憶装置、およびプリンタなどのコンピュータリソースをホストしてもよい。
リソース予測コンピュータシステム20は、様々な実施形態に従って、ネットワークサーバ18に対する多変量時系列(MTS)データに基づいて企業のリソース予測を実行し、MTSデータはデータベースコンピュータシステム22に格納される。リソース予測コンピュータシステム20およびMTSデータベースシステム22は、図示の目的でWAN14に接続されているものとして図1に示されているが、それらの一方または両方を図示されているLAN12のうちの1つに含めることができる。それらは、企業のネットワーク内の異なるLAN12とWAN14に接続することもできる。リソース予測コンピュータシステム20は、サーバ(複数可)、メインフレーム(複数可)、ワークステーション(複数可)、および/または任意の他の好適なコンピュータデバイスなどの1つ以上の相互接続されたコンピュータデバイスとして実装されてもよい。リソース予測コンピュータシステム20のそのような各コンピュータ装置は、1つ以上のプロセッサ24および1つ以上のメモリユニット26を含んでもよい。メモリユニット26は、一次コンピュータストレージ(例えば、RAMおよびROM)および二次コンピュータストレージ(例えば、HDD、SSD、フラッシュ)の両方を含んでもよい。プロセッサ(複数可)24は、図1に示し、さらに以下に記載するように、変数グルーピングモジュール30およびk最近傍(k−NN)探索モジュール32などの、メモリユニット26に格納されたコンピュータ命令(例えば、ソフトウェア)を実行するマイクロプロセッサ(複数可)を含んでもよい。図示の目的のために、図示されたリソース予測コンピュータシステム20は、1つのコンピュータのみを含み、ならびに1つのプロセッサ24および1つのメモリユニット26のみが図示されているが、本発明はそれに限定されず、リソース予測コンピュータシステム20を必要に応じてスケーリングすることができることを理解されたい。
MTSデータベース22は、企業システム10のネットワークサーバ18に対する時系列のコンピュータ使用率およびハードウェア統計を格納する。統計には、次のように、各ユーザリソース要求に関連するいくつかの変数の値(以下のものなど)を含めることができる。
−リソースを要求しているユーザのユーザ名
−要求の開始時間
−要求の終了時間
−要求の合計時間
−要求の動作時間
−要求されたプロセスまたはリソース
−要求に対処したネットワークサーバのID
−要求に対処したネットワークサーバの地理的位置
−CPU利用率−ネットワークサーバの一次メモリ(例えば、RAM)利用率
−ネットワークサーバのディスクIO(ディスクメモリまたは他の二次コンピュータメモリへの読み書き動作の合計)
MTSデータベース22は、データベース管理システム(DBMS)ソフトウェアを実行し、かつ好適なRAIDディスクアレイおよび/または任意の他の好適なデータ記憶機構を含む、必要に応じて1つ以上のデータベースサーバを用いて実装されてもよい。使用量およびハードウェア統計は、CSVファイルおよび/またはネットワークサーバ18からの任意の他の好適なデータフォーマットを使用してMTSデータベース22に送信されてもよい。各ネットワークサーバ18は、その周期的統計をMTSデータベース22に送信してもよく、および/またはLAN12内の1つ以上のネットワークサーバ18は、LAN12内の複数のネットワークサーバ18に関する統計を収集し、その収集をMTSデータベース22に送信することができる。MTSデータベース22は、例えば、オラクル(Oracle)またはSQLデータベース、または他の任意の好適なデータベースとして実装されてもよい。
様々な実施形態では、企業の未来のコンピュータリソースのニーズを予測するために、リソース予測コンピュータシステム20は、各関連変数が1つのクラスタのメンバーとなるように、かつ同じクラスタを有する変数間の依存性が高いが他のクラスタ内の変数と比較して非常に低いように、関連変数をクラスタへとグループ化する。プロセッサ24は、変数グルーピングモジュール30のソフトウェアを実行することによって、この機能を実行してもよい。クラスタが決定された後、リソース予測コンピュータシステム20は、予測を計算するために様々な実施形態においてk−NN探索を使用する。プロセッサ24は、k−NN探索モジュール32のソフトウェアを実行することによってこの機能を実行してもよい。
図2は、様々な実施形態によるMTSデータベース22とともにリソース予測コンピュータシステム20によって実行されてもよい予測プロセスのプロセスフローである。ステップ50において、MTSデータベース22は、企業のネットワークサーバ18に対する時系列使用量およびハードウェア統計変数を受信し、格納する。データは、5分ごと、10分ごと、または任意の他の好適な時間増分などの周期的な時間増分に対して収集される。次にステップ52において、リソース予測コンピュータシステム20は、データベース22に格納されているMTSデータを前処理して、ノイズを除去または低減し、かつ/または従来のデータ前処理技法を使用してデータを標準正規分布データへとスケーリングすることができる。
高次元時系列を扱うとき、すべての次元に基づく全体的なk−NN推定は、無関係なメトリクス間の干渉のために大きな誤差を持つ可能性がある。しかしながら、測定されたコンピュータハードウェアメトリクスのいくつかは、互いに密接に関連しており、同様の挙動を共有しているので、予測が単変量時系列から単に抽出されると、関連情報は失われることになる。すべての関連変数から集約された知識を利用するために、k−nn探索を実行する前、高次元MTSは、より小さいもののグループに分解され、ここでは同じグループ内の変数間の依存性は高いが、他のグループ内の変数との依存性は非常に低い。この動作は、図2のステップ54において、変数グルーピングモジュール30のソフトウェアを実行することによって、可変クラスタを生成するリソース予測コンピュータシステム20のプロセッサ24によって実行される。そのような分解はまた、モデル空間を大幅に狭めもするので、その後のk−NN探索を高速化する。様々な実装態様では、変数グルーピングは2つの段階、すなわち(i)相関行列構築、および(ii)変数クラスタリングを含む。
d個の変数を有し、かつ長さTのMTSが与えられた場合、2つの変数間の関連性を測定するために相関係数を使用することができる。一実施形態では、2つの変数間の関係の単調性のノンパラメトリックな尺度であるスピアマン(Spearman)の順位相関係数が使用される。スピアマン相関は、両方のデータセットが正規分布していると仮定しない。サイズnのサンプルの場合、未処理の変数X、Yは、ランクx、yに変換され、スピアマンの順位相関係数ρは、これらから次のように計算される。
Figure 0006756048
式中、x、yは、未処理の変数を指し、バー付きのx、yは、変数の平均を指す。
ある変数がある時間差後に他の変数に影響を与える可能性があることに留意し、したがって、変数i、jの各対について、アルゴリズムは、0から予め定義された「MaxLag」期間まで探索でき、ρijとなる最大係数を、以下のように選択することができる。
Figure 0006756048
すべての変数の中で、対での相関係数は、n×n相関行列を形成するために計算される。以下の表1は、特定のネットワークサーバホストを用いた実験で構築された例示的な相関行列である。これは、より濃い灰色を有する対称行列が強い相関を示すことに留意されたい。
Figure 0006756048
上記で構築した相関行列に基づいて、n個の変数をクラスタに分解するために分割方法を適用することができる。様々な実施形態において、アフィニティプロパゲーション(Affinity Propagation)(AP)クラスタリングアルゴリズムがこのステップで使用される。APは、データポイント間の「メッセージパッシング」の概念に基づくクラスタリングアルゴリズムである。k平均法(k−means)およびk−medoids法などの他の既知の分割方法とは異なり、APでは、アルゴリズムを実行する前にクラスタの数を決定または推定する必要はない。したがって、入力ハードウェアメトリクスが変化するにつれてグループ化の結果が変化する場合があるので、本実施形態により適している。APについてのさらなる詳細は、その全体が参照により本明細書に組み込まれる、Brendan J.Frey et al.,“Clustering by passing messages between data points,”Science 31:972−976(2007)に見出すことができる。
APアルゴリズムは、収束するまでサンプルの対間でメッセージを送信することによってクラスタを作成する。ポイント間で送信されるメッセージには2つのカテゴリがある。一方は、サンプルkがサンプルiの見本となるべきであるという責任であり、r(i,k)によって表される。もう一方は、サンプルiがサンプルkを見本として選択するべきであるという可用性であり、a(i,k)で表され:
Figure 0006756048
となり、式中、s(i,k)は、サンプルiとkとの間の類似度である。アルゴリズムは、収束するまで2つの行列の計算を実行する。表2は、表1の行列に基づくクラスタリング結果を示す。
Figure 0006756048
この例で分かるように、各変数0〜6は、グループ/クラスタのうちの1つに属する。
可変クラスタが決定された後、ステップ56において、k−NNアルゴリズムが所望の予測をするために使用される。説明の目的のために、k−NN探索アルゴリズムは、一変量の状況について、および一定幅の時間間隔で測定された直前の一定数の履歴データに基づく1ステップ先の値についてのみ最初に図示される。t=(1,2,・・・,T)の場合、予想範囲h=(1,2,・・・,H)に対して、点Tから予測xT+h(ここでxは⌒付き)行われる有限かつ等距離の時系列xを考える。最初に、時系列の最近の状態の特徴を表すために、特徴ベクトルの集合が作成される。等しい長さmのセグメントは、m個の連続した観測値のシーケンスx (ここでxは→付き)=[xt,xt−1,・・・,xt−(m−1)のベクトルシーケンスx (ここでxは→付き)とみなされ、ここで、mはサンプリング長と称される予め定められた整数である。ベクトルは、すべてのt=(m,m+1,m+2,・・・,T−m)、いわゆるm履歴と重複して作成されることに留意されたい。
次に、過去における行動の類似パターンを識別するために、様々な実施形態において、ユークリッド距離メトリクスなどの所与の距離メトリクスを使用して、すべてのm履歴と最後に観測されたベクトルx (ここでxは→付き)=[x,xT−1,・・・,xT−(m−1)との間の距離がそれぞれ計算される。
Figure 0006756048
最後に、すべてのm個の履歴に対する対での距離がランク付けされ、ターゲット特徴ベクトルまでの最小距離を有するk個のベクトルのその後の観測値がそれぞれ選択される。k個の最近傍の各々を局所的に重み付けすることができ、その後予測xT+h(ここでxは⌒付き)を形成するために集約される。
Figure 0006756048
式中、neighj,hは、近傍のjの範囲hに続く値であり、wは、重みを表す。図3は、一変量k−NN手法のための予測方法を図示するグラフである。基準期間(341〜381日目)に最も近い2つの近傍(171〜221日目と1〜51日目)を示す。
多変量の場合、単変量の場合の参照(例えば、最新の)特徴ベクトルおよびm履歴は、多次元に拡張される。Xをd次元の多変量時系列(MTS)とする。時間TにおけるMTSの未来を予測するためには、目標特徴行列は、
Figure 0006756048
であり、式中x T,i(ここでxは→付き)は、次元iで時間Tにおいて最後に観測されたベクトルを表す。同様に、距離メトリクスは、距離メトリクスの合計として定義することができる(例えば、すべてのd次元におけるユークリッド距離
Figure 0006756048
m履歴にわたって探索することによって、MTSの現在の(または他の参照)状態に近いグローバルなk個の最近傍を見つけることができ、それらの各々は、m個の連続した観測のd個のベクトルによって構成される。k個の最近傍の範囲hを有する後続の値は、参照k×d行列として表すことができる。
Figure 0006756048
各次元に対する予測値は、対応する次元での参照項目を集計することによって生成される。
Figure 0006756048
ここで、各次元の近傍は、結果を形成するためにそれぞれ重み付けされる。一実施形態では、重みは、勾配降下アルゴリズムによって得られ、新しいデータと一致するように徐々に調整される。予測は、時間範囲の累積ユーザリソース要求とそれらの要求に対処するために必要なサーバリソースを予想することができる。したがって、予測は、時間範囲ステップに対して予測されたサーバワークロードをもたらす。拡張されたワークロード予想を得るために、このプロセスを追加の時間範囲ステップに対して繰り返すことができる。
図2のステップ58において、リソース予測コンピュータシステム20は、未来の時間範囲ステップにおけるサーバの数を推奨することができる。このようなサーバ数の予測は、多数の有益な目的のために使用することができる。そのような目的の1つは、企業が予想された数のサーバに基づいてそのサーバ18をプロビジョニングすることを可能にすることである。以下のメトリクスを含むいくつかの計算されたメトリクスがそのような能力計画において使用されてもよい。
・CPU/メモリ/ディスクの過負荷率および不足負荷率。これらのメトリクスの計算は、CPU、メモリ、およびディスクの過負荷値および不足負荷値(それぞれの過負荷閾値および不足負荷閾値を上回るまたは下回る)を平均することによって実行することができる。閾値は、例えば、過負荷の場合は90%、不足負荷の場合は10%とすることができる。
・CPU/メモリ/ディスクの過負荷時間率および不足負荷時間率。これらのメトリクスは、全体の期間と比較した、CPU/メモリ/ディスクが過負荷になっている(過負荷閾値を上回った)または不足負荷となっている(不足負荷閾値を下回った)時間の長さの比率に基づいて計算することができる。
・全体的な過負荷時間率および不足負荷時間率。この計算では、サーバのためのCPU/メモリ/ディスクメトリクスのいずれかが過負荷または不足負荷の場合、場合によっては、サーバが過負荷または不足負荷になっているとみなされる。
これらのメトリクスは、上述のk−NN予測されたCPU/メモリ/ディスクの負荷に基づいて、リソース予測コンピュータシステム20によって、未来の時間ステップのために予測することができる(ステップ56参照)。
これらの予想された過負荷メトリクス/不足負荷メトリクスは、推奨されたサーバ18の数(図1参照)など、企業コンピュータシステムのためのハードウェアリソースを推奨するための様々な推奨方法論に対する入力パラメータとして使用することができる。3つのそのような推奨方法論は、いわゆる「容量ベースのサーバ数推奨」(C−SNR)、「使用量ベースのサーバ数推奨」(U−SNR)、および「適応型サーバ数推奨」(A−SNR)である。C−SNRでは、サーバによって処理することができる要求の数が予め定められている。したがって、要求の総数が予測されると、サーバ数を簡単に導出することができる。U−SNRでは、ユーザがサーバ要求を実行する最も可能性の高い時間は、ユーザの使用経過および分類に基づいて既知である。要求に対するユーザの平均負荷値もユーザの分類に基づいて認識されるため、ユーザの要求によってシステムにもたらされると予想される負荷を予測することができる。サーバ容量を最大限に活用しようとする割り当てアルゴリズムを適用することによって、サーバ数を決定することができる。A−SNRでは、比率(実際には閾値)を使用して、新しいユーザセッションを送信するサーバおよび新しいサーバを追加するべきかどうかを決定する。新しい要求が出されたとき、最初の試みは、現在稼働中のサーバがその要求に対処することである。要求は、分類結果から推定される潜在的な負荷レベルに基づいて現在のサーバに割り当てられる。過負荷状態のために新しい要求を現在アクティブなサーバに割り当てることができない場合、要求に対処するために新しいサーバが追加される。同様に、要求が完了すると、残りのワークロードをサーバ18間で再均衡化することができる。
このメトリクスのうちのどれが使用されようと、または他のメトリクスが使用されようと、リソース予測コンピュータシステム20は、予想されたユーザのワークロードに基づいて、特定の期間について企業にとって適切な数のサーバ18を予想することができる。リソース予測コンピュータシステム20は、これらのサーバ数推奨をネットワークサーバ18に対するブローカ(図1参照)として機能するネットワークサーバ40に通信することができる。リソース予測コンピュータシステム20から伝達された決定に基づいて、このブローカサーバ(複数可)40は、LAN12内のいくつのサーバ18を、様々な時点で起動(フルアクティブ、動作モード)および、または低電力モード(例えば、アイドルモードまたはスリープモード)にするべきかを決定することができ、それに応じてサーバ18に命令することができる。このようにして、ネットワークサーバ18のうちのいくつかは、予想された使用法および/または負荷パターンに基づいて、それらが必要とされ予想されていない期間中に低電力モードにすることができる。例えば、図1を参照して、リソース予測コンピュータシステム20は、特定の期間に必要とされる予想数のネットワークサーバ18を決定することができる。予想は、1つのLAN12内のネットワークサーバ18または複数のLAN12にわたるネットワークサーバ18に対するものとすることができる。リソース予測コンピュータシステム20は、この数をブローカサーバ40に送信することができ、これは、そのLAN12および/または他のLAN12内の様々なサーバ18に、適切なときに動作可能な高電力モード(ユーザのリソース要求を処理することができる)にあるか、または低電力モード(ユーザのリソース要求を処理できない)にあるように命令することができる。ネットワークサーバ18は、それに応じて命令された電力モードを仮定することができる。このようにして、予想されたネットワークリソースのニーズが低いときには、エネルギーおよび関連するコストを節約するために、ある数のネットワークサーバ18を低電力モードにすることができる。逆に、予想されたネットワークリソースのニーズが高いときには、十分な数のネットワークサーバ18が予想されるユーザ要求負荷に対処するように準備されることになる。
様々な実施形態において、プロセッサ24は(k−NN探索モジュールソフトウェア32を実行するとき)、k−NN探索の前にk−NN探索のためのkおよびmパラメータを選択する。モジュール32は、異なるデータセットに対する予想誤差を最小にするために、kおよびmパラメータを調整するために高クライミングアルゴリズムを使用してもよい。問題に対する恣意的な解(この場合は、kおよびmパラメータ)から始まる高クライミングアルゴリズムの反復アルゴリズムは、次いで、解の単一要素を漸増的に変更することによって、より良好な解を見つけようとする。その変更がより良好な解を生み出す場合、それ以上の改善を見出すことができなくなるまで繰り返される新しい解への漸増変更が行われる。他の実施形態では、kおよびmパラメータは、再確立される。
K最近傍を有する予測間の関係は、時間とともに変化する可能性がある。したがって、重みは、好ましくは、時間とともに調整される。Train=[xt−1,xt−2,・・・,xt−n]は、時間tにおけるサイズnの学習セットを表すと仮定する。xは、時間tにおける真の値であり、yは、時間tに対する予測値である。以前に取得した重みに基づいて、yをTrainに基づいて予測することができる。xの真の値が分かった後、Traint+1=[x,xt−1,・・・,xt−n+1]に基づいて重みを更新することができ、この新しい重みは、yt+1の予測に使用される。
別の一般的な問題は、企業で必要なコンピューティングリソースが動的に変化することである。企業が最高のワークロードに対応するサーバ数を維持している場合、ワークロードが低い時間の間、そのような多数のサーバを必要としないため、これは大きな無駄になる。ユーザの要求を満たすのに十分なサーバを維持するだけでなく、可能な限りエネルギーを節約するという目標を達成するためには、ワークロードを予測する必要がある。したがって、本発明の様々な実施形態は、予測およびストライプサンプリング手法に基づくワークロード生成方法を提供する。単位時間内の未来の要求数を予測し、要求の特徴を分析し、それに応じて要求を分類し、スライスサンプリング戦略を決定することによって、未来の詳細ワークロードデータを生成することができる。未来のワークロードデータは、サーバリソースを動的に調整するためのベースを提供することができる。
一般的な一態様では、予測およびストライプサンプリング手法をステップへと分割することができる。第1に、時系列予測モデルを適用して単位時間内の要求数を予測する。k最近傍(KNN)アルゴリズムに基づいて、要求数時系列データ内の現在のサブシーケンスに類似するK個のサブシーケンスが探索される。次いで、線形回帰モデルを適用して、K個の最近傍シーケンスによって与えられる予測を最終予測結果に合成することができる。
第2に、要求の特徴を分析する。各要求は、異なるリソース(CPU負荷、メモリなど)を消費する。さらに、各要求の長さを予測する必要がある。様々な実施形態に従って、分析を3つのタイプへと分割することができる。
a.相関分析。要求の異なる属性に対して相関分析を実行することができる。2つの属性が相関している場合、それらは互いに依存するが、一方で相関していない2つの属性は互いに影響しない。
b.分類要求。関連性の高い属性で要求を分類することによって、要求を、内部記憶コストの低い短期間の要求、内部記憶コストの低い長期間の要求、内部記憶コストの高い長期間の要求などの、異なるタイプへと分割することができる。
c.周期分析。周期的な要素によってもたらされるマイナスの影響は、取り除かれるべきである。要求は、勤務時間と非勤務時間との間に著しい違いを示している。要求をサンプリングすることが望まれる場合、同様の周期的時間内の要求がサンプリングのために選択されるべきである。
第3に、スライスベースのサンプリングおよび期間ベースのサンプリングの組み合わせを用いて、各カテゴリの割合に従って履歴データから要求が選択され、これらの要求データが最終的な予測にまとめられる。
このプロセスには、ワークロードが複数のメトリクスに基づいて測定されるという利点があり、これにより、単一のメトリクスの制限を克服する。別の潜在的な利点は、未来の要求数および様々なメトリクスに対する各要求の影響を考慮しながら、各要求によってもたらされるワークロードをモデル化することによってより正確な予測を行うことである。そのようにして、この方法は、全体的なワークロード予想手法の制限を克服する。
図4は、リソース予測コンピュータシステム20の図であり、図5は、本発明の様々な実施形態による将来のワークロードトレースを生成するために、この予測およびストライプサンプリング戦略を実施するためにリソース予測コンピュータシステム20によって実行されるプロセスフローの図である。図3に示すように、そのような実施形態によれば、リソース予測コンピュータシステム20は、未来のワークロードトレースを生成するための予測およびストライプサンプリングモジュール60を含んでもよい。予測およびストライプサンプリングモジュール60は、メモリ(複数可)26に格納され、かつリソース予測コンピュータシステム20のプロセッサ(複数可)24によって実行されるソフトウェアコードとして実装されてもよい。図5の例示的なプロセスフローは、予測およびストライプサンプリングモジュール60のコードが実行されるときに、リソース予測コンピュータシステム20によって実施することができる。さらに、データベース22は、ネットワークサーバのユーザによる履歴要求に関するデータを格納することができる。
ステップ62において、単位時間当たりの要求数が予測される。単位時間ごとにユーザによっていくつの要求が送信されるかを予測する問題は、時系列予測問題としてモデル化することができる。したがって、K個の最近傍分類アルゴリズムを使用して、データベース22内に格納されている履歴データから現在のサブシーケンスと同様のサブシーケンスを見つけ出すことができる。次いで、これらの類似のサブシーケンスに基づいて得られた予測を一緒に組み合わせて、最終予測結果を生成することができる。時間間隔が単位時間Tであると仮定すると、各単位時間内に発生する要求数は、N=[n,n,・・・,n]として表すことができ、式中、nは、i番目の単位時間内に発生した要求数であり、pは、次のように表すことができる。
Figure 0006756048
要求数が現時点のそれらと類似している場合を見つけるために、最新のm個の観測値からなるサブシーケンスを描画することができる。
Figure 0006756048
もう一方の観測は、次のように表すことができる。
Figure 0006756048
複数のサブシーケンスNi,i+m−1=[n,・・・,ni+m−1]は、Nnowに最も類似する履歴データから見出すことができる。履歴サブシーケンスと現在のサブシーケンスとの間の類似性を測定するための評価基準を使用することができる。Dis(X,Y)を2つの時系列間の類似性を測定するための距離関数とする。距離関数ユークリッド距離を使用することができ、これは以下の通りである。
Figure 0006756048
各履歴サブシーケンスと現在のサブシーケンスとの間の距離を計算することができる。履歴シーケンスは、サブシーケンスセット{N1,1+m−1,N2,2+m−1,・・・,Np−2*m+1,p−m}へと分割することができる。次いで、範囲0<i≦p−2*m+1でiを見つけるために距離を計算することができ、それは、Dis(Ni,i+m−1,Nnow)の値が最小になるようにする。次いで、現在のものに最も類似したサブシーケンスNi,i+m−1を決定することができる。
セット内のすべての履歴サブシーケンスについて、距離d=Dis(Ni+m−1,Nnow)を計算して距離セットD={d,d,・・・・・・,dp−2*m+1}を得ることができる。D内のすべての要素がソートされた後、最近接距離[d,d,・・・・・・,d]を決定することができ、距離[a,b,・・・,・・・,k]のインデックスは、最も類似したサブシーケンスのインデックスである。
これらK個の最近傍シーケンスの直後のサブシーケンスは、最終予測を生成するために結合されるのが好ましい。2つの要因を考慮することが好ましい。第1に、類似性は、モデルで考慮されるべきであり、概して、類似性が高いものほどより大きい重みを有するべきである。第2に、サブシーケンスの出現時間、概してより最近の出現時間はより大きい重みを有するべきである。したがって、様々な実施形態では、k個のサブシーケンスは、現在のサブシーケンスとの類似性および発生時間に従ってソートされる。次いで、線形回帰手法を適用して、k番目の予測に対する重みを学習することができる。
次に、ステップ64において、要求特徴または属性が分析される。属性は、上述のように、要求の持続時間、ディスクIO、CPUおよび/またはメモリ使用率などの要求データを含むことができる。このステップ64は、様々な実施形態による3つのサブステップ、ステップ66における訂正分析、ステップ68における要求分類、ステップ70における周期性分析を含むことができる。訂正分析ステップ66において、各要求は概して、異なるワークロードを様々なコンピュータリソースにもたらす。したがって、ワークロードを特徴付けるために、複数の特徴を使用するべきである。1つの問題は、これらのワークロード特徴に相関があるかどうかである。例えば、CPUの消費量が少なくなると、ディスク入力/出力の消費量も減少するという主張が、あるアプリケーションに当てはまるかどうかが分かるはずである。
様々な実施形態に従って、ピアソン相関係数をこのステップで使用することができる。要求ワークロードが2つの特定の特徴を有していると仮定すると、これは2つの時系列X=[x,x,・・・,x]およびY=[y,y,・・・,y]によってさらに表すことができ、式中、i番目の要求の値は(x,y)として表すことができ、これら2つの特徴間の相関関係は、次のように表すことができる。
Figure 0006756048
この相関係数の絶対値が大きいほど、相関度は高い。値が0に近い場合、2つの特徴は、ほぼ独立していることを示す。
要求分類ステップ68に関しては、特徴数に対する特徴値の分布を観察することによって、いくつかの特徴が複数のピークを有することがあり、これは特徴値を分類することができることを示す。要求をクラスの比率に従って過去からサンプリングすることができるように、異なるタイプへと分類することができる。分類プロセスの間、分類は、相関のある特徴についてなされるべきである。このステップでは、古典的なk平均法クラスタリングアルゴリズムに基づく二等分K平均法を、局所最適解に陥ることを回避するために使用することができる。このクラスタリングアルゴリズムは、3つのステップに分割することができる。第1のステップは、クラスタリング中心を見つけることであり、第2のステップは、各点とクラスタ中心との間の距離を計算し、各点を最も近いクラスタに入れることであり、第3のステップは、すべてのクラスタ座標の平均値を新しいクラスタ中心として計算することである。二等分K平均クラスタリング法は、最初にすべての点を1つのクラスタの中へと入れ、次いで1つのクラスタを2つに分割し、最後に最大誤差を低減させることができるクラスタを2つのクラスタに分割することを選択することによってさらに強化することができる。このプロセスは、クラスタの数がユーザによって与えられたKの数に等しくなるまで繰り返すことができる。
循環的要因は、予測における重要な要因である。サーバへの要求は、人々から行われるため、勤務時間と勤務時間外の要求数が異なることは明らかである。したがって、循環的要因の影響は、周期性分析ステップ70において考慮されるべきである。一実施形態では、高速フーリエ変換(FFT)を使用して、要求特徴シーケンスのサイクル長を計算することができる。時間間隔tにおける特性xの平均値を得ることができる。次いで、サンプリングレートf=1/tで、時系列f(n)、式中n=0,1,2,・・・,N−1、を決定することができる。
f(n)の離散フーリエ変換(DFT)をF(k)と仮定して、
Figure 0006756048
を得ることができ、式中、
Figure 0006756048
k=0,1,2,・・・,N−1である。DFTを得た後、各kは、次のように表すことができる、離散周波数値に対応する。
Figure 0006756048
シーケンスが周期的である場合、フーリエ変換関数のスペクトルは、周期の逆数でヒットし、衝撃値によってf(n)の周期を得ることができる。単一の特徴によって表される要求負荷については、対応するサイクル時点から要求をサンプリングすることだけが必要とされる。複数のカテゴリへと分類されている要求については、あらゆる時間単位における各カテゴリの比率を予測することができ、これはステップ62で導入されたK−NN手法を採用することによって行うことができる。
分析の結果により、ステップ72において、未来の要求をシミュレートするために、履歴データから要求データを抽出することができる。周期性分析により、サイクルの長さがTperidであることが示されたと仮定する。分類では、要求は、K個のクラスに分割され、履歴要求収集Nhistoryは、いくつかのサブセットに分割される。
Figure 0006756048
p個の要求がある時間間隔tpredictで未来発生すると予測され、k−stクラスの予測された比率がwkであると仮定する。したがって、カテゴリkの要求数は、pk=wk*pである。履歴サブセットNtpredict,k,pのサイズの範囲内で、要求を選択するために、乱数を生成することができる。次いで、すべてのカテゴリの要求を、シミュレートされた未来の要求の集合体に統合することができる。各履歴要求の発生時刻は、各単位時間間隔内で固定されていない。その相対的な開始時間は、次のように表すことができる。
unit=tactual−kT、k=0,1,2,・・・
未来の要求シーケンスのシミュレーション中に、実際の要求時間は、tpredict=tunit+tperiodとして表すことができる。
上記の方法により、未来のワークロードトレースを生成することができる。また、未来のワークロードトレースに基づいて、予想されるワークロードに基づいて企業のユーザのニーズを満たすことができるように未来の期間についてサーバ数推奨を行うことができる(図2のステップ58参照)。
上述の解決策の1つの利点は、ワークロードが複数のメトリクスに基づいて測定されることであり、これは単一のメトリクスの制限を克服する。別の利点は、未来の要求数と各要求が様々なメトリクスに与える影響を考慮しながら、各要求によってもたらされるワークロードをモデル化することで、より正確な予測を行うことである。そのため、この解決策は、全体的なワークロード予想手法で経験した制限を克服する。
予想された使用パターンの別の潜在的な有益な用途は、サービスとしてのデスクトップ(DaaS)を提供するクラウドコンピューティングベンダーによってホストされている、仮想デスクトップに移行する企業向けである。企業は、予測を実行して、CPU数、RAM容量、および/またはストレージ容量などの、予想されたDaaSリソースサイズを決定することができる。そのようにして、企業は、そのニーズのために過度に多くのクラウドコンピューティングリソースを保有しておくこと(かつ、それによってそのニーズのために過払いすること)、および過度に少ないラウドコンピューティングリソースしか保有しておかないこと(かつ、それによってそのユーザに対する必要とされるリソースを有しないこと)を回避することができる。
別の有益な用途は、企業が特定のワークロードまたはリソースに対して必要とするネットワークサーバ18の数を決定することである。(上述の推奨方法のいずれかに従って)必要なサーバ数を示す特定のリソースに対する企業の予想された使用パターンに基づいて、企業は適切な数のサーバを調達することができる。例えば、システムが高負荷状態にあるとき、コントローラは要求を共有するために、例えば、仮想サーバなどのサーバをシステムに追加する。システムの負荷が低い場合、コントローラは、余分なリソースを返してコストを削減する。図6は、そのような決定をするためのコントローラ120(例えば、図1に示されているリソース予測コンピュータシステム20)を図示している。
システムの要求は、時系列データとして説明することができ、すなわち要求の数は、時間とともに周期的に変化している。例えば、昼間の要求は、概して夜間の要求よりも多くなる。本発明の様々な実施形態では、コントローラ120は、未来の要求を予測し、異なる方針に従ってシステムを調整する。プロセスの一般的なステップは、図6に関連して以下に説明される。
k−NN予測部122は、未来の要求を予測するためにk−NNアルゴリズムを使用する。様々な実施形態では、予測部122は、特定の期間数ではなく、次の期間中に要求パターンを予測するだけである。要求パターンは、増加、減少、および変動の3つのタイプに分割することができる。要求パターンは、要求数がX1期間(例えば、3期間)にわたって増加した場合、またはZ1期間(例えば、Z1=2)中にY1%(例えば、40%)を超えて増加した場合、増加として分類することができる。増加パターンの後の次のパターンもまた、それらが連続的な増加しない期間を満たすまで増加パターンとして分類されることになる。Z2期間(例えば、Z2=Z1=2)中に要求数がX2期間にわたって減少し続ける(例えば、X2=X1=3)、またはY2%を超えて減少する(例えば、Y2=Y1=40%)場合、要求パターンは、減少として分類される。他のパターンは、変動として分類され、これを除いて様々な実施形態では、増加または減少パターンに続く期間も、場合によっては減少期間または増加期間が生じるまで、増加または減少に分類することができる。
図7は、1日の典型的なサービスシステムの負荷を示す。この例では、サンプル期間は、15分ごとである。この例では、午前7時から午前8時まで、要求データは、増加傾向にある。要求数は、この時間枠内でわずかな減少期間を有して急速に増加する。午前8時から午前9時まで、要求数は、減少パターンにあり、要求数は、この1時間の期間の大部分で減少する。午前10時から午後2時(すなわち、時間/時間軸上で14時)まで、要求データは、この4時間の期間中要求数が変動し続けるので、変動パターンにある。他の期間も同様に分類することができる。要求パターンを3つのタイプに分割した後、k−NN予測部122は、次の制御サイクルのための要求パターンを予測する。すべての制御サイクルの要求数が記録される。予測部122は、いくつかの連続する点(例えば、5つの連続する点)を1つのグループとしてグループ化し、最新のデータグループを分類するためのサンプルデータとする。次いで、k−NN予測部122は、履歴データから類似グループを探索する。様々な実施形態において、要求は通常周期性を示すので、k−NN予測部122は、履歴内の類似の周期的時間を探索する。2つのグループ間の分散は、それらの間の類似度を決定するために使用される。次いで、k−NN予測部122は、K個の最も類似したグループ(例えば、K=5)を選択する。これらの類似のグループを見つけた後、k−NN予測部122は、グループの次の期間のパターンを得て、次の期間に対する要求パターンの予測として最も高い頻度のパターンを取る。
3つのパターンは、異なる特徴を有している。その結果、意志決定部126は、異なる制御方針を適用することができる。増加するパターンでは、仮想プロバイダーからサーバリソースを取得してサービスの開始を待つのに時間がかかるため、事前にサーバを追加する必要がある。以下の式は、追加サーバの必要数を計算するために使用することができる。
Figure 0006756048
ここで、u(t)は、時刻tにおける制御出力であり、これは追加するサーバ数であり、e(t)は、システムの負荷と理想的な負荷との偏差であり、Kは、比例係数であり、r´(t)は、時間tにおける予測要求数であり、Tは、制御周期であり、Aは、予測影響係数である(予測が制御プロセスにどの程度影響するかを決定する)。式の右側の第1の部分(すなわち、Ke(t))は、従来の比例制御である。第2の部分(すなわち、AK(r´(t+T)−r´(t)))は予測の影響を制御プロセスに導入し、予測影響係数によって出力に影響を与える。
減少パターンでは、サーバの低減が遅延をもたらすことはめったにないので、事前にサーバを減少させる必要性はほとんど、またはまったくない。したがって、意思決定部126は、システムの負荷が低いときにサーバを閉じてサーバに戻すことができる。計算は、式u(t)=Ke(t)に従って行うことができる。増加パターンに対する上述の式と比較して、減少パターンの式は、比例制御部分のみを含む。
変動パターンでは、意思決定部126は、要求が頻繁に変動する場合があるので、システムの負荷の変化に慎重に対処しなければならない。意志決定部126が、負荷に応じてサーバを変動させるだけの場合、サーバの起動と停止を繰り返すことで発生するエネルギー消費コストに加えて、サーバが1時間単位で支払われるため、システムが不安定になり、多大な無駄が生じる可能性がある。そのため、変動パターンについては、意思決定部126は、以下の式を使用することができる。
Figure 0006756048
e(t)≧0のとき、意志決定部126は、比例制御によってサーバを追加するだけである。e(t)<0の場合、これはサーバ数を低減する必要があり得ることを意味し、意思決定部126は、最後の3つの制御期間(または他のいくつかの制御期間)にわたる負荷レベルを収集し、これらの期間すべての間システムが低負荷状態にあった場合、コントローラは、(3つの制御期間のうちの)負荷が最も大きい制御期間を選択して、減少パターンについて上述したようにクローズして戻すサーバ数を計算する。制御ポリシーの目的は、システムの安定性を確保しながらサーバ数を安定させることである。
サーバを追加することは、いくらかの遅延を有する場合があるため、コントローラ120は、遅延の影響を補償するためにスミス予測部124を含んでもよい。スミス予測部124は、利用可能/購入されているがまだ使用されていないサーバ数を入力として受信することができる。この入力に基づいて、スミス予測部124は、これらのサーバの容量を推定し、これらの保留容量をシステムの現在の負荷に対して補償する。次いで、補償されたシステムの負荷は、意思決定プロセスで使用するために意思決定部126に配信される。スミス予測部124の原理は、様々な実施形態において、補償部分がシステムのフィードバックに導入され、それが遅延されたフィードバック量を事前に意志決定部126に入れることである。
図8は、本発明の様々な実施形態によるコントローラ120の伝達関数である。この図では、G(s)e−tsは、システム内の遅れを表し、スミス予測部の伝達関数は、G(s)(1−e−ts)である。スミス予測部124は、k−NN予測部122 Gτ(s)に接続され、純粋な時間遅延補償を有するコントローラが形成される。スミス予測部を追加すると、システムの閉ループ伝達関数は、次のようになる。
Figure 0006756048
特性方程式は、次のとおりである。
Figure 0006756048
特性方程式内の遅延項は、スミス予測部の補償後に除去され、これはシステムに対する遅延の影響を低減することが分かる。
学習部128は、システム負荷および状態情報を収集し、その情報を使用して、意思決定部126において比例係数Kをオンラインで調整する。比例係数Kは、コントローラ120がシステムの負荷にどのように反応するかを決定する。K値が大きいほど、より多くの調整が行われるが、それによってシステムはより変動しやすくなる。学習部128は、式に従ってオンラインでKを調整することができ
Figure 0006756048
式中、Tは、サンプリング期間の長さであり、sは、この期間の平均サーバ数であり、rは、この期間の完了した要求数であり、sT/rは、単位時間あたりの単位サーバの効率を表し、Lは、修正係数で、調整率を決定する。Lの値が大きいと、Kの応答はより速くなるが、変動にもつながる場合がある。
コントローラ120は、部材26に格納されている適切なソフトウェア命令を用いて上述のプロセスを実施することができ、コンピュータシステム20のプロセッサ(複数可)24によって実行される(図1参照)。例えば、メモリ26は、上述のプロセスを実施するためにプロセッサ(複数可)24によって実行される、k−NN予測、スミス予測、学習、および意思決定のためのソフトウェアモジュールを含んでもよい。その結果をブローカコンピュータシステム40に提供することができ、場合によっては、それはネットワークサーバのランプアップまたはランプダウンを実行することができる。これら4つの部分(122、124、126、128)を組み入れ、様々な要求パターンに対して異なる制御ポリシーを適用することによって、本発明の実施形態は、ほとんどの期間にわたって、スケーラブルクラウドシステムに適切な制御を行うことができ、システムの性能を保証し、かつ不要なコストを削減する。
さらに別の有益な用途は、仮想ユーザのワークロードのシミュレーションである。仮想システムの模擬負荷テストのために、実際のクライアントワークロードに基づいた履歴的な時間データおよび未来の時間データを生成することができる。
したがって、様々な実施形態では、本発明は、企業コンピュータシステムに対するネットワークリソースのニーズを予想するコンピュータシステムおよび関連するコンピュータ実装方法を対象とする。様々な実施形態によれば、コンピュータデータベースシステムは、複数のネットワークサーバに関する多変量時系列(MTS)性能データを受信して格納する。MTS性能データは、一連の過去のサンプリング時間についての複数のネットワークサーバに対する複数のd個の性能変数に対するデータを含む。プログラムされたコンピュータシステム(例えば、リソース予測コンピュータシステム20)は、MTS性能データ内の性能変数の各々が変数グループに属するように、MTS性能データ内の変数を2つ以上の変数グループにグループ化する。次いで、プログラムされたコンピュータシステムは、1つ以上の未来の時間範囲ステップで変数の予測を計算することによって、企業コンピュータシステムのネットワークサーバの未来のワークロードの予測を計算する。プログラムされたコンピュータシステムは、以下を含むステップを実行することによって予測を計算する。
(i)2つ以上の変数グループに適用されるk最近傍探索アルゴリズムを使用して、MTS性能データの基準状態に対するk個の最近傍を見つけること、および
(ii)k個の最近傍の加重平均を計算すること。次いで、プログラムされたコンピュータシステムは、計算された予測に基づいて、1つ以上の未来の時間範囲ステップの各々において、企業コンピュータシステムのユーザによるリソース要求に対処するために、企業が動作モードにあるために必要な推奨ネットワークサーバ数を決定することができる。
様々な実装態様では、複数のネットワークサーバに対する性能変数は、少なくとも、単位期間あたりのCPU負荷、一次コンピュータメモリ利用率、および二次コンピュータストレージ入出力(IO)操作を示す変数を含む。また、変数をグループ化するステップは、プログラムされたコンピュータシステムによって、性能変数の各対間の相関を示す相関行列を計算するステップと、プログラムされたコンピュータシステムによって、クラスタリングアルゴリズムを使用して相関行列に基づいて変数グループを決定するステップと、も含んでもよい。相関行列はスピアマン相関行列を含んでもよく、クラスタリングアルゴリズムは、アフィニティプロパゲーションクラスタリングアルゴリズムを含んでもよい。
また、MTS性能データの基準状態に最も近いk個の最近傍を見つけるステップは、(i)MTSの基準状態を表すベクトルとMTSデータを表す複数のベクトルの各々との間の距離をそれぞれ以前のサンプリング時間において計算することと、(ii)MTSの基準状態を表すベクトルまでの距離が最も小さい過去のサンプリング時間についてk個のベクトルを決定することと、を含んでもよい。計算された距離は、ユークリッド距離であってもよい。
さらに、プログラムされたコンピュータシステムは、未来の時間範囲ステップのうちの少なくとも1つについて、企業コンピュータシステムのユーザによるリソース要求に対処するために、企業が動作モードにあるために必要な推奨ネットワークサーバ数を示すデータを送信してもよい。したがって、1つ以上のブローカコンピュータシステムは、推奨ネットワークサーバ数が少なくとも1つの未来の時間範囲ステップの間ユーザによるリソース要求に対処するための動作モードになるように、ネットワークサーバに命令してもよい。
別の一般的な態様では、本発明は、未来の期間にわたるネットワークサーバの未来のワークロードを予測するためのコンピュータシステムおよび関連するコンピュータ実装方法を対象とする。プログラムされたコンピュータシステム(例えば、リソース予測コンピュータシステム20)は、期間のk個の最も最近のサブシーケンスのソートに基づいて、未来の期間についての要求数pを予測し、単位時間T当たりの企業コンピュータシステムのユーザによるネットワークサーバへの要求数は、最近の期間の現在のサブシーケンスと最も類似している。次いで、プログラムされたコンピュータシステムは、(データベース22に格納されたデータに基づいて)履歴要求を要求の属性に基づいて2つ以上の要求タイプクラスに分類する。次いで、プログラムされたコンピュータシステムは、2つ以上の要求タイプクラスの各々における履歴要求の比率に基づいて、2つ以上の要求タイプクラスの各々について、未来の期間における要求の比率を予測する。次いで、プログラムされたコンピュータシステムは、要求タイプクラスについて1つ以上の要求属性に対する周期性を決定する。次いで、プログラムされたコンピュータシステムは、p個のサンプルが、2つ以上の要求タイプクラスの各々の予測比率を有するように、かつp個のサンプルが、要求タイプクラスの周期性に基づいて、将来の期間と同じ要求サイクルポイントからのものであるように、p個の履歴要求をサンプリングする。最後に、プログラムされたコンピュータシステムは、p個のサンプリングされた履歴要求を合成して未来の期間のネットワークサーバに対するワークロードトレースを得る。
様々な実装態様によれば、1つ以上のブローカシステムは、予測された未来のワークロードに基づいて、未来の期間にネットワークサーバの状態を調整することができる。また、プログラムされたコンピュータシステムは、履歴リクエストの属性の相関分析を実行し、相関分析に基づいて履歴要求を2つ以上のクラスに分類することを含め、要求の属性に基づいて、履歴要求を2つ以上の要求タイプクラスに分類することもできる。プログラムされたコンピュータシステムは、相関分析を実行する際に要求の属性のペア間のピアソン相関係数を計算し、要求の要求属性に基づいて、要求を2つ以上の要求に分割するためにクラスタリングアルゴリズムを使用することができる。また、高速フーリエ変換を周期性分析に使用して、2つ以上のクラスの1つ以上の要求属性のサイクル長を計算することもできる。
別の一般的な態様によれば、本発明は、企業コンピュータシステムに対するネットワークリソースのニーズを予想するコンピュータシステムおよび関連するコンピュータ実装方法を対象とする。プログラムされたコンピュータシステム(例えば、リソース予測コンピュータシステム20)は、企業コンピュータシステムユーザのユーザ要求データに基づいて、未来の時間範囲ステップについて予測されたユーザリソース要求パターンを決定する。次いで、プログラムされたコンピュータシステムは、未来の時間範囲ステップに対する予測されたユーザリソース要求パターンの分類に基づいて、未来の時間範囲ステップについて企業が必要とする推奨サーバ数を計算する。そうすることで、プログラムされたコンピュータシステムは、未来の時間範囲ステップに対する予測されたユーザリソース要求パターンが増加として分類されるときに、第1の制御ポリシーを使用して推奨サーバ数を計算し、未来の時間範囲ステップに対する予測されたユーザリソース要求パターンが減少として分類されたときに、第2の制御ポリシーを使用して推奨サーバ数を計算する。
様々な実装態様では、第1の制御ポリシーは、比例定数Kを含む第1の式を使用して推奨サーバ数を計算し、第2の制御ポリシーは、比例定数Kを含む第2の式を使用して推奨サーバ数を計算する。その場合、プログラムされたコンピュータシステムは、単位期間内の単位ネットワークサーバの効率に基づいて、第1および第2の制御ポリシーに対して、比例定数Kをオンラインで調整することもできる。また、プログラムされたコンピュータシステムは、未来の時間範囲ステップに対する予測されたユーザリソース要求パターンが増加または減少として分類されないときに、第3の制御ポリシーを使用して推奨サーバ数を計算することもできる。3番目の制御ポリシーは、比例定数Kを含む(第3の)式を使用して推奨サーバ数を計算することもできる。
様々な実装態様では、未来の時間範囲ステップに対する予測されたユーザリソース要求パターンは1つ以上の条件が満たされると増加して分類され、この1つ以上の条件は、予測要求数が連続した時間範囲ステップの第1の閾値数(N1)を超えて増加したという第1の条件と、予測要求数が連続した時間範囲ステップの第2の閾値数(N2)を超えて第1の閾値パーセンテージより多く増加したという第2の条件と、を含む。また、増加の分類のための1つ以上の条件は、(i)直前の時間範囲ステップが増加として分類され、かつ(ii)未来の時間範囲ステップが減少として分類されないという第3の条件を含むことができる。同様に、未来の時間範囲ステップに対する予測されたユーザリソース要求パターンは、1つ以上の条件が満たされると減少として分類することができ、この1つ以上の条件は、予測要求数が、連続した時間範囲ステップの第3の閾値数(N3)を超えて減少したという第1の条件、および予測要求数が、連続した時間範囲ステップの第4の閾値数(N4)を超えて第2の閾値パーセンテージより多く減少したという第2の条件を含む。(i)直前の時間範囲ステップが減少として分類され、かつ(ii)未来の時間範囲ステップが増加として分類されないという、減少の分類のための第3の条件もある可能性がある。プログラムされたコンピュータシステムはまた、増加する未来の時間範囲ステップのために、企業によって必要とされる推奨サーバ数を計算するときに、現在使用されていない利用可能なネットワークサーバの容量を補償することもできる。
例えば、図1は、本発明の態様を理解するのに十分な企業コンピュータシステム10の構成要素のみを図示していることに留意されたい。企業コンピュータシステム10は、有線(例えば、ツイストペアケーブルを介したイーサネット(登録商標))または無線(例えば、Wi−Fi)の通信リンクを有する、多数の相互接続ネットワークされたLAN、WAN、MANなどを含むことができることを認識するべきである。ネットワークサーバ18は、企業の要求に応じて多数の異なるタイプのリソースに対処することができ、クライアントコンピュータ16は、ラップトップ、パーソナルコンピュータ、タブレットコンピュータ、スマートフォンなどのような、任意の好適なタイプのネットワーク対応エンドユーザコンピュータデバイスとすることができる。リソース予測コンピュータシステム20は、1つ以上のネットワークコンピュータ装置によって実装することができる。リソース予測コンピュータシステム20が複数のコンピュータ装置を含む場合、それらは1つ以上のLAN、WAN、MANなどによって相互接続ネットワークすることができる。さらに、企業コンピュータシステム10は、サーバ18をプロビジョニングするための追加のブローカコンピュータ40を含んでもよい。
本明細書に記載のソフトウェアモジュールは、プロセッサ(複数可)24がモジュールのソフトウェアプログラムを実行するときに、プロセッサ(複数可)24が本明細書に記載のモジュールの機能を実行させるように、パイソン(Python)などの任意の好適なコンピュータ言語で書かれた1つ以上のコンピュータプログラム内に実装することができる。命令のプログラムを実行するために好適なプロセッサ24は、例として、一般および特殊用途の両方のマイクロプロセッサを含む。さらに、本明細書に記載の任意のコンピュータ構成要素は、単一のプロセッサまたは複数のプロセッサを含むことができる。プロセッサ24は、読み出し専用メモリ、もしくはランダムアクセスメモリ、またはその両方から命令およびデータを受信する。
本明細書は、多くの具体的な実装態様の詳細を含むが、これらはいかなる発明の範囲または特許請求され得るものの限定としても解釈されるべきではなく、むしろ特定の発明の特定の実装態様に特有である可能性のある特徴の説明として解釈されるべきである。本明細書において別々の実装態様の文脈で記載されている特定の特徴は、単一の実装態様において組み合わせて実装することもできる。逆に、単一の実装態様の文脈で記載されている様々な特徴は、別々にまたは任意の好適な副次的組み合わせで複数の実装態様で実施することもできる。さらに、特徴は、ある組み合わせにおいて作用するものとして上で説明されてもよく、かつ当初はそのように特許請求されてもよいが、場合によっては特許請求された組み合わせからの1つ以上の特徴を切り取ることができ、また特許請求された組み合わせは副次的組み合わせまたは副次的組み合わせの変形を対象としてもよい。
同様に、動作は特定の順序で図面に描かれているが、これは望ましい結果を達成するためには、そのような動作が示された特定の順序または順次に実行されること、またはすべての図示された動作が実行されることが必要であるように理解するべきではない。特定の状況では、多重タスク処理および並列処理が有利な場合がある。さらに、上述の実装態様における様々なシステム構成要素の分離は、すべての実装態様においてそのような分離を必要とすると理解されるべきではなく、記載されたプログラム構成要素およびシステムは、概して単一の製品において統合することができ、または複数の製品にパッケージ化することができると理解されるべきである。
このようにして、主題の特定の実装態様を記載した。他の実装態様は、以下の特許請求の範囲内にある。場合によっては、請求項に記載されている動作は異なる順序で実行することができ、それでも望ましい結果を達成することができる。さらに、添付の図面に示されたプロセスは、望ましい結果を達成するために、示された特定の順序、または順次順序を必ずしも必要としない。特定の実装態様では、多重タスク処理および並列処理が有利である場合がある。

Claims (12)

  1. 企業コンピュータシステムに対するネットワークリソースのニーズを予想するコンピュータ実装される方法であって、前記企業コンピュータシステムは、前記企業コンピュータシステムのユーザのためのコンピュータリソースをホストする複数のネットワークサーバを備え、前記方法は、
    コンピュータデータベースシステムによって、前記複数のネットワークサーバに対する能データを含む多変量時系列(MTS)を受信することであって、前記性能データが、一連の過去のサンプリング時間に対する前記複数のネットワークサーバに対する複数のd個の性能変数含む、受信することと、
    前記d個の性能変数の各々が性能変数グループに属するように、前記コンピュータデータベースシステムと通信するプログラムされたコンピュータシステムによって、前記性能データの前記d個の性能変数の各々を2つ以上の性能変数グループへとグループ化することであって
    前記プログラムされたコンピュータシステムによって、性能変数の各対間の依存度を表す相関行列を計算することと、
    前記プログラムされたコンピュータシステムによって、前記依存度に基づいて、前記2つ以上の性能変数グループを決定することと、を含む、グループ化することと、
    プログラムされたコンピュータシステムによって、1つ以上の未来の時間おいて前記d個の性能変数に対する予測を計算することによって、前記企業コンピュータシステムの前記複数のネットワークサーバの未来のワークロードの予測を計算することであって、
    前記2つ以上の性能変数グループに適用されるk最近傍探索アルゴリズムを用いて、前記性能データの基準状態を表す変数のベクトルに対するk個の最近傍を見つけることと、
    前記k個の最近傍の加重平均を計算することと、を含む、計算することと、
    プログラムされたコンピュータシステムによって、前記計算された予測に基づいた前記1つ以上の未来の時間各々において、前記企業コンピュータシステムの前記ユーザによるリソース要求に対処するための動作モードにあるために、前記企業コンピュータシステムによって必要とされる前記複数のネットワークサーバにおける推奨ネットワークサーバ数を決定することと、を含む、方法。
  2. 前記複数のネットワークサーバに対する前記d個の性能変数が、少なくとも以下の:
    CPU負荷と、
    一次コンピュータメモリ使用と、
    単位期間あたりの二次コンピュータストレージ入力/出力(IO)動作と、を示す変数を含む、請求項1に記載の方法。
  3. 前記相関行列が、スピアマン(Spearman)相関行列を含む、請求項に記載の方法。
  4. 前記プログラムされたコンピュータシステムによって、前記依存度に基づいて、前記2つ以上の性能変数グループを決定することは、アフィニティプロパゲーション(Affinity Propagation)クラスタリングアルゴリズムを用いて前記2つ以上の性能変数グループを決定することを含む、請求項に記載の方法。
  5. 前記性能データの前記基準状態を表す変数のベクトルに対する前記k個の最近傍を見つけることが、
    前記基準状態を表す変数のベクトルと、過去のサンプリング時間における前記性能データを表す複数のベクトルの各々との間の距離をそれぞれ計算することと、
    前記基準状態を表す前記変数のベクトルまでの最小距離を有する過去のサンプリング時間に対するk個のベクトルを決定することと、を含む、請求項1に記載の方法。
  6. 距離を計算することが、ユークリッド(Euclidean)距離を計算することを含む、請求項に記載の方法。
  7. 前記1つ以上の未来の時間うちの少なくとも1つについて、前記企業コンピュータシステムの前記ユーザによる前記リソース要求に対処するための動作モードにするために、前記企業コンピュータシステムによって必要とされる前記複数のネットワークサーバにおける前記推奨ネットワークサーバ数を示すデータを、前記プログラムされたコンピュータシステムによって送信することと、
    前記プログラムされたコンピュータシステムと通信している1つ以上のブローカコンピュータシステムによって、前記複数のネットワークサーバにおける前記推奨ネットワークサーバ数が、前記少なくとも1つの未来の時間ついて前記ユーザによる前記リソース要求に対処するための動作モードにあるように、前記複数のネットワークサーバに命令することと、をさらに含む、請求項1に記載の方法。
  8. 企業コンピュータシステムに対するネットワークリソースのニーズを予想するためのシステムであって、前記企業コンピュータシステムが、前記企業コンピュータシステムのユーザのためにコンピュータリソースをホストする複数のネットワークサーバを備え、前記システムが、
    前記複数のネットワークサーバに対する性能データを含む多変量時系列(MTS)格納するために、前記複数のネットワークサーバと通信するコンピュータデータベースシステムであって、前記性能データが、一連の過去のサンプリング時間についての前記複数のネットワークサーバに対する複数のd個の性能変数含む、コンピュータデータベースシステムと、
    前記コンピュータデータベースシステムと通信するプログラムされたコンピュータシステムであって、前記プログラムされたコンピュータシステムが、
    前記d個の性能変数の各々が変数グループに属するように、前記性能データの前記d個の性能変数の各々を2つ以上の性能変数グループにグループ化することであって
    前記プログラムされたコンピュータシステムによって、性能変数の各対間の依存度を表す相関行列を計算することと、
    前記プログラムされたコンピュータシステムによって、前記依存度に基づいて、前記2つ以上の性能変数グループを決定することと、を含む、グループ化することと、
    前記複数のネットワークサーバのワークロードを示す1つ以上の未来の時間おける前記d個の性能変数に対する予測を計算することであって、前記予測が、
    前記2つ以上の性能変数グループに適用されるk最近傍探索アルゴリズムを用いて、前記性能データの基準状態を表す変数のベクトルに対してk個の最近傍を見つけることと、
    前記k個の最近傍の加重平均を計算することと、
    よって計算される、予測を計算することと、
    前記計算された予測に基づいて、前記1つ以上の未来の時間各々において、前記企業コンピュータシステムの前記ユーザによるリソース要求に対処するための動作モードにするために、前記企業コンピュータシステムによって必要とされるネットワークサーバ数を決定することと
    よって、前記企業コンピュータシステムの前記複数のネットワークサーバの未来のワークロードを予測するようにプログラムされている、プログラムされたコンピュータシステムと、
    前記プログラムされたコンピュータシステムおよび前記複数のネットワークサーバと通信する、少なくとも1つのブローカコンピュータシステムであって、
    前記1つ以上の未来の時間うちの少なくとも1つに対する、前記企業コンピュータシステムの前記ユーザによる前記リソース要求に対処するように、動作モードにするために、前記企業コンピュータシステムによって必要とされる前記複数のネットワークサーバにおける推奨ネットワークサーバ数を示すデータを、前記プログラムされたコンピュータシステムから受信するため、および
    前記複数のネットワークサーバにおける前記推奨ネットワークサーバ数が、前記少なくとも1つの未来の時間対する、前記ユーザによる前記リソース要求に対処するための動作モードになるように、前記複数のネットワークサーバに命令するための、ブローカコンピュータシステムと、を備える、システム。
  9. 前記複数のネットワークサーバに対する前記d個の性能変数が、少なくとも以下の:
    CPU負荷と、
    一次コンピュータメモリ使用と、
    単位時間当たりの二次コンピュータストレージ入力/出力(IO)操作と、示す変数を含む、請求項に記載のシステム。
  10. 前記相関行列が、スピアマン相関行列を含む、請求項に記載のシステム。
  11. 前記プログラムされたコンピュータシステムによって、前記依存度に基づいて、前記2つ以上の性能変数グループを決定することは、アフィニティプロパゲーションクラスタリングアルゴリズムを用いて前記2つ以上の性能変数グループを決定することを含む、請求項に記載のシステム。
  12. 前記性能データの前記基準状態を表す変数のベクトルに対する前記k個の最近傍を見つけることが、
    前記基準状態を表す変数のベクトルと、過去のサンプリング時間における前記性能データを表す複数のベクトルの各々との間の距離をそれぞれ計算することと、
    前記基準状態を表す前記変数のベクトルまでの最小距離を有する過去のサンプリング時間に対するk個のベクトルを決定することと、を含む、請求項に記載のシステム。
JP2019534881A 2016-12-26 2016-12-26 コンピュータリソースのための予測的資産最適化 Active JP6756048B2 (ja)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/CN2016/112086 WO2018119568A1 (en) 2016-12-26 2016-12-26 Predictive asset optimization for computer resources

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2020142203A Division JP7111779B2 (ja) 2020-08-26 2020-08-26 コンピュータリソースのための予測的資産最適化

Publications (2)

Publication Number Publication Date
JP2020504382A JP2020504382A (ja) 2020-02-06
JP6756048B2 true JP6756048B2 (ja) 2020-09-16

Family

ID=62706540

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2019534881A Active JP6756048B2 (ja) 2016-12-26 2016-12-26 コンピュータリソースのための予測的資産最適化

Country Status (4)

Country Link
US (2) US11113612B2 (ja)
EP (1) EP3560146B1 (ja)
JP (1) JP6756048B2 (ja)
WO (1) WO2018119568A1 (ja)

Families Citing this family (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6756048B2 (ja) 2016-12-26 2020-09-16 モルガン スタンレー サービシーズ グループ,インコーポレイテッドMorgan Stanley Services Group,Inc. コンピュータリソースのための予測的資産最適化
EP3583505A4 (en) * 2017-02-17 2020-01-08 Visa International Service Association UNIFIED INTELLIGENT CONNECTOR
US11640617B2 (en) * 2017-03-21 2023-05-02 Adobe Inc. Metric forecasting employing a similarity determination in a digital medium environment
WO2020045925A1 (en) 2018-08-27 2020-03-05 Samsung Electronics Co., Ltd. Methods and systems for managing an electronic device
US11343155B2 (en) * 2018-09-13 2022-05-24 Cable Television Laboratories, Inc. Machine learning algorithms for quality of service assurance in network traffic
US11553047B2 (en) * 2018-11-30 2023-01-10 International Business Machines Corporation Dynamic connection capacity management
US11138047B2 (en) * 2018-12-05 2021-10-05 Vmware, Inc. Efficient network services with performance lag prediction and prevention
US10956839B2 (en) * 2019-02-05 2021-03-23 Bank Of America Corporation Server tool
CN111755106A (zh) * 2019-03-28 2020-10-09 株式会社日立制作所 一种门诊量的预测方法及装置
US10999403B2 (en) 2019-09-27 2021-05-04 Red Hat, Inc. Composable infrastructure provisioning and balancing
CN111598390B (zh) * 2019-10-16 2023-12-01 中国南方电网有限责任公司 服务器高可用性评估方法、装置、设备和可读存储介质
US11263049B2 (en) * 2020-04-29 2022-03-01 Bank Of America Corporation System for pattern recognition to customized resource usage
CN111800514B (zh) * 2020-07-13 2022-04-15 华侨大学 一种基于应用和位置感知的云管理系统
JP6950911B1 (ja) * 2020-07-31 2021-10-13 株式会社アイデミ— 需要予測プログラム、需要予測装置、需要予測方法、需要予測通知プログラム、需要予測通知装置及び需要予測通知方法
CN111985726B (zh) * 2020-08-31 2023-04-18 重庆紫光华山智安科技有限公司 资源数量预测方法、装置、电子设备及存储介质
CN112650971B (zh) * 2020-12-31 2024-03-05 新奥数能科技有限公司 一种公式计算的实现方法、装置、设备及存储介质
CN113076196A (zh) * 2021-04-08 2021-07-06 上海电力大学 结合注意力机制和门控循环单元的云计算主机负载预测法
US11252036B1 (en) * 2021-06-10 2022-02-15 Bank Of America Corporation System for evaluating and tuning resources for anticipated demands
CN113722094A (zh) * 2021-08-09 2021-11-30 国网福建省电力有限公司 基于神经网络算法的应用主机资源预测方法
CN117519956A (zh) 2022-07-26 2024-02-06 北京穿杨科技有限公司 资源配额确定方法、装置、计算设备及介质

Family Cites Families (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4071668B2 (ja) 2003-04-16 2008-04-02 富士通株式会社 システムの使用資源を調整する装置および方法
JP2005018304A (ja) 2003-06-25 2005-01-20 Nippon Telegr & Teleph Corp <Ntt> 時系列データ予測方法、装置、時系列データ予測プログラム及びその記録媒体
JP4298581B2 (ja) 2004-05-17 2009-07-22 中国電力株式会社 電力需要予測装置、電力需要予測システム、電力需要予測プログラム、記録媒体、及び電力需要予測方法
JP2006209276A (ja) 2005-01-26 2006-08-10 Hitachi Ltd 生体試料分類システム及びその方法
US20100082507A1 (en) * 2008-09-30 2010-04-01 Archana Sulochana Ganapathi Predicting Performance Of Executing A Query In Isolation In A Database
US8572746B2 (en) * 2010-01-21 2013-10-29 The Regents Of The University Of California Predictive blacklisting using implicit recommendation
US9075665B2 (en) * 2010-06-29 2015-07-07 International Business Machines Corporation Smoothing peak system load via behavior prediction in collaborative systems with temporal data access patterns
US8818787B2 (en) * 2011-01-31 2014-08-26 Yahoo! Inc. Method and system for predicting performance of software applications on prospective hardware architecture
CN102104509B (zh) 2011-02-17 2013-06-19 浪潮(北京)电子信息产业有限公司 云操作系统中服务器负载预测的方法及装置
US8805648B2 (en) 2011-10-05 2014-08-12 Ats Group (Ip Holdings) Limited Data fusion in high computational load environments
US8826277B2 (en) 2011-11-29 2014-09-02 International Business Machines Corporation Cloud provisioning accelerator
CN102664812B (zh) 2012-05-14 2015-05-20 山东大学 融合业务预测与实时负载的两阶段服务系统负载预测与均衡方法
US9235801B2 (en) * 2013-03-15 2016-01-12 Citrix Systems, Inc. Managing computer server capacity
CN103490956A (zh) * 2013-09-22 2014-01-01 杭州华为数字技术有限公司 基于业务量预测的自适应节能控制方法及设备、系统
US10552745B2 (en) * 2013-10-18 2020-02-04 Netflix, Inc. Predictive auto scaling engine
JP2016014990A (ja) 2014-07-01 2016-01-28 学校法人早稲田大学 動画像検索方法、動画像検索装置及びそのプログラム
US20170034720A1 (en) * 2015-07-28 2017-02-02 Futurewei Technologies, Inc. Predicting Network Performance
US10412155B2 (en) * 2015-10-29 2019-09-10 Capital One Services, Llc Automated server workload management using machine learning
US20170372224A1 (en) * 2016-06-28 2017-12-28 General Electric Company Deep learning for imputation of industrial multivariate time-series
JP6756048B2 (ja) 2016-12-26 2020-09-16 モルガン スタンレー サービシーズ グループ,インコーポレイテッドMorgan Stanley Services Group,Inc. コンピュータリソースのための予測的資産最適化

Also Published As

Publication number Publication date
EP3560146A1 (en) 2019-10-30
JP2020504382A (ja) 2020-02-06
US11481653B2 (en) 2022-10-25
WO2018119568A1 (en) 2018-07-05
EP3560146B1 (en) 2022-03-02
US20220215275A1 (en) 2022-07-07
US20200074323A1 (en) 2020-03-05
EP3560146A4 (en) 2020-01-01
US11113612B2 (en) 2021-09-07

Similar Documents

Publication Publication Date Title
JP6756048B2 (ja) コンピュータリソースのための予測的資産最適化
Cao et al. CPU load prediction for cloud environment based on a dynamic ensemble model
US20100030896A1 (en) Estimating latencies for query optimization in distributed stream processing
Hamrouni et al. A survey of dynamic replication and replica selection strategies based on data mining techniques in data grids
Thakkar et al. MUVINE: Multi-stage virtual network embedding in cloud data centers using reinforcement learning-based predictions
CN111124689A (zh) 一种集群中容器资源动态分配方法
Mondal et al. Scheduling of time-varying workloads using reinforcement learning
Liu et al. Workload forecasting based elastic resource management in edge cloud
JP7111779B2 (ja) コンピュータリソースのための予測的資産最適化
Banerjee et al. Efficient resource utilization using multi-step-ahead workload prediction technique in cloud
JP2021005387A5 (ja)
CN108241526B (zh) 基于模式预测的自适应控制策略
Liao et al. Adaptive resource prediction in the cloud using linear stacking model
CN108241864A (zh) 基于多变量分组的服务器性能预测方法
Kalai Arasan et al. Energy‐efficient task scheduling and resource management in a cloud environment using optimized hybrid technology
Horn et al. Multi-objective hybrid autoscaling of microservices in Kubernetes clusters
CN108241533B (zh) 一种基于预测和分层抽样的资源池未来负载生成方法
Li et al. Batch Jobs Load Balancing Scheduling in Cloud Computing Using Distributional Reinforcement Learning
Setayesh et al. An efficient online prediction of host workloads using pruned GRU neural nets
Jayalakshmi Predictive scaling for elastic compute resources on public cloud utilizing deep learning based long short-term memory
Fakhartousi et al. Autonomic Dominant Resource Fairness (A-DRF) in Cloud Computing
Tairin et al. Embracing Uncertainty for Equity in Resource Allocation in ML Training
Huang et al. Accurate Prediction of Required Virtual Resources via Deep Reinforcement Learning
Bansal et al. Deep Learning-based Workload Prediction in Cloud Computing to Enhance the Performance
Yu et al. Integrating clustering and regression for workload estimation in the cloud

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190819

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20190819

A871 Explanation of circumstances concerning accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A871

Effective date: 20190819

A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20191227

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20200121

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20200420

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: 20200728

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20200826

R150 Certificate of patent or registration of utility model

Ref document number: 6756048

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250