(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-12-02
(45)【発行日】2024-12-10
(54)【発明の名称】カスタマイズされた統合フローのテンプレート提供
(51)【国際特許分類】
G06F 9/48 20060101AFI20241203BHJP
G06Q 10/0633 20230101ALI20241203BHJP
G06Q 10/10 20230101ALI20241203BHJP
【FI】
G06F9/48 370
G06Q10/0633
G06Q10/10 310
(21)【出願番号】P 2022549643
(86)(22)【出願日】2021-02-11
(86)【国際出願番号】 IB2021051108
(87)【国際公開番号】W WO2021171124
(87)【国際公開日】2021-09-02
【審査請求日】2023-07-21
(32)【優先日】2020-02-24
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】390009531
【氏名又は名称】インターナショナル・ビジネス・マシーンズ・コーポレーション
【氏名又は名称原語表記】INTERNATIONAL BUSINESS MACHINES CORPORATION
【住所又は居所原語表記】New Orchard Road, Armonk, New York 10504, United States of America
(74)【代理人】
【識別番号】100112690
【氏名又は名称】太佐 種一
(74)【代理人】
【識別番号】100120710
【氏名又は名称】片岡 忠彦
(72)【発明者】
【氏名】シン、チェングゥアン
(72)【発明者】
【氏名】ハリソン、アシュレイ・ドナルド
(72)【発明者】
【氏名】チャップマン、マシュー・ポール
(72)【発明者】
【氏名】ダニエル、アンドリュー・ジェームス
【審査官】坂庭 剛史
(56)【参考文献】
【文献】特開2012-014291(JP,A)
【文献】米国特許出願公開第2010/0223629(US,A1)
【文献】特表2009-540469(JP,A)
【文献】特表2009-505218(JP,A)
【文献】特開2008-210227(JP,A)
【文献】特開2008-009966(JP,A)
【文献】特開2006-004346(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
G06F 9/48
G06Q 10/0633
G06Q 10/10
(57)【特許請求の範囲】
【請求項1】
カスタマイズされた統合フロー・テンプレートを提供するためのコンピュータ実装方法であって、前記方法は、
統合システムに対する複数の外部システムとのユーザの相互作用をモニタして、前記外部システムにおけるデータ変化を読み出すこと、
2つの前記外部システムにおいて同一のデータ変化イベントを有する2つの外部システムの間のそれぞれの少なくとも1つのイベント・ペアを識別すること、
イベント・チェーンに含ませるために少なくとも1つのイベント・ペアをフィルタリングすること、
前記データ変化イベントのタイムスタンプに基づいて、前記イベント・チェーン内のフィルタされた前記イベント・ペアの前記外部システムを順序付けすること、及び
フロー・トリガ及びフロー・ノード、少なくとも1つのフロー・ノードを定義するイベント・ペアの順序付けされた外部システムに基づいて、統合フローのテンプレートを出力すること
を含む、コンピュータ実装方法。
【請求項2】
同一のデータ変化イベントは、前記データ変化の値の多数の1対1の対応のマッピングを有する前記2つの外部システムで共通するフィールド内に入力された同一のデータ値で識別された多数のインスタンスに応答して発生する、
請求項1に記載の方法。
【請求項3】
少なくとも1つのイベント・ペアを識別することは、それぞれの外部システムのデータ変化イベントを識別すること、及び前記データ変化イベントを、他の外部システムの前記データ変化イベントと比較することを含み、それぞれのイベント・ペアは、識別されたもう1つのイベント・ペアと共通するフィールドを含む、
請求項1に記載の方法。
【請求項4】
さらに、統合システムのアカウントについてのユーザの相互作用に対するユーザ・アクセスを受領することを含み、前記統合システムが複数の外部システムへのアクセスを提供して、事前定義された時間的期間についてのデータ変化を読み出し、かつ統合フロー・テンプレートに基づくユーザ・ルーチンをキャプチャする、
請求項1に記載の方法。
【請求項5】
少なくとも1つのイベント・ペアをフィルタリングすることは、識別されたイベント・ペアをすべてが共通の外部システムを含むイベント・ペアのグループに制限することを含む、
請求項1に記載の方法。
【請求項6】
少なくとも1つのイベント・ペアをフィルタリングすることは、参照するイベント・ペアの同一のデータ変化イベントの同一のデータ変化の値の事前定義された閾値により、前記イベント・ペアをフィルタリングすると共に、前記イベント・チェーンのエンド・ポイントとして前記同一のデータ変化イベントの同一のデータ変化の値を
参照することを含む、
請求項1に記載の方法。
【請求項7】
さらに、参照するイベント・ペアとして同一のデータ変化イベント内で同一のデータ変化の値が最高のイベント・ペアを選択することを含む、
請求項6に記載の方法。
【請求項8】
少なくとも1つのイベント・ペアをフィルタリングすることは、破棄されたイベント・ペアを処理して、統合フロー・テンプレートの基礎としての単一のデータ・フローを見出すと共に如何なるループを削除することを含む、
請求項1に記載の方法。
【請求項9】
前記外部システムを順序付けすることは、
前記イベント・チェーンのそれぞれのエンド・ポイントについて前記イベント・チェーン内の前記データ変化を通して反復すること、及び
多数の同一のデータ変化イベントの前記タイムスタンプを比較することによって、前記イベント・チェーン内の前記イベント・ペアの位置を順序付けて統合フローのテンプレートを生成すること
を含む、
請求項6に記載の方法。
【請求項10】
さらに、いかなる破棄されたイベント・ペアを処理して、もう1つの統合フロー・テンプレートのための基礎として、もう1つのデータ・フローを見出すことを含む、
請求項8に記載の方法。
【請求項11】
統合フローのテンプレートを出力することは、前記順序付けされた外部システムを、既存のテンプレートをマッチングして、使用するためのテンプレートを選択することを含む、
請求項1に記載の方法。
【請求項12】
統合フローのテンプレートを出力することは、他の統合システムのユーザによる使用のため、テンプレートを公開することを含む、
請求項1に記載の方法。
【請求項13】
カスタマイズされた統合フロー・テンプレートを提供するためのシステムであって、前記システムは、
プロセッサ回路と、前記プロセッサ回路にコンピュータ・プログラム命令を提供してコンポーネントの機能を実行するように構成されたメモリと、
統合システムに対する複数の外部システムとのユーザの相互作用をモニタして、前記外部システムにおけるデータ変化を読み出ための、外部システム・モニタリング・コンポーネントと、
2つの前記外部システムにおいて同一のデータ変化イベントを有する2つの外部システムの間のそれぞれの少なくとも1つのイベント・ペアを識別する、イベント・ペア識別コンポーネントと、
イベント・チェーンに含ませるために少なくとも1つのイベント・ペアをフィルタリングする、フィルタリング・コンポーネントと、
前記データ変化イベントのタイムスタンプに基づいて、前記イベント・チェーン内のフィルタされた前記イベント・ペアの前記外部システムを順序付けする、順序付けコンポーネントと、
フロー・トリガ及びフロー・ノード、少なくとも1つのフロー・ノードを定義するイベント・ペアの順序付けされた外部システムに基づいて、統合フローのテンプレートを出力する、テンプレート出力コンポーネントと
を含むシステム。
【請求項14】
前記イベント・ペア識別コンポーネントは、
それぞれの外部システムのデータ変化イベントを識別すること、及び
前記データ変化イベントを、他の外部システムの前記データ変化イベントと比較することを含み、
それぞれのイベント・ペアは、識別されたもう1つのイベント・ペアと共通するフィールドを含む、
請求項13に記載のシステム。
【請求項15】
さらに、統合システムのアカウントについてのユーザの相互作用に対するユーザ・アクセスを受領するユーザ・アクセス・コンポーネントを含み、前記統合システムが複数の外部システムへのアクセスを提供して、事前定義された時間的期間についてのデータ変化を読み出し、かつ統合フロー・テンプレートに基づくユーザ・ルーチンをキャプチャする、
請求項13に記載のシステム。
【請求項16】
前記フィルタリング・コンポーネントが、
識別されたイベント・ペアをすべてが共通の外部システムを含むイベント・ペアのグループに制限すること、及び
参照するイベント・ペアの同一のデータ変化イベントの同一のデータ変化の値の事前定義された閾値により前記イベント・ペアをフィルタリングすると共に、前記イベント・チェーンのエンド・ポイントとして前記同一のデータ変化イベントの同一のデータ変化の値を参照すること
を含む、請求項13に記載のシステム。
【請求項17】
前記フィルタリング・コンポーネントは、
破棄されたイベント・ペアを処理して、統合フロー・テンプレートの基礎としての単一のデータ・フローを見出すと共に、如何なるループを削除すること、及び
いかなる破棄されたイベント・ペアを処理して、もう1つの統合フロー・テンプレートのための基礎として、もう1つのデータ・フローを見出すこと
を含む、
請求項
13に記載のシステム。
【請求項18】
前記順序付けコンポーネントは、
前記イベント・チェーンのそれぞれのエンド・ポイントについて前記イベント・チェーン内の前記データ変化を通して反復すること、及び
多数の同一のデータ変化イベントの前記タイムスタンプを比較することによって、前記イベント・チェーン内の前記イベント・ペアの位置を順序付けて統合フローのテンプレートを生成すること
を含む、
請求項16に記載のシステム。
【請求項19】
前記テンプレート出力コンポーネントは、
前記順序付けされた外部システムを、既存のテンプレートをマッチングして、使用するためのテンプレートを選択すること
他の統合システムのユーザによる使用のため、テンプレートを公開すること
を含む、
請求項13に記載のシステム。
【請求項20】
カスタマイズされた統合フロー・テンプレートを提供するためのコンピュータ・プログラムであって、前記コンピュータ・プログラムは、プロセッサ回路をして、
統合システムに対する複数の外部システムとのユーザの相互作用をモニタして、前記外部システムにおけるデータ変化を読み出すこと、
2つの前記外部システムにおいて同一のデータ変化イベントを有する2つの外部システムの間のそれぞれの少なくとも1つのイベント・ペアを識別すること、
イベント・チェーンに含ませるための少なくとも1つのイベント・ペアをフィルタリングすること、
前記データ変化イベントのタイムスタンプに基づいて前記イベント・チェーン内のフィルタされた前記イベント・ペアの前記外部システムを順序付けすること、及び
フロー・トリガ及びフロー・ノード、少なくとも1つのフロー・ノードを定義するイベント・ペアの順序付けされた外部システムに基づいて、統合フローのテンプレートを出力すること
を実行させる、
コンピュータ・プログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、統合フローの管理に関し、より具体的には、ユーザ・アクティビティに基づく統合フロー・テンプレートを提供することに関する。
【背景技術】
【0002】
統合製品において、ユーザは、統合がトリガされた場合に統合フローを生成して、異なるシステムにおいて異なるアクションを実行することができる。統合製品は、多数の外部システムにおける異なるビジネス・アプリケーションの間に流すためのメッセージとして、情報をパッケージすることが可能である。ビジネス・アプリケーションは、いくつかの場合において、また、ソフトウェア・アズ・ア・サービス(SaaS)として知られる外部的なクラウド・サービス・システムにより提供することができる。
【0003】
単純な統合フローは、例えば、クラウド・サービス・マーケッティング・システムで新たなリードが生成された場合、同一の情報を有するリードが、クラウド・サービス・システム内に生成される。この単純なフローは、そのユーザがそれらのクラウド・サービス・マーケッティング・システムと、それらのクラウド・サービス・セールス・システムとの間でリードを同期することを支援すると共に、クラウド・サービス・マーケッティングを使用し、かつソフトウェア製品を販売するほとんどの事業者が興味のある典型的なフローである。
【0004】
統合製品は、多数のユーザが興味を持ち、かつこれらが典型的なユース・ケースに基づいて生成される統合フローの形態のためのテンプレートを提供することができる。それら自身のフローを構築するためのテンプレートを選択するために、カスタマーは、それらのビジネス・ユース・ケースに基づいてテンプレートを選択すると共に、それらの特定の要求に基づいてテンプレート・フローを修正する必要がある。
【0005】
選択されるべきビジネスのための多くのテンプレートが存在するので、好適なテンプレートを見出し、かつ利用する活動は、彼らがどのシステム及びフローを実装したいのかを未だ正確に知らない可能性のあるユーザにとっては特に時間の浪費であり、かつ混乱する可能性がある。
【0006】
既存のテンプレートを修正することは、ユーザのビジネス・ニーズにテンプレートのフローを適合させるように仕立てるためのいくつかのアクションを実行することを含む可能性がある。このことは、もしもテンプレートが使用されるすべてのシステムを含んでいないならば、システムを追加又は削除すること、又はシステム・ノードの間でフィールド・マッピングを追加又は削除するか、又はこれらの両方を含む可能性がある。
これらの修正は、時間の浪費であり、かつ経験の乏しいユーザにとって実装することが困難な可能性がある。
【発明の概要】
【0007】
実施形態は、カスタマイズされた統合フロー・テンプレートを提供するためのコンピュータ実装方法を提供することができ;統合システムに対する複数の外部システムとのユーザの相互作用をモニタして、前記外部システムにおけるデータ変化を読み出すこと;2つの前記外部システムにおいて同一のデータ変化イベントを有する2つの外部システムの間のそれぞれの少なくとも1つのイベント・ペアを識別すること、;イベント・チェーンに含ませるために少なくとも1つのイベント・ペアをフィルタリングすること;前記データ変化イベントのタイムスタンプに基づいて、前記イベント・チェーン内のフィルタされた前記イベント・ペアの前記外部システムを順序付けすること;及びフロー・トリガ及びフロー・ノード、少なくとも1つのフロー・ノードを定義するイベント・ペアの順序付けされた外部システムに基づいて、統合フローのテンプレートを出力することを含む。
【0008】
実施形態は、また、カスタマイズされた統合フロー・テンプレートを提供するためのシステムを提供することができ;プロセッサ回路と、前記プロセッサ回路にコンピュータ・プログラム命令を提供してコンポーネントの機能を実行するように構成されたメモリと;統合システムに対する複数の外部システムとのユーザの相互作用をモニタして、前記外部システムにおけるデータ変化を読み出ための、外部システム・モニタリング・コンポーネントと;2つの前記外部システムにおいて同一のデータ変化イベントを有する2つの外部システムの間のそれぞれの少なくとも1つのイベント・ペアを識別する、イベント・ペア識別コンポーネントと;イベント・チェーンに含ませるために少なくとも1つのイベント・ペアをフィルタリングする、フィルタリング・コンポーネントと;前記データ変化イベントのタイムスタンプに基づいて、前記イベント・チェーン内のフィルタされた前記イベント・ペアの前記外部システムを順序付けする、順序付けコンポーネントと;フロー・トリガ及びフロー・ノード、少なくとも1つのフロー・ノードを定義するイベント・ペアの順序付けされた外部システムに基づいて、統合フローのテンプレートを出力する、テンプレート出力コンポーネントと、を含む。
【0009】
実施形態は、また、カスタマイズされた統合フロー・テンプレートを提供するためのコンピュータ・プログラム製品を提供することができ、前記コンピュータ・プログラム製品は、その内部に実体化されたプログラム命令を有する少なくとも1つの非過渡的なコンピュータ可読な記録媒体を含み、前記プログラム命令が少なくとも1つのコンピュータ・プロセッサ回路による実行によって前記プロセッサ回路をして:統合システムに対する複数の外部システムとのユーザの相互作用をモニタして、前記外部システムにおけるデータ変化を読み出すこと;2つの前記外部システムにおいて同一のデータ変化イベントを有する2つの外部システムの間のそれぞれの少なくとも1つのイベント・ペアを識別すること;イベント・チェーンに含ませるための少なくとも1つのイベント・ペアをフィルタリングすること;前記データ変化イベントのタイムスタンプに基づいて前記イベント・チェーン内のフィルタされた前記イベント・ペアの前記外部システムを順序付けすること;及びフロー・トリガ及びフロー・ノード、少なくとも1つのフロー・ノードを定義するイベント・ペアの順序付けされた外部システムに基づいて、統合フローのテンプレートを出力することを実行させる。
【0010】
コンピュータ可読な記録媒体は、非過渡的なコンピュータ可読な記録媒体であり、コンピュータ可読なプログラム・コードは、プロセッシング回路により実行可能とすることができる。上記の要約は、それぞれに説明される実施形態、又は本開示のすべての実装を説明することを意図しない。
【0011】
本出願に含まれる図面は、明細書に含まれ、その部分を構成する。それらは、本開示の実施形態を説明し、明細書と共に本開示の原理の例示を提供する。図面は、一定の実施形態の例示のみであり、本開示を限定することはない。
【図面の簡単な説明】
【0012】
【
図1】
図1は、本開示の実施形態によるシステムの概略図である。
【
図2A】
図2Aは、図面に矛盾しない実施形態による方法の詳細を示すフロー図である。
【
図2B】
図2Bは、図面に矛盾しない実施形態による
図2に図示した方法のさらなる詳細を示すフロー図である。
【
図3】
図3は、図面に矛盾しない実施形態による方法の側面を示すフロー図である。
【
図4】
図4は、図面に矛盾しない実施形態によるシステムを示すブロック図である。
【
図5】
図5は、図面に矛盾しない実施形態による、本発明を実装することができるコンピュータ・システム、又はクラウド・サーバのブロック図である。
【
図6】
図6は、図面に矛盾しない実施形態による、本発明を実装することができるクラウド・コンピューティング環境の概略図である。
【
図7】
図7は、図面に矛盾しない実施形態による、本発明を実装することができるクラウド・コンピューティング環境の抽象モデル・レイヤの図である。
【発明を実施するための形態】
【0013】
説明の簡略化及び明確化のため、図に示された要素は、スケール通りに描画されている必要はないことについて理解されるであろう。例えば、要素のいくつかの寸法は、明確化のために他の要素に比較して誇張される可能性がある。さらに、適切と考えられる場合には、参照符号は、対応するか、又は類似の特徴を示すために複数の図面の間で繰り返すことがある。
【0014】
本発明は、種々の修正、代替的形態の余地があるが、その特徴は、図面において実施例の目的で示され、かつ詳細に説明されるであろう。
しかしながら、その意図は説明される特定の実施形態を限定することには無いことが理解されるべきである。対照的に、その意図は、本発明の精神及び範囲に収まるすべての修正、均等、及び代替を包含することにある。
【0015】
図面及び詳細な説明においては、同様の符号は、一般に同様のコンポーネント、部分、ステップ及びプロセスを参照する。
【0016】
システム及び方法は、統合製品のユーザのためのカスタマイズした統合フロー・テンプレートを提供することについて説明される。本方法は、一定の期間的期間の間に彼らの外部システムにおけるデータ変化に基づいて、ユーザのために仕立てられた統合テンプレートを提供する。システムは、これらの外部システムの間の情報フローを使用して、これらのタスクを自動化するために実装することができる有用な統合テンプレートを判断する。ユーザは、その後、このフローを彼ら自身のフローを構築するためのスタート・ポイントとして使用することができる。
【0017】
本方法は、多くの異なるシステムを通して流れるデータにおける相関を識別し、かつこれらの相関を使用して統合フローを生成する。これは、既存のテンプレートを通して検索させ、スクラッチからフローを構築すること、又は手作業の処理に頼り続けるのではなく、適切なスタート・ポイントとしての統合フロー・テンプレートを提供することにより、ユーザに資する。
【0018】
図1を参照すると、ブロック図は、ビジネス・アプリケーションと一体的な相互作用のためエンタープライズの多数のユーザ161-163のための統合製品を提供するエンタープライズのための、統合サーバ140を含むシステム100の実施例の実施形態を示す。ビジネス・アプリケーション121-123は、外部クラウド・サービス・システム111-113上のクラウド・サービスとして提供することができる。
クラウド・サービスは、ソフトウェア・アズ・ア・サービス(SaaS)として参照することができる。ビジネス・アプリケーション124は、また、非クラウドベースのコンピュータ・システム114上に、又はエンタープライズに対してリモートに提供することができる。ビジネス・アプリケーション121-124を提供するシステム111-114は、それらが統合システムに対して外部なので、外部システムとして参照される。
【0019】
統合サーバ140は、クラウド統合サービス130からのクラウド上で、完全に管理された統合プラットホームとして提供することができる。統合サーバ140は、ツールキットにより、エンタープライズ・クライアントへと提供されるパッケージ化された統合資産から配置することができる。統合サーバ140は、それ自身のコンテナを動作して、ワークロードの分離を保証し、かつエンタープライズ・クライアントがアプリケーションに、クライアントがそれらの統合ソリューションを配置することを可能とするためのランタイム、システム・ツール、及びライブラリの全部を含むソフトウェア開発のための標準的ユニットへと、その依存性のすべてをパッケージすることを許容することができる。
【0020】
エンタープライズ・クライアントは、ビジネス・アプリケーション121-124の間の統合フロー142を構築することができると共に、統合フロー142は、アプリケーション・プログラミング・インタフェース(API)動作として公開することができる。統合フロー142は、ソースと、ターゲットとの間のデータの自動化された移動を提供する。統合フロー・テンプレート132は、クラウド統合サービス130によって提供することができる。
【0021】
説明するシステムは、ビジネス・アプリケーション121-124と、ユーザ161-163との相互作用に基づき、エンタープライズ・クライアントのためのカスタマイズされた統合フロー・テンプレート151を提供する、統合サーバ140のためのテンプレート提供システム150を含む。テンプレート提供システム150と、統合サーバ140との間のリンクは、統合フロー・スキーマなので、それはその特有の統合サーバ140上で使用されることができるフロー・テンプレートを生成することができる。
【0022】
イベント125-128は、外部システム111-114にキャプチャされ、カスタム化された統合フロー・テンプレート151は、それぞれ、トリガ153及び少なくとも1つのノード154、155を含む、少なくとも1つのフロー152で生成することができる。ノードは、ターゲット・システムにおける対応するイベントをトリガする特定のアクションを表す。
【0023】
トリガ又はノードについて、情報の3つのキー・ピースが存在する。
1.それがどの外部システムを示すのか。
2.トリガのためにそれがどのイベントをキャプチャするのか、又はノードのためにそれがどのアクションを執るのか。
(例えば、<トリガのため>の、生成、アップデート・イベント、<アクションのための>削除、アップデート・アクション)
3.イベント又はアクションのためどれがターゲット・オブジェクトであるのか。
【0024】
ノードは、ターゲット・システム内の対応するイベントをトリガする特定のアクションを表す。例えば、イベントは、セールス・システム内で生成されたリードとすることができると共に、フローは、“セール生成リード”を有するであろう。
【0025】
図2Aを参照すると、フロー
図200は、テンプレート提供システム150で実行される説明する方法の実施例の実施形態を図示する。本方法は、クライアントの統合システム、又はクラウド統合サービス130を介して遠隔的に実行することができる。
【0026】
本方法は、201でユーザのアクセス・パーミッションを受領して、時間的期間の間、多数の外部システムからのデータ変更を読み出す。外部システムは、ビジネス・アプリケーションを動作しているローカル又はクラウド・サービス・システムを含む、統合システムの部分ではない如何なるシステムである。本方法は202で、定義された時間的期間にわたり、外部システムとユーザとの相互作用をモニタすることができる。モニタリング202は、エンタープライズ内でのユーザ又はユーザ・グループをモニタすることについてのユーザ・コンフィグレーションを基準としてアカウント毎とすることができる。
【0027】
モニタリングは、すでに発生したか、又は統合サーバが次に定義された時間的期間についてのデータ変化を聴取することを許容することにより、変化のセットを提供することを含む。これは、203で外部システムに発生したデータ変化イベントを収集する。
データ変化イベントは、変化したデータ値を有するそれぞれの外部システムにおける多数のフィールドを有することができる。
【0028】
一度データ変化イベントが収集されると、データ変化イベントは、カスタム化、又は仕立てられた統合フロー・テンプレートを判断するために使用される。
【0029】
これは、204で、データ変化イベントにおいて同一のデータ変化を有する外部システムのペアを識別することを含む。イベント・ペアを識別することは、それぞれのシステムのデータ変化イベントについて、イベントと、外部システムの残りのもののデータ変化イベントとを比較することによって実行することができる。2つのシステムは、それらが多数のデータ変化イベントの中で1対1のマッピングの関係を有する同一の値を含むフィールドを有する場合に、ペアとしてマークすることができる。同一の値を含むフィールドを、共通フィールドとして参照し、かつ同一の値を含むデータ変化イベントを、同一のデータ変化イベントとして参照する。共通フィールドは、2つのノードの間のマッピングとして使用される。
【0030】
識別されたイベント・ペアを処理することができる。205で、トリガ又はイベント・ノードとしてイベント・チェーン内にイベント・ペアを含ませるための定義された基準に基づいて、識別されたイベント・ペアについてフィルタを実行することができる。それぞれのイベント・ペアは、チェーン内のもう1つのペアと共通フィールドを有しなければならない。
【0031】
205で、フィルタリングは、イベント・ペア内の共通フィールド内の同一のデータ値の閾値数に基づくことができる。1つの外部システムの同一のデータ変化イベントの事前定義されたパーセンテイジがチェーン内の他のペアの全部をチェーン・アップするために使用することができる。これらの同一のデータ変化イベントは、トリガでのエンド・ポイント及び同一のデータ変化イベント・チェーンのラスト・ノードとして参照することができる。
【0032】
本方法の1つの利益は、それがマッピングを認識するため、フィールド名の如何なる類似性に依存しないことにある。フィールド名は、2つの外部システムの間で完全に異なり、かつそれらは、値のマッチングによってのみ識別される。これは、値がブーリアン又は数である場合には膨大な数のマッピングとなるであろうが、それらは事前設定されたマッチング率によってフィルタ・アウトされるであろう。
【0033】
さらに206で処理が実行されて、単一フローを発見すると共に、フロー中のループを除去することができる。これは、イベント・ペアの制限することを含むことができる:
-それぞれのペアは、外部システムの固有の組み合わせを有しなければならないこと;
-それぞれの外部システムは、最大で2つのペアとなるだけであること;及び
-これらがトリガ及びエンド・ノードを形成するので、すべてのイベント・ペア内で1度だけ出現する少なくとも2つの外部システムが存在しなければならないこと。
【0034】
破棄されたイベント・ペアは、少なくとも1つの可能性のある追加的なフロー・テンプレートについての後続する処理のために保存される。
【0035】
205のフィルタリング及び206の処理は、
図3に関連してさらに説明される、制約的なプログラミング、又は反復ロジックを使用して実行することができる。
【0036】
イベント・ペアの最終的なグループ内のそれぞれのイベント・ペアは、グループ内のもう1つのペアと共通フィールドを有しなければならない。システムのグループは、イベントのタイムスタンプに基づいて207で順序付けされるので、それらが時系列的なイベント・チェーンを規定する。これは、トリガ及び少なくとも1つのフロー・ノードを識別するため、タイムスタンプからどれがソースで、どれがターゲット・システムであるかを識別することを含むことができる。
【0037】
チェーン内での外部システムの順序付けが組織化されて、ファイナライズされたフローを生成する。同一のデータ変化イベントのそれぞれのエンド・ポイントについて、チェーン内のデータ変化を通して反復し、チェーン内のペアの位置づけを、多数の同一のデータ変化イベントのタイムスタンプを比較することによって順序付けして、ファイナライズされた統合テンプレートを生成する。
【0038】
2つの同一のデータ変化イベントは、もしもそれらが同一のデータ変化イベントの同一のセットを共有し、かつ一方がもう1つの外部システムの全部を含むのであれば、重複と考えられる。より短いチェーンを破棄することができるか、又は2つのチェーンが同一の長さである場合、ランダムに一方を廃棄することができる。
【0039】
208で、処理206によって破棄された如何なる未使用のイベント・ペアが存在するか否かを判断する。そうであれば、209で本方法をループさせることによってもう1つのフローのためにこれらを処理する。
【0040】
未使用のペアがもうなくなると、少なくとも1つの得られたフローを210でテンプレート統合フローとすることができるか、又は既存のテンプレート統合フローにマッチするために使用することができる。出力されたテンプレート統合フローは、始原的なユーザのコンテントと共に、他のユーザのためのテンプレートとして格納することができる。
【0041】
ユーザは、その後、確認すると共に、それらの環境についての統合フローを終了すると共に任意的にさらなるフローを適用する。
【0042】
図2Bを参照すると、フロー
図250は、テンプレート提供システム150で実行される説明する本方法の実施例の実施形態を示す。
【0043】
本方法は、251で開始することができると共に、252で、データ変化イベントを、多数の外部システムから収集することができる。
本方法は、253で同一のデータ変化イベントを共有するペアを識別することができる。
【0044】
254で、イベント・ペアが見出されるか否かを判断することができる。もしもイベント・ペアが見出されないのであれば、本方法は、260で終了する。もしもイベント・ペアが見出されたならば、255で、1つよりも多いイベント・ペアが見出されたか否かを判断する。そうであれば、本方法は、256で多数のイベント・ペアを使用して、同一のデータ変化イベントのチェーンを生成することができる。
【0045】
ただ1つだけのイベント・ペアが見出された場合において、本方法は、257で時間によってイベント・ペアにおける外部システムを順序付けて、統合テンプレートを生成することができる。多数のイベント・ペアが見出され、かつイベント・チェーンにグループされる場合において、本方法は257で、時間によってチェーン内の外部システムを順序付け、統合フロー・テンプレートを生成することができる。
【0046】
258で、以前の統合フロー・テンプレートの生成において破棄されたいずれかの未利用のイベント・ペアが存在するか否かを判断することができる。もしそうであれば、256で本方法をループさせることによって、もう1つの統合フロー・テンプレートを生成するために処理がなされる。もしも未使用のイベント・ペアが無いのであれば、本方法は、259で全部の統合フロー・テンプレートを出力することができる。本方法は、その後、260で終了する。
【0047】
図3を参照すると、フロー
図300は、イベント・チェーン内に含ませるための識別されたイベント・ペアをフィルタリングする205の
図2Aの方法の側面の実施例の実施形態を示す。
【0048】
本方法は、301で外部システムのペアの間の識別されたイベント・ペアを受領する。イベント・ペアは、302で、すべてが1つの同一の外部システムを含むイベント・ペアに制限することができる。
【0049】
イベント・ペアは、共通フィールドについて外部システムのペア内でチェックされると共に、データ変化の同一の値を有する共通フィールドの最高の数を有するイベント・ペアが303で選択され、かつこれらの値が参照値として使用される。
【0050】
それぞれの他のイベント・ペア内の参照値の数を見出すために、他のイベント・ペアが304で検索される。イベント・ペアは、もしも参照値の閾値数に一致しないのであれば破棄される。これは、同一のデータ変化イベントを、他のペアと比較して、最高の同一のデータ変化イベントがマッチする最もマッチする1つを見出すことによって実行することができる。ロジックは、もしも事前設定されたパーセンテイジを有するペアが見出されないのであれば、停止することができる。これは、選択されたペアの間で新たな共有された同一のデータ変化イベントについて反復することができる。
【0051】
残りのフィルタされたイベント・ペアは、305で処理に提供されて、単一フローを発見すると共に、
図2Aのステップ206で説明したように如何なるループでも削除する。
【0052】
分析の後、出力は、ユーザに対して彼らの詳細な統合を構築するためのスタート・ポイントとして使用することができる、多数の例示フローを提示する。もしもユーザのシステムを通して不十分なデータが通過した場合、データ・イベントのマッチングが全く見出されなかった可能性があり、かつしたがってユーザに対して全く例示フローが提示されないであろう。
【0053】
実施例の実施形態は、本方法の例示のために説明された。実施例においては、ビジネス・アプリケーション121-123は、セールス及びマーケッティング・クラウド・サービス、電子メール・クラウド・サービス、ソーシャル・メディア・サービス、スプレッドシート・アプリケーション、及びすべてが外部システムにおいて統合サーバへと提供されたAPIを含む。
【0054】
実施例1
【0055】
外部システムにおいては、イベントのみがキャプチャされる。
例えば:
・10:00 メッセージが、ソーシャル・メディア・システムにおいて受領される。
名:ジョン
姓:ドー
電子メール・アドレス:jd@company.com、送信時間:9:59)
・10:01 セールス・システムにおいてリードが生成される
名:ジョン
姓:ドー
コンタクト:jd@company.com、生成日:10:01)
・12:00 電子メールが電子メール・システムで送付される。
電子メール:jd@company.com、送付:12:00)
【0056】
この単一の値変化イベントについて、上述したイベントに基づき、本方法は、3つのシステムがマッピング・フィールドに関連すると判断する。
・ソーシャル・メディア.名<->セールス.名
・ソーシャル・メディア.姓<->セールス.姓
・ソーシャル・メディア.電子メール・アドレス<->セールス.コンタクト<->電子メール.電子メール
【0057】
したがって、ソーシャル・メディア・システム及びセールス・システムは、3つの共通フィールドを有し、ソーシャル・メディア・システム及び電子メール・システムは、1つの共通フィールドを有し、セールス・システム及び電子メール・システムは1つの共通フィールドを有する。
【0058】
もしも他の値変化イベントが存在するものと想定するならば、それらは、すべて同一の値を有するが、電子メール・システムは幾らかのノイズを有した。ソーシャル・メディア・システムは、セールス・システムの10イベントと100%マッチングする10のイベントを有する。電子メール・システムは、15イベントを有し、5イベントは、他の2つのシステムにおけると同一の値変化を有しない。
【0059】
もしも、マッチングの閾値を80%を超えるように設定するのであれば、電子メール・システムは、マッチング率が10/15=66.67%なので、考慮されないであろう。テンプレートのため、2つのシステム・イベントが存在するであろう。セールス・システムはリードを生成し<->ソーシャル・メディアがメッセージを受領した
【0060】
その後、本方法は、これらの10イベントを注視し、もしもセールス・イベントの前にソーシャル・メディア・イベントの全部が発生したのであれば、システムは、再順位付けして、以下のフローを生成する。(トリガ)ソーシャル・メディア・システムがメッセージを受領した--->(アクション)セールス・システムがソーシャル・メディア名からの値を使用して名、ソーシャル・メディア姓からの値を使用して姓を使用してリードを生成し、そしてソーシャル・メディアの電子メール・アドレスからの値を使用してコンタクトした。
【0061】
実施例2
【0062】
実施例のユース・ケースは、以下の様に説明される。
ユーザは、毎日10amに以下のタスクを実行する(ユーザ・ルーチン1として参照する。)
1.共有スプレッドシートに如何なる新たなカスタマーが追加されたか否かをチェックする。
2.外部マーケッティング及びセールス・システムにどのシステムを先ずランダムの順序で新たなカスタマーのためのコンタクトを追加する。
3.ステップ2の全部のアクションが完了したらすぐに、これらのコンタクトへとウェルカム電子メールを送付する。
【0063】
もう1人のユーザは、1日の間、規則的に以下のタスクを実行する(ユーザ・ルーチング2として参照する。):
1.外部マーケッティング・システムにおける新たなリードをチェックする。
2.新たなカスタマーのため、製品を提供するためのAPIシステムを呼び出す。
3.ステップ2が完了した後、もう1つの電子メールをカスタマーに送付する。
【0064】
説明する方法は、2つのユーザ・タスクを実行するために要求されるすべてのシステムにアクセスを有する2つのテンプレートを生成するために使用することができる。
【0065】
システム1のイベントA及びシステム2のイベントBは、システム1のイベントAにおけるフィールドXが、システム2のイベントBにおけるフィールドYの値を有しているので、イベント・ペアである。2つのペアをリンクするチェーンを構築するためには(4システム)、他の2つのシステムは、システム3のイベントC及びシステム4のイベントDにおいてそれぞれフィールドZ及びフィールドWを有しなければならない。
【0066】
先ず、2つのペアは、もしもそれらが同一の外部システムのイベントを共有していなければ、互いにチェックされないであろう。
【0067】
例えば:
ペアAB->スプレッドシートの行-セールス・リード
ペアBC->セールス・リード-電子メール
ペアCD->電子メール・メール-APIリード
ペアBD->セールス・リード-APIリード
【0068】
ペアAB、BC及びBDは、それらがすべてB(セールス・リード)を有するためチェックされ、CDは破棄されるであろう。
【0069】
イベントA(システム1から)及びイベントB(システム2から)の両方が、同一の値が変化した8フィールドを有するものとすると、それは8つの共通フィールド(ABペア)を有することになる。他のペアについては:10フィールドは、3つの共通フィールドで変化し(BCペア)、4フィールドは、4つの共通フィールドで変化した(BDペア)。ABペア内の共通フィールドの数が最高なので、スタート・ペアとして選択されるであろう。
【0070】
BCペアの変化イベント内のABペアから識別された8つの共通フィールドの同一の値について検索される。事前設定されたパーセンテイジ閾値は=80%に設定される。BCペア内の3つの共通フィールドは、ABペアの8つの共通ペアにおける3つのフィールドであり、かつそれらの3つの共通フィールド内の値の変化は、100%マッチングすることが見出される。したがって、ABペアによってチェーン・リード内が記録されるであろう(AB<->BC)
【0071】
BDペアについて、ABペア内の共通フィールドの1つとのマッチングする60%の同一値を有するだけの1フィールドがBDの共通フィールドから見出される。
したがって、BDは、チェーン内とはされないであろう。
【0072】
実施例のユーザ・ルーチン1およびユーザ・ルーチン2を使用し、以下のペアが見出される。
スプレッドシート・システム<->マーケッティング・システム
マーケッティング・システム<->電子メール・システム
セールス・システム<->電子メール・システム
スプレッドシート・システム<->セールス・システム
マーケッティング・システム<->セールス・システム
マーケッティング・システム<->APIシステム
APIシステム<->電子メール・システム
【0073】
以下のものは、単一のデータ・フロー及びルールアウト・ループを見出すための基準のセットの実施例である:
それぞれのペアは、外部システムの固有の組み合わせを有しなければならない;
それぞれの外部システムは、最大での2つのペアにのみ存在することができる;及び
すべてのペア内に一度だけ出現する少なくとも2つの外部システムが存在するべきである。
【0074】
もしも例えばペアAB、BC、CD、DB及びDEが存在するものとする:それぞれのペアは、外部システムの固有の組み合わせを有し、A及びEは、すべてのペア内に1度だけ出現する。しかしながら、BC->CD->DBは、ループである。この実施例においては、B及びDの両方は、2つのペアよりも出現する。良好な制約アルゴリズムで、DBは、それぞれの外部システムが最大で2つのペアにおいてのみ存在することができるという要求にしたがって、識別され、かつ除去されるであろう。このことは、本実施例のBDはチェーンではなく同一の値変化についての80%のマッチング基準に適合しないという、制約の実施例の使用として提供される。
【0075】
本方法は、アクションのノードが1つの下流ノードよりも多い可能性があるフローを生成することを目的としない。言い換えれば、BC及びBDのうちの1つは、第1のフロー・テンプレートを形成する場合に削除され、かつ削除されたペアは、第2のフロー・テンプレートとなるであろう。すなわち、結果は、フロー1:AB->BCプラスフロー2:BDとなるであろう。
【0076】
それは、第1の反復において第1のフローを見出すことができる。上記にリストした制約に基づいた削除の多数の方法が存在する可能性がある。ペアの最高の数を有するもの、最高の数の中で引き分けがある場合には、ランダムに1つが選択される。
スプレッドシート・システム<->マーケッティング・システム
マーケッティング・システム<->電子メール・システム(削除)
セールス・システム<->電子メール・システム
スプレッドシート・システム<->セールス・システム(削除)
マーケッティング・システム<->セールス・システム
マーケッティング・システム<->APIシステム(削除)
APIシステム<->電子メール・システム(削除)
【0077】
第1の反復において残されたデータ変化について:
マーケッティング・システム<->電子メール・システム
スプレッドシート・システム<->セールス・システム
マーケッティング・システム<->APIシステム
APIシステム<->電子メール・システム
【0078】
もう1つのフローが発見される:
マーケッティング・システム<->電子メール・システム(削除)
スプレッドシート・システム<->セールス・システム(削除)
マーケッティング・システム<->APIシステム
APIシステム<->電子メール・システム
【0079】
しかしながら、実際のユース・ケースにおいては、同様に異なるフローが存在する可能性があるであろう。
スプレッドシート・システム<->マーケッティング・システム
マーケッティング・システム<->電子メール・システム(削除)
セールス・システム<->電子メール・システム(削除)
スプレッドシート・システム<->セールス・システム(削除)
マーケッティング・システム<->セールス・システム(削除)
マーケッティング・システム<->APIシステム
APIシステム<->電子メール・システム
【0080】
及び
マーケッティング・システム<->電子メール・システム(削除)
セールス・システム<->電子メール・システム
スプレッドシート・システム<->セールス・システム
マーケッティング・システム<->セールス・システム(削除)
【0081】
それぞれの同一のイベント変化チェーンについて、システムは、システムによるこれらの変化のタイムスタンプを収集するであろう。例えば、電子メールbob@company.comを有するデータ・エントリについての変化イベントは、セールス、マーケッティング及び電子メール・サービスに追加される。
bob@company.com:12:10-セールス、12:11-電子メール、10:10-マーケッティング
fred@company.com:12:10-セールス、12:09-電子メール、7:00-マーケッティング
jane@company.com:12:11-セールス、12:10-電子メール、5:00-マーケッティング
【0082】
したがって、もしもすべてのイベントが、時間についてと同じ順序であるならば、フロー・テンプレート内のシステムは、再順序付けされる。例えば、上記に共有した実施例のイベントのためのフローを構成するために、テンプレートは、セールス及び電子メールの前に順序付けされたマーケッティング・システムを有しなければならない。セールス及び電子メールの順番は、重要ではない。
【0083】
図4を参照すると、ブロック図は、コンピュータ・システムに提供されたテンプレート提供システム150の実施例の実施形態を図示しており、このコンピュータ・システムは、少なくとも1つのプロセッサ回路上で実行するソフトウェア・ユニットとすることができる、説明したコンポーネントの機能を実行するための少なくとも1つのプロセッサ回路401、ハードウェア・モジュール又は回路を含む。並列的な処理スレッドを動作させる多数のプロセッサ回路は、コンポーネントのいくつか、又は全部の機能を並列処理することを可能とするために提供することができる。メモリ402は、コンポーネントの機能を実行するために少なくとも1つのプロセッサ回路401へと、コンピュータ命令403を提供するように構成することができる。
【0084】
テンプレート提供システム150は、
図1を参照して説明したように、統合フロー142を提供するための統合サーバ140とインタフェースする。
【0085】
テンプレート提供システム150は、説明した方法の機能を提供するコンポーネントを含む。テンプレート提供システム150は、時間的期間にわたる外部システムでのデータ変化イベントに関連するデータを収集するためにユーザ・パーミッションを受領するユーザ・アクセス・コンポーネント451、外部システムをモニタするための外部システム・モニタリング・コンポーネント452、及びデータを収集するためのデータ変化イベント・コンポーネント453を含む。
【0086】
テンプレート提供システム150は、データ変化イベントにおいて同一のデータ値変化を有する外部システムのペアを識別するためのイベント・ペア識別コンポーネント454、事前定義された基準に基づいてイベント・ペアをフィルタするためのフィルタリング・コンポーネント456を含むチェーン生成コンポーネント455、及びイベント・チェーン内でシステムを順序付けするための順序付けコンポーネント457を含む。
【0087】
テンプレート提供システム150は、カスタマイズされた統合フロー・テンプレート152としてのチェーンを出力するための、テンプレート出力コンポーネント458を含むことができる。テンプレート提供システム150は、また、若しくは代替的に、既存のテンプレート統合フローにマッチングするために収集されたイベント・チェーンを使用するためのテンプレート・マッチング・コンポーネント459を含むことができる。
【0088】
図5は、本発明の実施形態による、
図1~4の統合サーバ140及びテンプレート提供システム150を提供するためのコンポーネントのブロック図を示す。
図5は、1つの実施形態の例示のみを提供し、異なる実施形態が実装可能な環境に関連して如何なる限定を意味しないことについて理解されるべきである。図示した環境に対する多くの修正が可能である。
【0089】
コンピューティング・システムは、少なくとも1つのプロセッサ回路502、少なくとも1つのコンピュータ可読なRAMs504、少なくとも1つのコンピュータ可読なROM506、少なくとも1つのコンピュータ可読な記録媒体508、デバイス・ドライバ512、リード/ライト・ドライブ又はインタフェース514、及び通信アダプタ又はインタフェース516を含むことができ、すべてが通信機能518越しに相互接続される。通信機能518は、プロセッサ回路(マイクロプロセッサ、通信及びネットワーク・プロセッサといった)の間でデータ、又は制御情報、又はそれらの両方を渡すために設定された如何なるアーキテクチャで実装することができる。
【0090】
少なくとも1つのオペレーティング・システム510及びテンプレート提供システ150といったアプリケーション・プログラム511は、少なくとも1つのそれぞれのRAMs504(典型的にはキャッシュ・メモリを含む。)を介した少なくとも1つのプロセッサ回路502による実行のための、少なくとも1つのコンピュータ可読な記録媒体508に格納される。例示する実施形態においては、それぞれのコンピュータ可読な記録媒体508は、本発明の実施形態によるコンピュータ・プログラム及びデジタル情報を格納可能な、内部ハードドライブ、CD-ROM、DVD、メモリ・スティック、磁気テープ、磁気ディスク、光学ディスク、RAM、ROM、EPROM、フラッシュ・メモリ、といった半導体記録デバイス、又は如何なる他のコンピュータ可読な記録媒体とすることができる。
【0091】
コンピューティング・システムは、また、少なくとも1つの携行可能なコンピュータ可読な記録媒体526との間で読み出し及び書き込みするための、R/Wドライブ又はインタフェース514を含むことができる。コンピューティング・システム上のアプリケーション・プログラム511は、少なくとも1つの携行可能なコンピュータ可読な記録媒体526に格納することができ、それぞれのR/Wドライブ又はインタフェース514を介して読み出すことができ、かつそれぞれのコンピュータ可読な記録媒体508内にロードされることができる。
【0092】
コンピューティング・システムは、また、TCP/IPアダプタ・カード又はワイヤレス通信アダプタといった、ネットワーク・アダプタ又はインタフェース516を含むことができる。コンピューティング・システム上のアプリケーション・プログラム511は、外部コンピュータ、又は外部ストレージ・デバイスから、ネットワーク(例えば、インターネット、ローカル・エリア・ネットワーク、又は他のワイド・エリア・ネットワーク、又はワイヤレス・ネットワーク)及びネットワーク・アダプタ516を介してダウンロードすることができる。ネットワーク・アダプタ又はインタフェース516から、プログラムは、コンピュータ可読な記録媒体508内にロードすることができる。ネットワークは、銅ワイヤ、光ファイバ、ワイヤレス通信、ルータ、ファイア・ウォール、スイッチ、ゲートウェイ・コンピュータ及びエッジ・サーバを含むことができる。
【0093】
コンピューティング・システムは、また、ディスプレイ・スクリーン520、キーボード又はキーパッド522、及びコンピュータ・マウス又はタッチパッド524を含むことができる。デバイス・ドライバ512は、イメージングのためのディスプレイ・スクリーン520、キーボード又はキーパッド522、コンピュータ・マウス又はタッチパッド524、又は英数字のキャラクタの入力及びユーザ選択を圧力検出するためのディスプレイ・スクリーン520、又はこれらの組み合わせへとインタフェースする。デバイス・ドライバ512、R/Wドライブ又はインタフェース514及びネットワーク・アダプタ又はインタフェース516は、コンピュータ可読な記録媒体508、又はROM506、又はこれら両方に格納されたハードウェア及びソフトウェアを含むことができる。
【0094】
本発明は、いかなる可能な技術的に詳細な一体化レベルであっても、システム、方法、又はコンピュータ・プログラム製品、又はこれらの組み合わせとすることができる。コンピュータ・プログラム製品は、プロセッサに対して本発明の特徴を遂行させるためのコンピュータ可読なプログラム命令をそれ上に有する記録媒体(又は複数の媒体)を含むことができる。
【0095】
コンピュータ可読な記録媒体は、命令実行デバイスが使用するための複数の命令を保持し格納することができる有形のデバイスとすることができる。コンピュータ可読な媒体は、例えば、これらに限定されないが、電気的記録デバイス、磁気的記録デバイス、光学的記録デバイス、電気磁気的記録デバイス、半導体記録デバイス又はこれらのいかなる好ましい組み合わせとすることができる。コンピュータ可読な記録媒体の限定的ではない実施例は、次のポータブル・コンピュータ・ディスク、ハードディスク、ランダム・アクセス・メモリ(RAM)、リード・オンリー・メモリ(ROM)、消去可能なプログラマブル・リード・オンリー・メモリ(EPROM又はフラッシュ・メモリ(登録商標))、スタティック・ランダム・アクセス・メモリ(SRAM)、ポータブル・コンパクト・ディスク・リード・イオンリー・メモリ(CD-ROM)、デジタル多目的ディスク(DVD)、メモリ・スティック、フロッピー・ディスク(登録商標)、パンチ・カード又は命令を記録した溝内に突出する構造を有する機械的にエンコードされたデバイス、及びこれらの好ましい如何なる組合せを含む。本明細書で使用するように、コンピュータ可読な記録媒体は、ラジオ波又は他の自由に伝搬する電磁波、導波路又は他の通信媒体(例えば、光ファイバ・ケーブルを通過する光パルス)といった電磁波、又はワイヤを通して通信される電気信号といったそれ自体が一時的な信号として解釈されることはない。
【0096】
本明細書において説明されるコンピュータ・プログラムは、コンピュータ可読な記録媒体からそれぞれのコンピューティング/プロセッシング・デバイスにダウンロードでき、又は例えばインターネット、ローカル・エリア・ネットワーク、ワイド・エリア・ネットワーク又はワイヤレス・ネットワーク及びそれからの組み合わせといったネットワークを介して外部コンピュータ又は外部記録デバイスにダウンロードすることができる。ネットワークは、銅通信ケーブル、光通信ファイバ、ワイヤレス通信、ルータ、ファイア・ウォール、スイッチ、ゲートウェイ・コンピュータ及びエッジ・サーバ又はこれらの組み合わせを含むことができる。それぞれのコンピューティング/プロセッシング・デバイスにおけるネットワーク・アダプタ・カード又はネットワーク・インタフェースは、ネットワークからコンピュータ可読なプログラム命令を受領し、このコンピュータ可読なプログラム命令を格納するためにそれぞれのコンピューティング/プロセッシング・デバイス内のコンピュータ可読な記録媒体内に転送する。
【0097】
本発明の操作を遂行するためのコンピュータ可読なプログラム命令は、アセンブラ命令、命令セット・アーキテクチャ(ISA)命令、機械語命令、マシン依存命令、マイクロ・コード、ファームウェア命令、状態設定データ、集積回路のための構成データ、又は1つ又はそれ以上の、Smalltalk(登録商標)、C++などのオブジェクト指向プログラミング言語、“C”プログラミング言語又は類似のプログラム言語といった手続き型プログラミング言語を含むプログラミング言語のいかなる組合せにおいて記述されたソース・コード又はオブジェクト・コードのいずれかとすることができる。コンピュータ可読なプログラム命令は、全体がユーザ・コンピュータ上で、部分的にユーザ・コンピュータ上でスタンドアローン・ソフトウェア・パッケージとして、部分的にユーザ・コンピュータ上で、かつ部分的にリモート・コンピュータ上で、又は全体がリモート・コンピュータ又はサーバ上で実行することができる。後者のシナリオにおいて、リモート・コンピュータは、ローカル・エリア・ネットワーク(LAN)、ワイド・エリア・ネットワーク(WAN)を含むいかなるタイプのネットワークを通してユーザ・コンピュータに接続することができ、又は接続は、外部コンピュータ(例えばインターネット・サービス・プロバイダを通じて)へと行うことができる。いくつかの実施形態では、例えばプログラマブル論理回路、フィールド・プログラマブル・ゲートアレイ(FPGA)、又はプログラマブル論理アレイ(PLA)を含む電気回路がコンピュータ可読なプログラム命令を、コンピュータ可読なプログラム命令の状態情報を使用して、本発明の特徴を実行するために電気回路をパーソナライズして実行することができる。
【0098】
本明細書で説明した本発明の側面を、本発明の実施形態にしたがい、フローチャート命令及び方法のブロック図、又はそれらの両方、装置(システム)、及びコンピュータ可読な記録媒体及びコンピュータ・プログラムを参照して説明した。フローチャートの図示及びブロック図又はそれら両方及びフローチャートの図示におけるブロック及びブロック図、又はそれらの両方のいかなる組合せでもコンピュータ可読なプログラム命令により実装することができることを理解されたい。
【0099】
これらのコンピュータ可読なプログラム命令は、汎用目的のコンピュータ、特定目的のコンピュータ、または他のプロセッサ又は機械を生成するための他のプログラマブル・データ・プロセッシング装置に提供することができ、コンピュータのプロセッサ又は他のプログラマブル・データ・プロセッシング装置による実行がフローチャート及びブロック図のブロック又は複数のブロック又はこれらの組み合わせで特定される機能/動作を実装するための手段を生成する。コンピュータ、プログラマブル・データ・プロセッシング装置及び他の装置又はこれらの組み合わせが特定の仕方で機能するように指令するこれらのコンピュータ可読なプログラム命令は、またコンピュータ可読な記録媒体に格納することができ、その内に命令を格納したコンピュータ可読な記録媒体は、フローチャート及びブロック図のブロック又は複数のブロック又はこれらの組み合わせで特定される機能/動作の特徴を実装する命令を含む製造品を構成する。
【0100】
コンピュータ可読なプログラム命令は、またコンピュータ、他のプログラマブル・データ・プロセッシング装置、又は他のデバイス上にロードされ、コンピュータ、他のプログラマブル装置、又は他のデバイス上で操作ステップのシリーズに対してコンピュータ実装プロセスを生じさせることで、コンピュータ、他のプログラマブル装置又は他のデバイス上でフローチャート及びブロック図のブロック又は複数のブロック又はこれらの組み合わせで特定される機能/動作を実装させる。図のフローチャート及びブロック図は、本発明の種々の実施形態にしたがったシステム、方法及びコンピュータ・プログラムのアーキテクチャ、機能、及び可能な実装操作を示す。この観点において、フローチャート又はブロック図は、モジュール、セグメント又は命令の部分を表すことかでき、これらは、特定の論理的機能(又は複数の機能)を実装するための1つ又はそれ以上の実行可能な命令を含む。いくつかの代替的な実装においては、ブロックにおいて記述された機能は、図示した以外で実行することができる。例えば、連続して示された2つのブロックは、含まれる機能に応じて、実際上1つのステップとして遂行され、同時的、実質的に同時的に、部分的又は完全に一時的に重ね合わされた仕方で実行することができ、又は複数のブロックは、時として逆の順番で実行することができる。またブロック図及びフローチャートの図示、又はこれらの両方及びブロック図中のブロック及びフローチャートの図示又はこれらの組み合わせは、特定の機能又は動作を実行するか又は特定の目的のハードウェア及びコンピュータ命令を遂行する特定目的のハードウェアに基づいたシステムにより実装することができることを指摘する。
【0101】
クラウド・コンピューティング
【0102】
本開示は、クラウド・コンピューティングについての詳細を含むが、本明細書内で参照した教示は、クラウド・コンピューティング環境に限定されることはない。むしろ、本開示の環境は、現在知られ、又は将来開発される他の如何なるタイプのコンピューティング環境との組み合わせにおいても実装することができる。
【0103】
クラウド・コンピューティングは、最小限の管理労力又はサービス提供者との交流をもって、迅速に提供及び開放構成可能なコンピューティング資源(例えば、ネットワーク、ネットワーク帯域幅、サーバ、処理、メモリ、ストレージ、アプリケーション、仮想マシン及びサービス)の共用されるプールにアクセスするための利便性のある、オンデマンドのネットワークアクセスのためのサービス提供のモデルである。このクラウド・モデルは、少なくとも5つの特徴、少なくとも3つのサービスモデル、及び少なくとも4つの配置モデルを含むことができる。
【0104】
特徴は以下のとおりである:
オンデマンド・セルフサービス:クラウドのコンシューマは、サーバ時間、及びネットワーク・ストレージといったコンピューティング能力を、サービスの提供者との人間的交流を必要とすることなく必要なだけ自動的に一方向的に提供される。
広範なネットワークアクセス:能力は、ネットワーク上で利用可能であり、かつ異なったシン又はシッククライアント・プラットフォーム(例えば、モバイルホン、ラップトップ及びPDA)による利用を促す標準的な機構を通してアクセスされる。
リソースの共用:提供者のコンピューティング資源は、マルチテナント・モデルを使用し、動的に割当てられる必要に応じて再割り当てられる異なった物理的及び仮想化資源と共に多数の消費者に提供するべく共用される。
コンシューマは概ね提供される資源の正確な位置(例えば、国、州、又はデータセンタ)に関する制御又は知識を有さず、抽象化の高度の階層において位置を特定することができるというように、位置非依存の感覚が存在する。
迅速な弾力性:機能は、迅速かつ弾力的に、場合によっては自動的に供給され素早くスケールアウトし、迅速に解放して素早くスケールインすることが可能である。
コンシューマにとっては、供給のために利用可能な機能は、多くの場合、制限がないように見え、いつでも任意の量で購入することができる。
計測されるサービス:クラウド・システムは、サービスの種類(例えば、ストレージ、処理、帯域幅、及びアクティブ・ユーザ・アカウント)に適したいくつかの抽象化レベルで計量機能を活用することによって、リソースの使用を自動的に制御し、最適化する。
リソース使用量を監視し、制御し、報告することで、使用されているサービスのプロバイダ及びコンシューマの両方に対して透明性を提供することができる。
【0105】
サービスモデルは、以下のとおりである:
ソフトウェア・アズ・ア・サービス(SaaS):コンシューマに提供される機能は、クラウド・インフラストラクチャ上で実行されるプロバイダのアプリケーションを使用することである。
アプリケーションは、ウェブ・ブラウザ(例えば、ウェブベースの電子メール)のようなシン・クライアント・インターフェースを通じて、種々のクライアント・デバイスからアクセス可能である。
コンシューマは、限定されたユーザ固有のアプリケーション構成設定を除いて、ネットワーク、サーバ、オペレーティング・システム、ストレージ、又は個々のアプリケーションの機能も含む、基盤となるクラウド・インフラストラクチャを管理又は制御することはない。
プラットフォーム・アズ・ア・サービス(PaaS):コンシューマに提供される能力は、プロバイダがサポートするプログラミング言語及びツールを用いて作成された、コンシューマが作成又は獲得したアプリケーションを、クラウド・インフラストラクチャ上に配置することである。
コンシューマは、ネットワーク、サーバ、オペレーティング・システム、又はストレージを含む、基盤となるクラウド・インフラストラクチャを管理又は制御することはないが、配置されたアプリケーションを制御し、可能であればアプリケーション・ホスティング環境の構成を制御する。
インフラストラクチャ・アズ・ア・サービス(IaaS):コンシューマに提供される機能は、処理、ストレージ、ネットワーク、及びその他の基本的なコンピューティング・リソースの提供であり、コンシューマは、オペレーティング・システム及びアプリケーションを含むことができる任意のソフトウェアを配置し、実行させることが可能である。
コンシューマは、基盤となるクラウド・インフラストラクチャを管理又は制御することはないが、オペレーティング・システム、ストレージ、配置されたアプリケーションの制御を有し、可能であれば選択ネットワーキング・コンポーネント(例えば、ホストのファイア・ウォール)の限定的な制御を有する。
【0106】
配置モデルは、以下の通りである:
プライベート・クラウド:クラウド・インフラストラクチャは、1つの組織のためだけに動作する。これは、その組織又は第三者によって管理することができオン・プレミス又はオフ・プレミスで存在することができる。
コミュニティ・クラウド:クラウド・インフラストラクチャは、いくつかの組織によって共有され、共通の利害関係(例えば、任務、セキュリティ要件、ポリシー、及びコンプライアンスの考慮事項)を有する特定のコミュニティをサポートする。これは、それらの組織又は第三者によって管理することができ、オン・プレミス又はオフ・プレミスに存在することができる。
パブリック・クラウド:クラウド・インフラストラクチャは、公衆又は大きな産業グループが利用可能できるようにされており、クラウド・サービスを販売する組織によって所有される。
ハイブリッド・クラウド:クラウド・インフラストラクチャは、2つ又はそれより多いクラウド(プライベート、コミュニティ、又はパブリック)を組み合わせたものであり、これらのクラウドは、固有のエンティティのままであるが、データ及びアプリケーションのポータビリティを可能にする標準化技術又は専有技術によって互いに結合される(例えば、クラウド間の負荷バランスのためのクラウド・バースティング)。
【0107】
クラウド・コンピューティング環境は、無国籍性、粗結合性、モジュール性、及び意味的相互運用性に焦点を合わせたサービス指向のものである。クラウド・コンピューティングの心臓部において、相互接続された複数のノードを含むものがインフラストラクチャである。
【0108】
図6は、例示的なクラウド・コンピューティング環境50を示す。
図示するように、クラウド・コンピューティング環境50は、1つ又はそれ以上のクラウド・コンピューティング・ノード10を含み、それらと共にクラウド・コンシューマにより使用される例えばパーソナル・デジタル・アシスタント(PDA)又はセルラ電話54A、デスクトップ・コンピュータ54B、ラップトップ・コンピュータ54C、又は自動車コンピュータ・システム54N又はこれらの組合せといったローカル・コンピューティング・デバイスが通信する。ノード10は、互いに通信することができる。
これらは、上述したプライベート、コミュニティ、パブリック、又はハイブリッド・クラウド、又はそれらの組合せといった、1つ又はそれ以上のネットワーク内で、物理的又は仮想的にグループ化することができる(不図示)。これは、クラウド・コンピューティング環境50が、クラウド・コンシューマがローカルなコンピューティング・デバイス上のリソースを維持する必要を無くするための、インフラストラクチャ、プラットホーム、又はソフトウェア・アズ・ア・サービスを提供することを可能とする。
図6に示すコンピューティング・デバイス54A-Nのタイプは、例示を意図するためのみのものであり、コンピューティング・ノード10及びクラウド・コンピューティング環境50は、任意のタイプのネットワーク又はアドレス可能なネットワーク接続(例えばウェブ・ブラウザを使用して)、又はそれらの両方を通じて、いかなるタイプのコンピュータ化デバイスとも通信することができることが理解される。
【0109】
ここで、
図7参照すると、クラウド・コンピューティング環境50(
図6)により提供される機能的抽象レイヤのセットが示される。予め、
図7に示したコンポーネント、レイヤ、及び機能は、例示することのみを意図したものであり、本発明の実施形態は、これらに限定されることは無いことは理解されるべきである。図示したように、後述するレイヤ及び対応する機能が提供される。
【0110】
ハードウェア及びソフトウェアレイヤ60は、ハードウェア及びソフトウェア・コンポーネントを含む。ハードウェア・コンポーネントの例としては、メインフレーム61;RISC(縮小命令セットコンピュータ)アーキテクチャに基づく複数のサーバ62;複数のサーバ63;複数のブレード・サーバ64;複数のストレージ・デバイス65;及びネットワーク及びネットワーキング・コンポーネント66を含むことができる。いくつかの実施形態ではソフトウェア・コンポーネントは、ネットワーク・アプリケーション・サーバ・ソフトウェア67及びデータベース・ソフトウェア68を含む。
【0111】
可視化レイヤ70は、それから後述する仮想エンティティの実施例が提供される抽象レイヤ;仮想サーバ71;仮想ストレージ72;仮想プライベート・ネットワークを含む仮想ネットワーク73;仮想アプリケーション及びオペレーティング・システム74;及び仮想クライアント75を提供する。
【0112】
1つの実施例では、マネージメント・レイヤ80は、下記の機能を提供することができる。リソース提供部81は、コンピューティング資源及びクラウド・コンピューティング環境内でタスクを遂行するために用いられる他の資源の動的獲得を提供する。計測及び価格設定部82は、クラウド・コンピューティング環境内で資源が使用されるとコストの追跡を提供すると共に、これらの資源の消費に対する課金又は請求を提供する。1つの実施例では、これら資源としてはアプリケーション・ソフトウェア・ライセンスを含むことができる。セキュリティ部は、クラウド・コンシューマ及びタスクの同定及び認証と共にデータ及び他の資源の保護を提供する。ユーザ・ポータル部83は、コンシューマに対するクラウド・コンピューティング環境及びシステム・アドミニストレータへのアクセス性を提供する。サービスレベル・マネージメント部84は、クラウド・コンピューティング資源の割り当て及び管理を提供し、必要なサービス・レベルに適合させる。サービス・レベル・アグリーメント(SLA)プランニング・フルフィルメント部85は、SLAにしたがって将来的な要求が要求されるクラウド・コンピューティング資源の事前準備を行うと共にその獲得を行う。
【0113】
ワークロード・レイヤ90は、クラウド・コンピューティング環境を利用するための機能の例示を提供する。このレイヤによって提供されるワークロード及び機能の例としては、マッピング及びナビゲーション91;ソフトウェア開発及びライフタイム・マネージメント92;仮想教室教育伝達93;データ分析処理94;トランザクション・プロセッシング95;及び統合フロー・テンプレート処理96を含むことができる。
【0114】
本発明のコンピュータ・プログラム製品は、その内部にコンピュータ可読なプログラム・コードを有する1つ又はそれ以上のコンピュータ可読なハードウェア記録デバイスを含み、前記プログラム・コードは、1つ又はそれ以上のプロセッサ回路によって実行されて、本発明の方法を実装する。
【0115】
本発明のコンピュータ・システムは、1つ又はそれ以上のプロセッサ回路、1つ又はそれ以上のメモリ、及び1つ又はそれ以上のコンピュータ可読なハードウェア記録デバイスを含み、前記1つ又はそれ以上のハードウェア記録デバイスが、1つ又はそれ以上のメモリを介して1つ又はそれ以上のプロセッサ回路によって本発明の方法を実装するために実行可能なプログラム・コードを含む。
【0116】
本開示の種々の実施形態の説明は、例示の目的のために提示されたが、開示された実施形態への排他又は限定を意図するものではない。多くの変更例又は変形例は、本開示の範囲及び精神から逸脱することなく、当業者において自明である。本明細書で使用する用語は、本実施形態の原理、実用的用途、又は市場において見出される技術を超える技術的改善を最良に説明するため、又は本明細書において開示された実施形態を当業者の他の者が理解できるようにするために選択したものである。
【0117】
改善及び修正は、本発明の精神から逸脱することなく、成すことができる。