IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ オラクル・インターナショナル・コーポレイションの特許一覧

特表2024-503321仮想化されたクラウド環境におけるレイヤ2ネットワークのインターネットグループ管理プロトコル(IGMP)
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公表特許公報(A)
(11)【公表番号】
(43)【公表日】2024-01-25
(54)【発明の名称】仮想化されたクラウド環境におけるレイヤ2ネットワークのインターネットグループ管理プロトコル(IGMP)
(51)【国際特許分類】
   H04L 45/76 20220101AFI20240118BHJP
   H04L 49/201 20220101ALI20240118BHJP
【FI】
H04L45/76
H04L49/201
【審査請求】未請求
【予備審査請求】未請求
(21)【出願番号】P 2023540139
(86)(22)【出願日】2021-11-24
(85)【翻訳文提出日】2023-08-25
(86)【国際出願番号】 US2021060804
(87)【国際公開番号】W WO2022146587
(87)【国際公開日】2022-07-07
(31)【優先権主張番号】63/132,377
(32)【優先日】2020-12-30
(33)【優先権主張国・地域又は機関】US
(31)【優先権主張番号】17/494,725
(32)【優先日】2021-10-05
(33)【優先権主張国・地域又は機関】US
(81)【指定国・地域】
(71)【出願人】
【識別番号】502303739
【氏名又は名称】オラクル・インターナショナル・コーポレイション
(74)【代理人】
【識別番号】110001195
【氏名又は名称】弁理士法人深見特許事務所
(72)【発明者】
【氏名】ブラール,ジャグウィンダー・シング
(72)【発明者】
【氏名】クレーガー-スティクルズ,ルーカス・マイケル
(72)【発明者】
【氏名】ボックマン,ブライス・ユージーン
(72)【発明者】
【氏名】ジョーンズ,ピーター・クロフト
(72)【発明者】
【氏名】ベイカー,シェーン
【テーマコード(参考)】
5K030
【Fターム(参考)】
5K030KA05
5K030LD04
5K030MD07
(57)【要約】
L2仮想ネットワークにおける通信のための技術が説明される。ある例では、L2仮想ネットワークは、ホストマシンのセット上でホストされる複数のL2計算インスタンスと、ネットワーク仮想化デバイスのセット上でホストされる複数のL2仮想ネットワークインターフェースおよびL2仮想スイッチとを含む。L2仮想ネットワークインターフェースは、L2仮想ネットワークのL2ポートをエミュレートする。IGMP構成は、L2仮想スイッチに配信される。
【特許請求の範囲】
【請求項1】
コンピュータシステムによって実現される方法であって、
第1のネットワーク仮想化デバイス(NVD)から、第1の計算インスタンスのインターネットグループ管理プロトコル(IGMP)応答に関する第1の情報を受信することを含み、前記第1の情報は、前記第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示し、
前記第1の計算インスタンスは、ホストマシン上でホストされ、レイヤ2仮想ネットワークに属し、
前記レイヤ2仮想ネットワークは、物理ネットワーク上でホストされ、複数の計算インスタンスと、複数のレイヤ2仮想ネットワークインターフェースと、複数のレイヤ2仮想スイッチとを含み、
前記物理ネットワークは、第1のNVDと前記ホストマシンとを含み、
前記第1のNVDは、前記複数のレイヤ2仮想ネットワークインターフェースのうちの第1のレイヤ2仮想ネットワークインターフェースと、前記複数のレイヤ2仮想スイッチのうちの第1のレイヤ2仮想スイッチとをホストし、
前記第1のレイヤ2仮想ネットワークインターフェースおよび前記第1のレイヤ2仮想スイッチは、前記第1の計算インスタンスに関連付けられ、前記方法はさらに、
前記第1の情報に基づいて、前記第1の計算インスタンスが前記マルチキャストグループに追加されることを示すIGMPテーブルを生成することと、
前記IGMPテーブルの少なくとも第1の部分を第2のNVDに送信することとを含み、前記第2のNVDは、前記複数のレイヤ2仮想ネットワークインターフェースのうちの第2のレイヤ2仮想ネットワークインターフェースと、前記複数のレイヤ2仮想スイッチのうちの第2のレイヤ2仮想スイッチとをホストし、前記第2のレイヤ2仮想ネットワークインターフェースおよび前記第2のレイヤ2仮想スイッチは、前記複数の計算インスタンスのうちの第2の計算インスタンスに関連付けられる、コンピュータシステムによって実現される方法。
【請求項2】
前記方法はさらに、
前記第2のNVDから、前記第2の計算インスタンスのIGMP応答に関する第2の情報を受信することを含み、前記第2の情報は、前記第2の計算インスタンスが前記マルチキャストグループに追加されるべきであることを示し、前記IGMPテーブルは、さらに前記第2の情報に基づいて生成され、前記第2の計算インスタンスが前記マルチキャストグループに追加されることを示す、請求項1に記載の方法。
【請求項3】
前記方法はさらに、
前記第1のNVDに、前記IGMPテーブルの少なくとも第2の部分を送信することを含む、請求項2に記載の方法。
【請求項4】
前記第2のNVDに送信される前記第1の部分は、前記第2の計算インスタンスが前記マルチキャストグループに追加されるという第1の指示を含まず、前記第1の計算インスタンスが前記マルチキャストグループに追加されるという第2の指示を含み、前記第1のNVDに送信される前記第2の部分は、前記第2の指示を含み、前記第1の指示を含まない、請求項3に記載の方法。
【請求項5】
前記IGMPテーブルは、前記第1のNVDおよび前記第2のNVDに送信される、請求項3に記載の方法。
【請求項6】
前記方法はさらに、
前記第1のNVDにIGMPクエリについて要求を送信することを含み、前記第1のIGMP応答は、前記第1のNVDによって前記IGMPクエリに基づいて受信される、請求項1~5のいずれか1項に記載の方法。
【請求項7】
前記方法はさらに、
前記レイヤ2仮想ネットワークの構成情報に基づいて、前記第1のレイヤ2仮想スイッチは前記第1の計算インスタンスに関連付けられ前記第1のNVDによってホストされると判断することを含み、前記第1のレイヤ2仮想スイッチは前記第1の計算インスタンスに関連付けられ前記第1のNVDによってホストされると判断することに基づいて、前記要求は前記第1のNVDに送信される、請求項6に記載の方法。
【請求項8】
前記方法はさらに、
前記第1のNVDから、前記第1の計算インスタンスが前記マルチキャストグループから除去されるべきであることを示す第2の情報を受信することと、
前記第2の情報に基づいて、前記IGMPテーブルに対する更新を生成することとを含み、前記更新は、前記第1の計算インスタンスが前記マルチキャストグループから除去されることを示し、前記方法はさらに、
前記第2のNVDに、少なくとも前記更新を送信することを含む、請求項1~7のいずれか1項に記載の方法。
【請求項9】
前記更新は、前記第1のNVDではなく別のNVDにさらに送信される、請求項8に記載の方法。
【請求項10】
ネットワーク仮想化デバイスであって、
1つ以上のプロセッサと、
命令を記憶する1つ以上のコンピュータ可読記憶媒体とを備え、前記命令は、前記1つ以上のプロセッサによって実行されると、前記ネットワーク仮想化デバイスを、
レイヤ2仮想ネットワークに属する第1のレイヤ2仮想ネットワークインターフェースおよび第1のレイヤ2仮想スイッチをホストするよう構成し、
前記第1のレイヤ2仮想ネットワークインターフェースおよび前記第1のレイヤ2仮想スイッチは、前記レイヤ2仮想ネットワークに属する第1の計算インスタンスに関連付けられ、
前記第1の計算インスタンスは、前記ネットワーク仮想化デバイスを備える物理ネットワークのホストマシン上でホストされ、前記ホストマシンおよび前記ネットワーク仮想化デバイスは、通信可能に結合され、
前記レイヤ2仮想ネットワークは、前記物理ネットワーク上でホストされ、複数の計算インスタンスと、複数のレイヤ2仮想ネットワークインターフェースと、複数のレイヤ2仮想スイッチとを備え、前記命令は、さらに、前記1つ以上のプロセッサによって実行されると、前記ネットワーク仮想化デバイスを、
前記第1の計算インスタンスに、インターネットグループ管理プロトコル(IGMP)クエリを送信するよう構成し、
前記第1の計算インスタンスのIGMP応答を受信するよう構成し、前記IGMP応答は、前記第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示す、ネットワーク仮想化デバイス。
【請求項11】
前記命令の前記実行はさらに、前記ネットワーク仮想化デバイスを、
コンピュータシステムに、前記IGMP応答に関する第1の情報を送信するよう構成し、前記第1の情報は、前記第1の計算インスタンスが前記マルチキャストグループに追加されるべきであることを示し、前記命令の前記実行はさらに、前記ネットワーク仮想化デバイスを、
前記コンピュータシステムから、IGMPテーブルの少なくとも一部を受信するよう構成し、前記IGMPテーブルは、前記第1の情報に基づいて生成される、請求項10に記載のネットワーク仮想化デバイス。
【請求項12】
前記一部は、前記複数の計算インスタンスのうちの第2の計算インスタンスが前記マルチキャストグループに追加されるという第1の指示を含み、前記第2の計算インスタンスは、第2のネットワーク仮想化デバイスによってホストされる第2のレイヤ2仮想ネットワークインターフェースおよび第2のレイヤ2仮想スイッチに関連付けられる、請求項11に記載のネットワーク仮想化デバイス。
【請求項13】
前記命令の前記実行はさらに、前記ネットワーク仮想化デバイスを、
前記第1の計算インスタンスの前記IGMP応答と前記コンピュータシステムから受信された前記IGMPテーブルの前記一部とに基づいてローカルIGMPテーブルを記憶するよう構成し、前記一部は、前記第1の計算インスタンスが前記マルチキャストグループに追加されるという第2の指示を含まず、前記ローカルIGMPテーブルは前記第2の指示を含む、請求項12に記載のネットワーク仮想化デバイス。
【請求項14】
前記命令の前記実行はさらに、前記ネットワーク仮想化デバイスを、
前記コンピュータシステムから、前記IGMPクエリについて要求を受信するよう構成し、前記IGMPクエリは、前記要求に基づいて送信される、請求項11に記載のネットワーク仮想化デバイス。
【請求項15】
前記命令の前記実行はさらに、前記ネットワーク仮想化デバイスを、
前記コンピュータシステムから受信した前記IGMPテーブルの前記一部に基づいてローカルIGMPテーブルを記憶するよう構成し、前記ローカルIGMPテーブルは、前記複数の計算インスタンスのうちの第2の計算インスタンスが前記マルチキャストグループに追加されることを示し、前記命令の前記実行はさらに、前記ネットワーク仮想化デバイスを、
前記第1の計算インスタンスのフレームを受信するよう構成し、
前記ローカルIGMPテーブルに基づいて、前記フレームが複製され、前記第2の計算インスタンスに送信されるべきであると判断するよう構成し、
前記第2の計算インスタンス宛ての複製されたフレームを送信するよう構成する、請求項11に記載のネットワーク仮想化デバイス。
【請求項16】
命令を記憶する1つ以上のコンピュータ可読記憶媒体であって、前記命令は、ネットワーク仮想化デバイス上で実行されると、前記ネットワーク仮想化デバイスに、動作を実行させ、前記動作は、
レイヤ2仮想ネットワークに属する第1のレイヤ2仮想ネットワークインターフェースおよび第1のレイヤ2仮想スイッチをホストすることを含み、
前記第1のレイヤ2仮想ネットワークインターフェースおよび前記第1のレイヤ2仮想スイッチは、前記レイヤ2仮想ネットワークに属する第1の計算インスタンスに関連付けられ、
前記第1の計算インスタンスは、前記ネットワーク仮想化デバイスを備える物理ネットワークのホストマシン上でホストされ、前記ホストマシンおよび前記ネットワーク仮想化デバイスは、通信可能に結合され、
前記レイヤ2仮想ネットワークは、前記物理ネットワーク上でホストされ、複数の計算インスタンスと、複数のレイヤ2仮想ネットワークインターフェースと、複数のレイヤ2仮想スイッチとを備え、前記動作はさらに、
前記第1の計算インスタンスに、第1のインターネットグループ管理プロトコル(IGMP)クエリを送信することと、
前記第1の計算インスタンスの第1のIGMP応答を受信することとを含み、前記第1のIGMP応答は、前記第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示す、1つ以上のコンピュータ可読記憶媒体。
【請求項17】
前記動作はさらに、
コンピュータシステムに、前記第1のIGMP応答に関する第1の情報を送信することを含み、前記第1の情報は、前記第1の計算インスタンスが前記マルチキャストグループに追加されるべきであることを示し、前記動作はさらに、
前記コンピュータシステムから、IGMPテーブルの少なくとも一部を受信することを含み、前記IGMPテーブルは、前記第1の情報に基づいて生成される、請求項16に記載の1つ以上のコンピュータ可読記憶媒体。
【請求項18】
前記動作はさらに、
前記第1の計算インスタンスに、第2のIGMPクエリを送信することと、
前記第1の計算インスタンスの第2のIGMP応答を受信することとを含み、前記第2のIGMP応答は、前記第1の計算インスタンスが前記マルチキャストグループから除去されるべきであることを示す、請求項17に記載の1つ以上のコンピュータ可読記憶媒体。
【請求項19】
前記動作はさらに、
前記コンピュータシステムから受信した前記IGMPテーブルの前記一部に基づいてローカルIGMPテーブルを記憶することと、
前記第1の計算インスタンスが前記マルチキャストグループから除去されることを示すよう、前記ローカルIGMPテーブルを更新することとを含む、請求項18に記載の1つ以上のコンピュータ可読記憶媒体。
【請求項20】
前記動作はさらに、
前記コンピュータシステムから受信した前記IGMPテーブルの前記一部に基づいてローカルIGMPテーブルを記憶することと、
前記第1の計算インスタンスが前記マルチキャストグループから除去されるべきであることを示す更新を前記コンピュータシステムに送信することとを含む、請求項18に記載の1つ以上のコンピュータ可読記憶媒体。
【発明の詳細な説明】
【技術分野】
【0001】
関連出願の参照
この国際特許出願は、2020年12月30日に提出された「INTERNET GROUP MANAGEMENT PROTOCOL (IGMP) OF A LAYER 2 NETWORK IN A VIRTUALIZED CLOUD ENVIRONMENT」と題される米国仮出願63/132,377の利益を主張する、2021年10月5日に提出された「LAYER-2 NETWORKING USING ACCESS CONTROL LISTS IN A VIRTUALIZED CLOUD ENVIRONMENT」と題される米国特許出願17/494,725に対する優先権を主張し、その内容は、あらゆる目的のためにその全体が参照により本明細書に組み込まれる。
【背景技術】
【0002】
背景
クラウドコンピューティングは、コンピューティングリソースのオンデマンド可用性を提供する。クラウドコンピューティングは、インターネットを介してユーザに利用可能なデータセンタに基づくことができる。クラウドコンピューティングは、サービスとしてのインフラストラクチャ(IaaS)を提供することができる。仮想ネットワークは、ユーザによる使用のために作成されてもよい。しかしながら、これらの仮想ネットワークは、それらの機能性および価値を制約する制限を有する。したがって、さらなる改善が望まれる。
【発明の概要】
【課題を解決するための手段】
【0003】
概要
本開示は、仮想化されたクラウド環境に関する。仮想化されたクラウド環境においてレイヤ2ネットワーキング機能を提供するための技術が説明される。レイヤ2機能は、仮想化されたクラウド環境によって提供されるレイヤ3ネットワーキング機能に加えて、およびそれと関連して、提供される。
[0004]
本開示のいくつかの実施形態は、顧客の仮想クラウドネットワーク(VCN)など、プライベートネットワーク内でレイヤ2仮想ローカルエリアネットワーク(VLAN)を顧客に提供することに関する。レイヤ2VLANにおいては、異なる計算インスタンスが接続される。顧客は、計算インスタンスを接続するエミュレートされた単一スイッチの認知を与えられる。実際、このエミュレートされたスイッチは、ローカルスイッチの集合を含む無限にスケーラブルな分散型スイッチとして実現される。より具体的には、各計算インスタンスは、ネットワーク仮想化デバイス(NVD)に接続されたホストマシン上で実行される。NVDに接続されたホスト上の各計算インスタンスについて、NVDは、計算インスタンスに関連付けられるレイヤ2仮想ネットワークインターフェースカード(VNIC)およびローカルスイッチをホストする。レイヤ2VNICは、レイヤ2VLAN上において計算インスタンスのポートを表す。ローカルスイッチは、VNICを、レイヤ2VLANの他の計算インスタンスに関連付けられる他のVNIC(例えば、他のポート)に接続する。例えば、インターネットグループ管理プロトコル(IGMP)機能を含む、様々なレイヤ2ネットワークサービスがサポートされる。
【0004】
ここでは、方法、システム、1つ以上のプロセッサによって実行可能なプログラム、コード、または命令を記憶する非一時的コンピュータ可読記憶媒体などを含む様々な実施形態について説明する。
【図面の簡単な説明】
【0005】
図1】特定の実施形態に従って、クラウドサービスプロバイダインフラストラクチャによってホストされている仮想またはオーバーレイクラウドネットワークを示す分散環境のハイレベル図である。
図2】特定の実施形態に従って、CSPI内の物理ネットワークの物理要素を示すアーキテクチャ概略図である。
図3】特定の実施形態に従って、ホストマシンが複数のネットワーク仮想化デバイス(NVD)に接続されているCSPIの例示的な配置を示す図である。
図4】特定の実施形態に従って、ホストマシンとマルチテナント機能をサポートするためのI/O仮想化を提供するNVDとの間の接続を示す図である。
図5】特定の実施形態に従って、CSPIによって提供される物理ネットワークを示す概略ブロック図である。
図6】ある実施形態によるコンピューティングネットワークの概略図である。
図7】ある実施形態による、VLANの論理およびハードウェア概略図である。
図8】ある実施形態による、複数の接続されたL2 VLANの論理概略図である。
図9】ある実施形態による、複数の接続されたL2 VLANおよびサブネット900の論理概略図である。
図10】ある実施形態による、VLAN内通信およびVLAN内の学習の概略図である。
図11】ある実施形態によるVLANの概略図である。
図12】ある実施形態による、VLAN内通信のためのプロセス1200を示すフローチャートである。[0018]
図13】ある実施形態による、レイヤ2仮想ネットワーク構成を定義するために好適な例示的環境を示す図である。
図14】ある実施形態による、レイヤ2仮想ネットワークにおける例示的なIGMP技術を示す図である。
図15】ある実施形態による、レイヤ2仮想ネットワークにおいてIGMPテーブルを生成するためのプロセスを示すフローチャートである。
図16】ある実施形態による、レイヤ2仮想ネットワークにおいてIGMPテーブルを更新するためのプロセスを示すフローチャートである。
図17】ある実施形態による、レイヤ2仮想ネットワークにおいてIGMPクエリを実行するためのプロセスを示すフローチャートである。
図18】ある実施形態による、レイヤ2仮想ネットワークにおいてIGMPテーブルを使用するためのプロセスを示すフローチャートである。
図19】少なくとも1つの実施形態に従って、クラウドインフラストラクチャをサービスシステムとして実現するための1つのパターンを示すブロック図である。
図20】少なくとも1つの実施形態に従って、クラウドインフラストラクチャをサービスシステムとして実現するための別のパターンを示すブロック図である。
図21】少なくとも1つの実施形態に従って、クラウドインフラストラクチャをサービスシステムとして実現するための別のパターンを示すブロック図である。
図22】少なくとも1つの実施形態に従って、クラウドインフラストラクチャをサービスシステムとして実現するための別のパターンを示すブロック図である。
図23】少なくとも1つの実施形態に従って、例示的なコンピュータシステムを示すブロック図である。
【発明を実施するための形態】
【0006】
詳細な説明
以下の説明では、説明の目的のために、特定の詳細が、特定の実施形態の完全な理解を促すために記載される。しかしながら、様々な実施形態がこれらの具体的な詳細なしに実施されてもよいことは明らかであろう。図および記載は、限定することを意図したものではない。「例示的」という文言は、ここでは、「例、事例、または例示として供される」ことを意味するために用いられる。「例示的」としてここに記載される任意の実施形態または設計は、必ずしも、他の実施形態もしくは設計よりも好ましいまたは有利であると解釈されるべきではない。
【0007】
A.例示的な仮想ネットワーキングアーキテクチャ
クラウドサービスという用語は、一般的に、クラウドサービスプロバイダ(CSP)が、システムおよびインフラストラクチャ(クラウドインフラストラクチャ)を用いて、ユーザまたは顧客がオンデマンドで(例えば、サブスクリプションモデルを介して)利用できるサービスを指す。通常、CSPのインフラストラクチャを構成するサーバおよびシステムは、顧客自身のオンプレミスサーバおよびシステムから離れている。したがって、顧客は、サービス用のハードウェアおよびソフトウェア資源を別途購入することなく、CSPによって提供されるクラウドサービスを利用することができる。クラウドサービスは、サービスを提供するために使用されるインフラストラクチャの調達に顧客が投資する必要がなく、アプリケーションおよび計算リソースへの容易且つ拡張可能なアクセスを加入している顧客に提供するように設計されている。
【0008】
様々な種類のクラウドサービスを提供するクラウドサービスプロバイダがいくつかある。クラウドサービスは、SaaS(Software-as-a-Service)、PaaS(Platform-as-a-Service)、IaaS(Infrastructure-as-a-Service)などの様々な異なる種類またはモデルを含む。
【0009】
顧客は、CSPによって提供される1つ以上のクラウドサービスに加入することができる。顧客は、個人、組織、企業などの任意のエンティティであってもよい。顧客がCSPによって提供されるサービスに加入または登録すると、その顧客に対してテナントまたはアカウントが作成される。その後、顧客は、このアカウントを介して、アカウントに関連付けられた1つ以上の加入済みクラウドリソースにアクセスすることができる。
【0010】
上述したように、IaaS(Infrastructure as a Service)は、1つの特定種類のクラウドコンピューティングサービスである。IaaSモデルにおいて、CSPは、顧客が自身のカスタマイズ可能なネットワークを構築し、顧客リソースを展開するために使用できるインフラストラクチャ(クラウドサービスプロバイダインフラストラクチャまたはCSPIと呼ばれる)を提供する。したがって、顧客のリソースおよびネットワークは、CSPによって提供されたインフラストラクチャによって分散環境にホストされる。これは、顧客のインフラストラクチャが顧客のリソースおよびネットワークをホストする従来のコンピューティングとは異なる。
【0011】
CSPIは、基板ネットワークまたはアンダーレイネットワークとも呼ばれる物理ネットワークを形成する、様々なホストマシン、メモリリソース、およびネットワークリソースを含む相互接続された高性能の計算リソースを含んでもよい。CSPIのリソースは、1つ以上の地理的な地域にわたって地理的に分散されている1つ以上のデータセンタに分散されてもよい。仮想化ソフトウェアは、これらの物理リソースによって実行され、仮想化分散環境を提供することができる。仮想化は、物理ネットワーク上に(ソフトウエアベースネットワーク、ソフトウェア定義ネットワーク、または仮想ネットワークとも呼ばれる)オーバーレイネットワークを作成する。CSPI物理ネットワークは、物理ネットワークの上に1つ以上のオーバーレイまたは仮想ネットワークを作成するための基礎を提供する。仮想ネットワークまたはオーバーレイネットワークは、1つ以上の仮想クラウドネットワーク(VCN)を含むことができる。仮想ネットワークは、ソフトウェア仮想化技術(例えば、ハイパーバイザ、ネットワーク仮想化デバイス(NVD)(例えば、スマートNIC)によって実行される機能、トップオブラック(TOR)スイッチ、NVDによって実行される1つ以上の機能を実装するスマートTOR、および他のメカニズム)を用いて実装され、物理ネットワークの上で実行できるネットワーク抽象化層を作成する。仮想ネットワークは、ピアツーピアネットワーク、IPネットワークなどの様々な形態をとることができる。仮想ネットワークは、典型的には、レイヤ3IPネットワークまたはレイヤ2VLANのいずれかである。このような仮想ネットワークまたはオーバーレイネットワークは、しばしば仮想レイヤ3ネットワークまたはオーバーレイレイヤ3ネットワークと呼ばれる。仮想ネットワークのために開発されたプロトコルの例は、IP-in-IP(またはGRE(Generic Routing Encapsulation))、仮想拡張可能LAN(VXLAN-IETF RFC7348)、仮想プライベートネットワーク(VPN)(例えば、MPLSレイヤ3仮想プライベートネットワーク(RFC4364))、VMware NSX、GENEVE(Generic Network Virtualization Encapsulation)などを含む。
【0012】
IaaSの場合、CSPによって提供されたインフラストラクチャ(CSPI)は、パブリックネットワーク(例えば、インターネット)を介して仮想化計算リソースを提供するように構成されてもよい。IaaSモデルにおいて、クラウドコンピューティングサービスプロバイダは、インフラストラクチャ要素(例えば、サーバ、記憶装置、ネットワークノード(例えば、ハードウェア)、展開ソフトウェア、プラットフォーム仮想化(例えば、ハイパーバイザ層)など)をホストすることができる。場合によっては、IaaSプロバイダは、それらのインフラストラクチャ要素に付随する様々なサービス(例えば、課金、監視、ロギング、セキュリティ、負荷分散およびクラスタリングなど)を提供することができる。これらのサービスがポリシー駆動型であるため、IaaSユーザは、負荷分散を駆動するためのポリシーを実装することによって、アプリケーションの可用性および性能を維持することができる。CSPIは、インフラストラクチャおよび一連の補完的なクラウドサービスを提供する。これによって、顧客は、可用性の高いホスト型分散環境で幅広いアプリケーションおよびサービスを構築し、実行することができる。CSPIは、顧客オンプレミスネットワークなどの様々なネットワーク拠点から安全にアクセスできる柔軟な仮想ネットワーク上で高性能の計算リソースおよび能力ならびに記憶容量を提供する。顧客がCSPによって提供されたIaaSサービスに加入または登録すると、その顧客のために作成されたテナンシは、CSPIから安全に分離されたパーティションとなり、顧客は、クラウドリソースを作成、整理、管理することができる。
【0013】
顧客は、CSPIによって提供された計算リソース、メモリリソース、およびネットワーキングリソースを使用して、独自の仮想ネットワークを構築することができる。これらの仮想ネットワーク上に、計算インスタンスなどの1つ以上の顧客リソースまたはワークロードを展開することができる。例えば、顧客は、CSPIによって提供されたリソースを使用して、仮想クラウドネットワーク(VCN)と呼ばれる1つ以上のカスタマイズ可能なプライベート仮想ネットワークを構築することができる。顧客は、顧客VCN上で1つ以上の顧客リソース、例えば計算インスタンスを展開することができる。計算インスタンスは、仮想マシン、ベアメタルインスタンスなどであってもよい。したがって、CSPIは、顧客が可用性の高い仮想ホスト環境において様々なアプリケーションおよびサービスを構築および実行することを可能にするインフラストラクチャおよび一連の相補的なクラウドサービスを提供する。顧客は、CSPIによって提供された基礎的な物理リソースを管理または制御しないが、オペレーティングシステム、記憶、および展開されたアプリケーションを制御し、場合によっては一部のネットワーキングコンポーネント(例えば、ファイアウォール)を限定的に制御する。
【0014】
CSPは、顧客およびネットワーク管理者がCSPIリソースを使用してクラウドに展開されたリソースを構成、アクセス、および管理することを可能にするコンソールを提供することができる。特定の実施形態において、コンソールは、CSPIを利用および管理するために使用することができるウェブベースのユーザインターフェイスを提供する。いくつかの実施形態において、コンソールは、CSPによって提供されたウェブベースのアプリケーションである。
【0015】
CSPIは、シングルテナンシアーキテクチャまたはマルチテナンシアーキテクチャをサポートすることができる。シングルテナンシアーキテクチャにおいて、ソフトウェア(例えば、アプリケーション、データベース)またはハードウェア要素(例えば、ホストマシンまたはサーバ)は、単一の顧客またはテナントにサービスを提供する。マルチテナンシアーキテクチャにおいて、ソフトウェアまたはハードウェア要素は、複数の顧客またはテナントにサービスを提供する。したがって、マルチテナンシアーキテクチャにおいて、CSPIリソースは、複数の顧客またはテナントの間で共有される。マルチテナンシ環境において、各テナントのデータが分離され、他のテナントから見えないようにするために、CSPIには予防措置および保護措置が講じられる。
【0016】
物理ネットワークにおいて、ネットワークエンドポイント(エンドポイント)は、物理ネットワークに接続され、接続されているネットワークと双方向に通信するコンピューティング装置またはシステムを指す。物理ネットワークのネットワークエンドポイントは、ローカルエリアネットワーク(LAN)、ワイドエリアネットワーク(WAN)、または他の種類の物理ネットワークに接続されてもよい。物理ネットワークの従来のエンドポイントの例は、モデム、ハブ、ブリッジ、スイッチ、ルータ、および他のネットワーキング装置、物理コンピュータ(またはホストマシン)などを含む。物理ネットワークの各物理装置は、当該装置と通信するために使用できる固定ネットワークアドレスを有する。この固定ネットワークアドレスは、レイヤ2アドレス(例えば、MACアドレス)、固定レイヤ3アドレス(例えば、IPアドレス)などであってもよい。仮想化環境または仮想ネットワークにおいて、エンドポイントは、物理ネットワークの要素によってホストされている(例えば、物理ホストマシンによってホストされている)仮想マシンなどの様々な仮想エンドポイントを含むことができる。仮想ネットワークのこれらのエンドポイントは、オーバーレイレイヤ2アドレス(例えば、オーバーレイMACアドレス)およびオーバーレイレイヤ3アドレス(例えば、オーバーレイIPアドレス)などのオーバーレイアドレスによってアドレス指定される。ネットワークオーバーレイは、ネットワーク管理者がソフトウェア管理を用いて(例えば、仮想ネットワークの制御プレーンを実装するソフトウェアを介して)ネットワークエンドポイントに関連付けられたオーバーレイアドレスを移動できるようにすることによって柔軟性を実現する。したがって、物理ネットワークとは異なり、仮想ネットワークにおいて、ネットワーク管理ソフトウェアを使用して、オーバーレイアドレス(例えば、オーバーレイIPアドレス)を1つのエンドポイントから別のエンドポイントに移動することができる。仮想ネットワークが物理ネットワーク上に構築されているため、仮想ネットワークおよび基礎となる物理ネットワークの両方は、仮想ネットワークの要素間の通信に関与する。このような通信を容易にするために、CSPIの各要素は、仮想ネットワークのオーバーレイアドレスを基板ネットワークの実際の物理アドレスにまたは基板ネットワークの実際の物理アドレスを仮想ネットワークのオーバーレイアドレスにマッピングするマッピングを学習および記憶するように構成されている。これらのマッピングは、通信を容易にするために使用される。仮想ネットワークのルーティングを容易にするために、顧客トラフィックは、カプセル化される。
【0017】
したがって、物理アドレス(例えば、物理IPアドレス)は、物理ネットワークの要素に関連付けられ、オーバーレイアドレス(例えば、オーバーレイIPアドレス)は、仮想ネットワークのエンティティに関連付けられる。物理IPアドレスとオーバーレイIPアドレスは、いずれも実IPアドレスである。これらは、仮想IPアドレスとは別物であり、仮想IPアドレスは、複数の実IPアドレスにマッピングされる。仮想IPアドレスは、仮想IPアドレスと複数の実IPアドレスの間の1対多のマッピングを提供する。
【0018】
クラウドインフラストラクチャまたはCSPIは、世界中の1つ以上の地域の1つ以上のデータセンタに物理的にホストされる。CSPIは、物理ネットワークまたは基板ネットワークの要素と、物理ネットワーク要素上に構築された仮想ネットワークの仮想化要素(例えば、仮想ネットワーク、計算インスタンス、仮想マシン)とを含んでもよい。特定の実施形態において、CSPIは、レルム(realm)、地域(region)、および利用可能なドメイン(domain)において編成およびホストされる。地域は、典型的には、1つ以上のデータセンタを含む局所的な地理的領域である。地域は、一般的に互いに独立しており、例えば、国または大陸を跨ぐ広大な距離によって分離されてもよい。例えば、第1の地域は、オーストラリアにあってもよく、別の地域は、日本にあってもよく、さらに別の地域は、インドにあってもよい。CSPIリソースは、各地域が独立したCSPIリソースのサブセットを有するようにこれらの地域間で分割される。各地域は、一連のコアインフラストラクチャサービスおよびリソース、例えば、計算リソース(例えば、ベアメタルサーバ、仮想マシン、コンテナおよび関連インフラストラクチャ)、記憶リソース(例えば、ブロックボリューム記憶、ファイル記憶、オブジェクト記憶、アーカイブ記憶)、ネットワーキングリソース(例えば、仮想クラウドネットワーク(VCN)、負荷分散リソース、オンプレミスネットワークへの接続)、データベースリソース、エッジネットワーキングリソース(例えば、DNS)、アクセス管理および監視リソースなどを提供することができる。各地域は、一般的に、当該地域をレルム内の他の地域に接続するための複数の経路を持つ。
【0019】
一般的に、アプリケーションは、近くのリソースを使用することが遠くのリソースを使用することよりも速いため、最も多く使用される地域に展開される(すなわち、その地域に関連するインフラストラクチャ上に展開される)。また、アプリケーションは、大規模な気象システムまたは地震などの地域全体のイベントのリスクを軽減するための冗長性、法的管轄、税金ドメイン、および他のビジネスまたは社会的基準に対する様々な要件を満たすための冗長性など、様々な理由で異なる地域に展開されてもよい。
【0020】
地域内のデータセンタは、さらに編成され、利用可能なドメイン(availability domain:AD)に細分化されてもよい。利用可能なドメインは、ある地域に配置された1つ以上のデータセンタに対応してもよい。地域は、1つ以上の利用可能なドメインから構成されてもよい。このような分散環境において、CSPIリソースは、仮想クラウドネットワーク(VCN)などの地域に固有なものまたは計算インスタンスなどの利用可能なドメインに固有なものである。
【0021】
1つの地域内のADは、フォールトトレラント(fault tolerant)になるように互いに分離され、同時に故障する可能性が非常に低くなるように構成されている。これは、1つの地域内の1つのADの障害が同じ地域内の他のADの可用性に影響を与えることが殆どないように、ネットワーキング、物理ケーブル、ケーブル経路、ケーブル入口などの重要なインフラストラクチャリソースを共有しないように、ADを構成することによって達成される。同じ地域内のADを低遅延広帯域のネットワークで互いに接続することによって、他のネットワーク(例えば、インターネット、顧客オンプレミスネットワーク)への高可用性接続を提供し、複数のADにおいて高可用性および災害復旧の両方のための複製システムを構築することができる。クラウドセンアイスは、複数のADを利用して、高可用性を確保すると共に、リソースの障害から保護する。IaaSプロバイダによって提供されたインフラストラクチャが成長するにつれて、追加の容量と共により多くの地域およびADを追加してもよい。利用可能なドメイン間のトラフィックは、通常、暗号化される。
【0022】
特定の実施形態において、地域は、レルムにグループ化される。レルムは、地域の論理的な集合である。レルムは、互いに隔離されており、いかなるデータを共有しない。同じレルム内の地域は、互いに通信することができるが、異なるレルム内の地域は、通信することができない。CSPの顧客のテナンシまたはアカウントは、単一のレルムに存在し、その単一のレルムに属する1つ以上の地域を跨ることができる。典型的には、顧客がIaaSサービスに加入すると、レルム内の顧客指定地域(「ホーム」地域と呼ばれる)に、その顧客のテナンシまたはアカウントが作成される。顧客は、顧客のテナンシをレルム内の1つ以上の他の地域に拡張することができる。顧客は、顧客のテナンシが存在するレルム内に存在していない地域にアクセスすることができない。
【0023】
IaaSプロバイダは、複数のレルムを提供することができ、各レルムは、特定の組の顧客またはユーザに対応する。例えば、商用レルムは、商用顧客のために提供されてもよい。別の例として、レルムは、特定の国のためにまたはその国の顧客のために提供されてもよい。さらに別の例として、政府用レルムは、例えば政府のために提供されてもよい。例えば、政府用レルムは、特定の政府のために作成されてもよく、商用レルムよりも高いセキュリティレベルを有してもよい。例えば、オラクル(登録商標)クラウドインフラストラクチャ(OCI)は、現在、商用領域向けのレルムと、政府クラウド領域向けの2つのレルム(例えば、FedRAMP認可およびIL5認可)とを提供する。
【0024】
特定の実施形態において、ADは、1つ以上の障害ドメイン(fault domain)に細分化することができる。障害ドメインは、反親和性(anti-affinity)を提供するために、AD内のインフラストラクチャリソースをグループ化したものである。障害ドメインは、計算インスタンスを分散することができる。これによって、計算インスタンスは、1つのAD内の同じ物理ハードウェア上に配置されない。これは、反親和性として知られている。障害ドメインは、1つの障害点を共有するハードウェア要素(コンピュータ、スイッチなど)の集合を指す。計算プールは、障害ドメインに論理的に分割される。このため、1つの障害ドメインに影響を与えるハードウェア障害または計算ハードウェア保守イベントは、他の障害ドメインのインスタンスに影響を与えない。実施形態によっては、各ADの障害ドメインの数は、異なってもよい。例えば、特定の実施形態において、各ADは、3つの障害ドメインを含む。障害ドメインは、AD内の論理データセンタとして機能する。
【0025】
顧客がIaaSサービスに加入すると、CSPIからのリソースは、顧客にプロビジョニングされ、顧客のテナンシに関連付けられる。顧客は、これらのプロビジョニングされたリソースを使用して、プライベートネットワークを構築し、これらのネットワーク上にリソースを展開することができる。CSPIによってクラウド上でホストされている顧客ネットワークは、仮想クラウドネットワーク(VCN)と呼ばれる。顧客は、顧客用に割り当てられたCSPIリソースを使用して、1つ以上の仮想クラウドネットワーク(VCN)を構成することができる。VCNとは、仮想またはソフトウェア定義のプライベートネットワークである。顧客のVCNに配備された顧客リソースは、計算インスタンス(例えば、仮想マシン、ベアメタルインスタンス)および他のリソースを含むことができる。これらの計算インスタンスは、アプリケーション、ロードバランサ、データベースなどの様々な顧客作業負荷を表してもよい。VCN上に配備された計算インスタンスは、インターネットなどのパブリックネットワークを介して公的にアクセス可能なエンドポイント(パブリックエンドポイント)と通信することができ、同じVCNまたは他のVCN(例えば、顧客の他のVCN、または顧客に属さないVCN)内の他のインスタンスと通信することができ、顧客オンプレミスデータセンタまたはネットワークと通信することができ、センディエンドポイントと通信することができ、および他の種類のエンドポイントと通信することができる。
【0026】
CSPは、CSPIを用いて多様なサービスを提供することができる。場合によっては、CSPIの顧客自身は、サービスプロバイダのように振る舞い、CSPIリソースを使用してサービスを提供することができる。サービスプロバイダは、識別情報(例えば、IPアドレス、DNS名およびポート)によって特徴付けられるサービスエンドポイントを公開することができる。顧客のリソース(例えば、計算インスタンス)は、サービスによって公開されたその特定のサービスのサービスエンドポイントにアクセスすることによって、特定のサービスを消費することができる。これらのサービスエンドポイントは、一般に、ユーザがエンドポイントに関連付けられたパブリックIPアドレスを使用して、インターネットなどのパブリック通信ネットワークを介して公的にアクセス可能なエンドポイントである。公的にアクセス可能なネットワークエンドポイントは、パブリックエンドポイントと呼ばれることもある。
【0027】
特定の実施形態において、サービスプロバイダは、(サービスエンドポイントと呼ばれることもある)サービスのエンドポイントを介してサービスを公開することができる。サービスの顧客は、このサービスエンドポイントを使用してサービスにアクセスすることができる。特定の実施形態において、サービスのために提供されたサービスエンドポイントは、そのサービスを消費しようとする複数の顧客によってアクセスすることができる。他の実装形態において、専用のサービスエンドポイントを顧客に提供してもよい。したがって、その顧客のみは、その専用センディエンドポイントを使用してサービスにアクセスすることができる。
【0028】
特定の実施形態において、VCNは、作成されると、そのVCNに割り当てられたプライベートオーバーレイIPアドレス範囲(例えば、10.0/16)であるプライベートオーバーレイクラスレスドメイン間ルーティング(Classless Inter-Domain Routing:CIDR)アドレス空間に関連付けられる。VCNは、関連するサブネット、ルートテーブル、およびゲートウェイを含む。VCNは、単一の地域内に存在するが、地域の1つ以上または全ての利用可能なドメインに拡張することができる。ゲートウェイは、VCN用に構成され、VCNとVCN外部の1つ以上のエンドポイントとの間のトラフィック通信を可能にする仮想インターフェースである。VCNの1つ以上の異なる種類のゲートウェイを構成することによって、異なる種類のエンドポイント間の通信を可能にすることができる。
【0029】
VCNは、1つ以上のサブネットなどの1つ以上のサブネットワークに細分化されてもよい。したがって、サブネットは、VCN内で作成され得る構成単位または区画である。VCNは、1つ以上のサブネットを持つことができる。VCN内の各サブネットは、当該VCN内の他のサブネットと重複せず、当該VCNのアドレス空間のアドレス空間サブセットを表すオーバーレイIPアドレス(例えば、10.0.0.0/24および10.0.1.0/24)の連続範囲に関連付けられる。
【0030】
各計算インスタンスは、仮想ネットワークインターフェイスカード(VNIC)に関連付けられる。これによって、各計算インスタンスは、VCNのサブネットに参加することができる。VNICは、物理ネットワークインターフェイスカード(NIC)の論理表現である。一般的に、VNICは、エンティティ(例えば、計算インスタンス、サービス)と仮想ネットワークとの間のインターフェースである。VNICは、サブネットに存在し、1つ以上の関連するIPアドレスと、関連するセキュリティルールまたはポリシーとを有する。VNICは、スイッチ上のレイヤ2ポートに相当する。VNICは、計算インスタンスと、VCN内のサブネットとに接続されている。計算インスタンスに関連付けられたVNICは、計算インスタンスがVCNのサブネットの一部であることを可能にし、計算インスタンスが、計算インスタンスと同じサブネット上にあるエンドポイントと、VCN内の異なるサブネット内のエンドポイントと、またはVCN外部のエンドポイントと通信する(例えば、パケットを送信および受信する)ことを可能にする。したがって、計算インスタンスに関連するVNICは、計算インスタンスがVCNの内部および外部のエンドポイントとどのように接続しているかを判断する。計算インスタンスのVNICは、計算インスタンスが作成され、VCN内のサブネットに追加されるときに作成され、その計算インスタンスに関連付けられる。サブネットは、計算インスタンスのセットからなる場合、計算インスタンスのセットに対応するVNICを含み、各VNICは、コンピュータインスタンスのセット内の計算インスタンスに接続されている。
【0031】
計算インスタンスに関連するVNICを介して、各計算インスタンスにはプライベートオーバーレイIPアドレスが割り当てられる。このプライベートオーバーレイIPアドレスは、計算インスタンスの作成時に計算インスタンスに関連するVNICに割り当てられ、計算インスタンスのトラフィックをルーティングするために使用される。特定のサブネット内の全てのVNICは、同じルートテーブル、セキュリティリスト、およびDHCPオプションを使用する。上述したように、VCN内の各サブネットは、当該VCN内の他のサブネットと重複せず、当該VCNのアドレス空間のアドレス空間サブセットを表すオーバーレイIPアドレス(例えば、10.0.0.0/24および10.0.1.0/24)の連続範囲に関連付けられる。VCNの特定のサブネット上のVNICの場合、VNICに割り当てられたオーバーレイIPアドレスは、サブネットに割り当てられたオーバーレイIPアドレスの連続範囲からのアドレスである。
【0032】
特定の実施形態において、必要に応じて、計算インスタンスには、プライベートオーバーレイIPアドレスに加えて、追加のオーバーレイIPアドレス、例えば、パブリックサブネットの場合に1つ以上のパブリックIPアドレスを割り当てることができる。これらの複数のアドレスは、同じVNIC、または計算インスタンスに関連付けられた複数のVNICに割り当てられる。しかしながら、各インスタンスは、インスタンス起動時に作成され、インスタンスに割り当てられたオーバーレイプライベートIPアドレスに関連付けられたプライマリVNICを有する。このプライマリVNICは、削除することができない。セカンダリVNICと呼ばれる追加のVNICは、プライマリVNICと同じ利用可能なドメイン内の既存のインスタンスに追加することができる。全てのVNICは、インスタンスと同じ利用可能なドメインにある。セカンダリVNICは、プライマリVNICと同じVCNのサブネットにあってもよく、または同じVCNまたは異なるVCNの異なるサブネットにあってもよい。
【0033】
計算インスタンスは、パブリックサブネットにある場合、オプションでパブリックIPアドレスを割り当てられることができる。サブネットを作成するときに、当該サブネットをパブリックサブネットまたはプライベートサブネットのいずれかとして指定することができる。プライベートサブネットとは、当該サブネット内のリソース(例えば、計算インスタンス)および関連するVNICがパブリックオーバーレイIPアドレスを持つことができないことを意味する。パブリックサブネットとは、サブネット内のリソースおよび関連するVNICがパブリックIPアドレスを持つことができることを意味する。顧客は、地域またはレルム内の単一の利用可能なドメインまたは複数の利用可能なドメインにわたって存在するサブネットを指定することができる。
【0034】
上述したように、VCNは、1つ以上のサブネットに細分化されてもよい。特定の実施形態において、VCNのために構成された仮想ルータ(VCN VRまたは単にVRと呼ばれる)は、VCNのサブネット間の通信を可能にする。VCN内のサブネットの場合、VRは、サブネット(すなわち、当該サブネット上の計算インスタンス)と、VCN内部の他のサブネット上のエンドポイントおよびVCN外部の他のエンドポイントとの通信を可能にする当該サブネットの論理ゲートウェイを表す。VCN VRは、VCN内のVNICと、VCNに関連する仮想ゲートウェイ(ゲートウェイ)との間のトラフィックをルーティングするように構成された論理エンティティである。ゲートウェイは、図1に関して以下でさらに説明される。VCN VRは、レイヤ3/IPレイヤの概念である。一実施形態において、1つのVCNに対して1つのVCN VRが存在する。このVCN VRは、IPアドレスによってアドレス指定された無制限の数のポートを潜在的に有し、VCNの各サブネットに対して1つのポートを有する。このようにして、VCN VRは、VCN VRが接続されているVCNの各サブネットに対して異なるIPアドレスを有する。また、VRは、VCNのために構成された様々なゲートウェイに接続されている。特定の実施形態において、サブネットのオーバーレイIPアドレス範囲からの特定のオーバーレイIPアドレスは、そのサブネットのVCN VRのポートに保留される。例えば、関連するアドレス範囲10.0/16および10.1/16を各々有する2つのサブネットを有するVCNを考える。アドレス範囲10.0/16を有するVCNの第1のサブネットの場合、この範囲からのアドレスは、そのサブネットのVCN VRのポートに保留される。場合によっては、この範囲からの第1のIPアドレスは、VCN VRに保留されてもよい。例えば、オーバーレイIPアドレス範囲10.0/16を有するサブネットの場合、IPアドレス10.0.0.1は、そのサブネットのVCN VRのポートに保留されてもよい。同じVCN内のアドレス範囲10.1/16を有する第2のサブネットの場合、VCN VRは、IPアドレス10.1.0.1を有する第2のサブネットのポートを有してもよい。VCN VRは、VCN内の各サブネットに対して異なるIPアドレスを有する。
【0035】
いくつかの他の実施形態において、VCN内の各サブネットは、VRに関連付けられた保留またはデフォルトIPアドレスを使用してサブネットによってアドレス指定可能な、それ自身に関連するVRを有してもよい。保留またはデフォルトIPアドレスは、例えば、そのサブネットに関連付けられたIPアドレスの範囲からの第1のIPアドレスであってもよい。サブネット内のVNICは、このデフォルトまたは保留IPアドレスを使用して、サブネットに関連付けられたVRと通信(例えば、パケットを送信および受信)することができる。このような実施形態において、VRは、そのサブネットの着信/送信ポイントである。VCN内のサブネットに関連付けられたVRは、VCN内の他のサブネットに関連付けられた他のVRと通信することができる。また、VRは、VCNに関連付けられたゲートウェイと通信することができる。サブネットのVR機能は、サブネット内のVNICのVNIC機能を実行する1つ以上のNVD上で実行され、またはそれによって実行される。
【0036】
ルートテーブル、セキュリティルール、およびDHCPオプションは、VCNのために構成されてもよい。ルートテーブルは、VCNの仮想ルートテーブルであり、ゲートウェイまたは特別に構成されたインスタンスを経由して、トラフィックをVCN内部のサブネットからVCN外部の宛先にルーティングするためのルールを含む。VCNとの間でパケットの転送/ルーティングを制御するために、VCNのルートテーブルをカスタマイズすることができる。DHCPオプションは、インスタンスの起動時にインスタンスに自動的に提供される構成情報を指す。
【0037】
VCNのために構成されたセキュリティルールは、VCNのオーバーレイファイアウォールルールを表す。セキュリティルールは、受信ルールおよび送信ルールを含むことができ、(例えば、プロトコルおよびポートに基づいて)VCN内のインスタンスに出入りすることを許可されるトラフィックの種類を指定することができる。顧客は、特定の規則をステートフルまたはステートレスにするかを選択することができる。例えば、顧客は、送信元CIDR0.0.0.0/0および宛先TCPポート22を含むステートフル受信ルールを設定することによって、任意の場所から1組のインスタンスへの着信SSHトラフィックを許可することができる。セキュリティルールは、ネットワークセキュリティグループまたはセキュリティリストを使用して実装されてもよい。ネットワークセキュリティグループは、そのグループ内のリソースのみに適用されるセキュリティルールのセットからなる。一方、セキュリティリストは、そのセキュリティリストを使用するサブネット内の全てのリソースに適用されるルールを含む。VCNは、デフォルトセキュリティルールとデフォルトセキュリティリストを含んでもよい。VCNのために構成されたDHCPオプションは、VCN内のインスタンスが起動するときに自動的に提供される構成情報を提供する。
【0038】
特定の実施形態において、VCNの構成情報は、VCN制御プレーンによって決定され、記憶される。VCNの構成情報は、例えば、VCNに関連するアドレス範囲、VCN内のサブネットおよび関連情報、VCNに関連する1つ以上のVR、VCN内の計算インスタンスおよび関連VNIC、VCNに関連する種々の仮想化ネットワーク機能(例えば、VNIC、VR、ゲートウェイ)を実行するNVD、VCNの状態情報、および他のVCN関連情報を含んでもよい。特定の実施形態において、VCN配信サービスは、VCN制御プレーンによって記憶された構成情報またはその一部をNVDに公開する。配信された情報を用いて、NVDによって記憶および使用される情報(例えば、転送テーブル、ルーティングテーブルなど)を更新することによって、VCN内のコンピュートインスタンスとの間でパケットを転送することができる。
【0039】
特定の実施形態において、VCNおよびサブネットの作成は、VCN制御プレーン(CP)によって処理され、計算インスタンスの起動は、計算制御プレーンによって処理される。計算制御プレーンは、計算インスタンスの物理リソースを割り当て、次にVCN制御プレーンを呼び出して、VNICを作成し、計算インスタンスに接続するように構成される。また、VCN CPは、パケットの転送およびルーティング機能を実行するように構成されたVCNデータプレーンに、VCNデータマッピングを送信する。特定の実施形態において、VCN CPは、更新をVCNデータプレーンに提供するように構成された配信サービスを提供する。VCN制御プレーンの例は、図17、18、19および20(参照番号、1716、1816、1916および2016を参照)に示され、以下に説明される。
【0040】
顧客は、CSPIによってホストされているリソースを用いて、1つ以上のVCNを作成することができる。顧客VCN上に展開された計算インスタンスは、異なるエンドポイントと通信することができる。これらのエンドポイントは、CSPIによってホストされているエンドポイントおよびCSPL外部のエンドポイントを含むことができる。
【0041】
CSPIを用いてクラウドベースのサービスを実装するための様々な異なるアーキテクチャは、図1、2、3、4、5、17、18、19および21に示され、以下に説明される。図1は、特定の実施形態に従って、CSPIによってホストされているオーバーレイVCNまたは顧客VCNを示す分散環境100のハイレベル図である。図1に示された分散環境は、オーバーレイネットワーク内の複数の要素を含む。図1に示された分散環境100は、単なる例であり、特許請求された実施形態の範囲を不当に限定することを意図していない。多くの変形例、代替例、および修正例が可能である。例えば、いくつかの実装形態において、図1に示された分散環境は、図1に示されたものより多いまたは少ないシステムまたは要素を有してもよく、2つ以上のシステムを組み合わせてもよく、または異なるシステムの構成または配置を有してもよい。
【0042】
図1の例に示されたように、分散環境100は、顧客が加入して仮想クラウドネットワーク(VCN)を構築するために使用することができるサービスおよびリソースを提供するCSPI101を含む。特定の実施形態において、CSPI101は、加入顧客にIaaSサービスを提供する。CSPI101内のデータセンタは、1つ以上の地域に編成されてもよい。図1は、地域の一例である「US地域」102を示す。顧客は、地域102に対して顧客VCN104を構成している。顧客は、VCN104上に様々な計算インスタンスを展開することができ、計算インスタンスは、仮想マシンまたはベアメタルインスタンスを含むことができる。インスタンスの例は、アプリケーション、データベース、ロードバランサなどを含む。
【0043】
図1に示された実施形態において、顧客VCN104は、2つのサブネット、すなわち、「サブネット-1」および「サブネット-2」を含み、各サブネットは、各自のCIDR IPアドレス範囲を有する。図1において、サブネット-1のオーバーレイIPアドレス範囲は、10.0/16であり、サブネット-2のアドレス範囲は、10.1/16である。VCN仮想ルータ105は、VCN104のサブネット間の通信およびVCN外部の他のエンドポイントとの通信を可能にするVCNの論理ゲートウェイを表す。VCN VR105は、VCN104内のVNICとVCN104に関連するゲートウェイとの間でトラフィックをルーティングするように構成される。VCN VR105は、VCN104の各サブネットにポートを提供する。例えば、VR105は、IPアドレス10.0.0.1を有するポートをサブネット-1に提供することができ、IPアドレス10.1.0.1を有するポートをサブネット-2に提供することができる。
【0044】
各サブネット上に複数の計算インスタンスを展開することができる。この場合、計算インスタンスは、仮想マシンインスタンスおよび/またはベアメタルインスタンスであってもよい。サブネット内の計算インスタンスは、CSPI101内の1つ以上のホストマシンによってホストされてもよい。計算インスタンスは、当該計算インスタンスに関連するVNICを介してサブネットに参加する。例えば、図1に示すように、計算インスタンスC1は、当該計算インスタンスに関連するVNICを介したサブネット-1の一部である。同様に、計算インスタンスC2は、C2に関連するVNICを介したサブネット-1の一部である。同様に、仮想マシンインスタンスまたはベアメタルインスタンスであり得る複数の計算インスタンスは、サブネット-1の一部であってもよい。各計算インスタンスには、関連するVNICを介して、プライベートオーバーレイIPアドレスおよびMACアドレスが割り当てられる。例えば、図1において、計算インスタンスC1は、オーバーレイIPアドレス10.0.0.2およびMACアドレスM1を有し、計算インスタンスC2は、プライベートオーバーレイIPアドレス10.0.0.3およびMACアドレスM2を有する。計算インスタンスC1およびC2を含むサブネット-1内の各計算インスタンスは、サブネット-1のVCN VR105のポートのIPアドレスであるIPアドレス10.0.0.1を使用して、VCN VR105へのデフォルトルートを有する。
【0045】
サブネット-2には、仮想マシンインスタンスおよび/またはベアメタルインスタンスを含む複数の計算インスタンスを展開することができる。例えば、図1に示すように、計算インスタンスDlおよびD2は、それぞれの計算インスタンスに関連するVNICを介したサブネット-2の一部である。図1に示す実施形態において、計算インスタンスD1は、オーバーレイIPアドレス10.1.0.2およびMACアドレスMM1を有し、計算インスタンスD2は、プライベートオーバーレイIPアドレス10.1.0.3およびMACアドレスMM2を有する。計算インスタンスD1およびD2を含むサブネット-2内の各計算インスタンスは、サブネット-2のVCN VR105のポートのIPアドレスであるIPアドレス10.1.0.1を使用して、VCN VR105へのデフォルトルートを有する。
【0046】
また、VCN A104は、1つ以上のロードバランサを含んでもよい。例えば、ロードバランサは、サブネットに対して提供されてもよく、サブネット上の複数の計算インスタンス間でトラフィックをロードバランスするように構成されてもよい。また、ロードバランサは、VCN内のサブネット間でトラフィックをロードバランスするように提供されてもよい。
【0047】
VCN104上に展開された特定の計算インスタンスは、様々な異なるエンドポイントと通信することができる。これらのエンドポイントは、CSPI200によってホストされているエンドポイントと、CSPI200外部のエンドポイントとを含んでもよい。CSPI101によってホストされているエンドポイントは、特定の計算インスタンスと同じサブネット上のエンドポイント(例えば、サブネット-1の2つの計算インスタンス間の通信)、異なるサブネットにあるが同じVCN内のエンドポイント(例えば、サブネット-1の計算インスタンスとサブネット-2の計算インスタンスとの間の通信)、同じ地域の異なるVCN内のエンドポイント(例えば、サブネット-1の計算インスタンスと、同じ地域106または110のVCN内のエンドポイントとの間の通信、サブネット-1内の計算インスタンスと、同じ地域のサービスネットワーク110内のエンドポイントとの間の通信)、または異なる地域のVCN内のエンドポイント(例えば、サブネット-1の計算インスタンスと、異なる地域108のVCN内のエンドポイントとの間の通信)を含んでもよい。また、CSPI101によってホストされているサブネット内の計算インスタンスは、CSPI101によってホストされていない(すなわち、CSPI101の外部にある)エンドポイントと通信することができる。これらの外部のエンドポイントは、顧客オンプレミスネットワーク116内のエンドポイント、他のリモートクラウドホストネットワーク118内のエンドポイント、インターネットなどのパブリックネットワークを介してアクセス可能なパブリックエンドポイント114、および他のエンドポイントを含む。
【0048】
同じサブネット上の計算インスタンス間の通信は、送信元計算インスタンスおよび宛先計算インスタンスに関連するVNICを使用して促進される。例えば、サブネット-1内の計算インスタンスC1は、サブネット-1内の計算インスタンスC2にパケットを送信したいことがある。送信元計算インスタンスから送信され、その宛先が同じサブネット内の別の計算インスタンスであるパケットの場合、このパケットは、まず、送信元計算インスタンスに関連するVNICによって処理される。送信元計算インスタンスに関連するVNICによって実行される処理は、パケットヘッダからパケットの宛先情報を決定することと、送信元計算インスタンスに関連するVNICに対して構成された任意のポリシー(例えば、セキュリティリスト)を識別することと、パケットのネクストホップ(next hop)を決定することと、必要に応じて任意のパケットのカプセル化/カプセル除去機能を実行することと、パケットの意図した宛先への通信を容易にするためにパケットをネクストホップに転送/ルーティングすることとを含んでもよい。宛先計算インスタンスが送信元計算インスタンスと同じサブネットにある場合、送信元計算インスタンスに関連するVNICは、宛先計算インスタンスに関連するVNICを識別し、処理するためのパケットをそのVNICに転送するように構成されている。次いで、宛先計算インスタンスに関連するVNICは、実行され、パケットを宛先計算インスタンスに転送する。
【0049】
サブネット内の計算インスタンスから同じVCNの異なるサブネット内のエンドポイントにパケットを通信する場合、通信は、送信元計算インスタンスおよび宛先計算インスタンスに関連するVNICと、VCN VRとによって促進される。例えば、図1のサブネット-1の計算インスタンスC1がサブネット-2の計算インスタンスD1にパケットを送信したい場合、パケットは、まず、計算インスタンスC1に関連するVNICによって処理される。計算インスタンスC1に関連するVNICは、VCN VRのデフォルトルートまたはポート10.0.0.1を使用して、パケットをVCN VR105にルーティングするように構成されている。VCN VR105は、ポート10.1.0.1を使用してパケットをサブネット-2にルーティングするように構成されている。その後、パケットは、D1に関連するVNICによって受信および処理され、VNICは、パケットを計算インスタンスD1に転送する。
【0050】
VCN104内の計算インスタンスからVCN104の外部のエンドポイントにパケットを通信するために、通信は、送信元計算インスタンスに関連するVNIC、VCN VR105、およびVCN104に関連するゲートウェイによって促進される。1つ以上の種類のゲートウェイをVCN104に関連付けることができる。ゲートウェイは、VCNと別のエンドポイントとの間のインターフェースであり、別のエンドポイントは、VCNの外部にある。ゲートウェイは、レイヤ3/IPレイヤ概念であり、VCNとVCNの外部のエンドポイントとの通信を可能にする。したがって、ゲートウェイは、VCNと他のVCNまたはネットワークとの間のトラフィックフローを容易にする。異なる種類のエンドポイントとの異なる種類の通信を容易にするために、様々な異なる種類のゲートウェイをVCNに設定することができる。ゲートウェイによって、通信は、パブリックネットワーク(例えば、インターネット)またはプライベートネットワークを介して行われてもよい。これらの通信には、様々な通信プロトコルを使用してもよい。
【0051】
例えば、計算インスタンスC1は、VCN104の外部のエンドポイントと通信したい場合がある。パケットは、まず、送信元計算インスタンスC1に関連するVNICによって処理されてもよい。VNIC処理は、パケットの宛先がClのサブネット-1の外部にあると判断する。C1に関連するVNICは、パケットをVCN104のVCN VR105に転送することができる。次いで、VCN VR105は、パケットを処理し、処理の一部として、パケットの宛先に基づいて、VCN104に関連する特定のゲートウェイをパケットのネクストホップとして決定する。その後、VCN VR105は、パケットを特定のゲートウェイに転送することができる。例えば、宛先が顧客のオペプレミスネットワーク内のエンドポイントである場合、パケットは、VCN VR105によって、VCN104のために構成された動的ルーティングゲートウェイ(DRG)122に転送されてもよい。その後、パケットは、ゲートウェイからネクストホップに転送され、意図した最終の宛先へのパケットの通信を容易にすることができる。
【0052】
VCNのために様々な異なる種類のゲートウェイを構成してもよい。VCNのために構成され得るゲートウェイの例は、図1に示され、以下に説明される。VCNに関連するゲートウェイの例は、図17、18、19および20(例えば、参照番号1734、1736、1738、1834、1836、1838、1934、1936、1938、2034、2036、および2038によって示されたゲートウェイ)にも示され、以下に説明される。図1に示された実施形態に示されるように、動的ルーティングゲートウェイ(DRG)122は、顧客VCN104に追加されてもよく、またはそれに関連付けられてもよい。DRG122は、顧客VCN104と別のエンドポイントとの間のプライベートネットワークトラフィック通信を行うための経路を提供する。別のエンドポイントは、顧客オンプレミスネットワーク116、CSPI101の異なる地域内のVCN108、またはCSPI101によってホストされていない他のリモートクラウドネットワーク118であってもよい。顧客オンプレミスネットワーク116は、顧客のリソースを用いて構築された顧客ネットワークまたは顧客データセンタであってもよい。顧客オンプレミスネットワーク116へのアクセスは、一般的に厳しく制限される。顧客オンプレミスネットワーク116と、CSPI101によってクラウドに展開またはホストされる1つ以上のVCN104との両方を有する顧客の場合、顧客は、オンプレミスネットワーク116およびクラウドベースのVCN104が互いに通信できることを望む場合がある。これによって、顧客は、CSPI101によってホストされている顧客のVCN104とオンプレミスネットワーク116とを含む拡張ハイブリッド環境を構築することができる。DRG122は、このような通信を可能にする。このような通信を可能にするために、通信チャネル124が設定される。この場合、通信チャネルの一方のエンドポイントは、顧客オンプレミスネットワーク116にあり、他方のエンドポイントは、CSPI101にあり、顧客VCN104に接続されている。通信チャネル124は、インターネットなどのパブリック通信ネットワーク、またはプライベート通信ネットワークを経由することができる。インターネットなどのパブリック通信ネットワーク上のIPsec VPN技術、パブリックネットワークの代わりにプライベートネットワークを使用するオラクル(登録商標)のFastConnect技術などの様々な異なる通信プロトコルを使用することができる。通信チャネル124の1つのエンドポイントを形成する顧客オンプレミスネットワーク116内の装置または機器は、図1に示されたCPE126などの顧客構内機器(CPE)と呼ばれる。CSPI101側のエンドポイントは、DRG122を実行するホストマシンであってもよい。
【0053】
特定の実施形態において、リモートピアリング接続(RPC)をDRGに追加することができる。これによって、顧客は、1つのVCNを別の地域内の別のVCNとピアリングすることができる。このようなRPCを使用して、顧客VCN104は、DRG122を使用して、別の地域内のVCN108に接続することができる。また、DRG122は、CSPI101によってホストされていない他のリモートクラウドネットワーク118、例えば、マイクロソフト(登録商標)Azureクラウド、アマゾン(登録商標)AWSクラウドと通信するために使用されてもよい。
【0054】
図1に示すように、顧客VCN104上の計算インスタンスがインターネットなどのパブリックネットワークを介してアクセス可能なパブリックエンドポイント114と通信することを可能にするように、顧客VCN104にインターネットゲートウェイ(IGW)120を構成することができる。IGW1120は、VCNをインターネットなどのパブリックネットワークに接続するためのゲートウェイである。IGW120は、VCN104などのVCN内のパブリックサブネット(パブリックサブネット内のリソースは、パブリックオーバーレイIPアドレスを有する)がインターネットなどのパブリックネットワーク114上のパブリックエンドポイント112に直接アクセスすることを可能にする。IGW120を使用して、VCN104内のサブネットからまたはインターネットからの接続を開始することができる。
【0055】
顧客VCN104にネットワークアドレス変換(NAT)ゲートウェイ128を構成することができる。NATゲートウェイ128は、顧客VCN内の専用のパブリックオーバーレイIPアドレスを有しないクラウドリソースを、直接着信インターネット接続(例えば、L4-L7接続)に曝すことなくインターネットにアクセスすることを可能にする。これによって、VCN104のプライベートサブネット-1などのVCN内のプライベートサブネットがインターネット上のパブリックエンドポイントにプライベートアクセスすることを可能にする。NATゲートウェイにおいて、プライベートサブネットからパブリックインターネットに接続を開始することができるが、インターネットからプライベートサブネットに接続を開始することができない。
【0056】
特定の実施形態において、顧客VCN104にサービスゲートウェイ(SGW)126を構成することができる。SGW126は、VCN104とサービスネットワーク110にサポートされているサービスエンドポイントとの間のプライベートネットワークトラフィックの経路を提供する。特定の実施形態において、サービスネットワーク110は、CSPによって提供されてもよく、様々なサービスを提供することができる。このようなサービスネットワークの例は、顧客が使用できる様々なサービスを提供するオラクル(登録商標)サービスネットワークである。例えば、顧客VCN104のプライベートサブネット内の計算インスタンス(例えば、データベースシステム)は、パブリックIPアドレスまたはインターネットへのアクセスを必要とすることなく、サービスエンドポイント(例えば、オブジェクト記憶装置)にデータをバックアップすることができる。いくつかの実施形態において、VCNは、1つのみのSGWを有することができ、VCN内のサブネットのみから接続を開始することができ、サービスネットワーク110から接続を開始することができない。VCNを他のVCNにピアリングする場合、他のVCN内のリソースは、通常SGWにアクセスすることができない。FastConnectまたはVPN ConnectでVCNに接続されているオンプレミスネットワーク内のリソースも、そのVCNに構成されたサービスゲートウェイを使用することができる。
【0057】
いくつかの実装形態において、SGW126は、サービスクラスレスドメイン間ルーティング(CIDR)ラベルを使用する。CIDRラベルは、関心のあるサービスまたはサービスのグループに対する全ての地域公開IPアドレス範囲を表す文字列である。顧客は、SGWおよび関連するルーティングルールを設定する際に、サービスCIDRラベルを使用してサービスへのトラフィックを制御する。顧客は、サービスのパブリックIPアドレスが将来に変化する場合、セキュリティルールを調整する必要なく、セキュリティルールを設定するときにオプションとしてサービスCIDRラベルを使用することができる。
【0058】
ローカルピアリングゲートウェイ(LPG)132は、顧客VCN104に追加可能なゲートウェイであり、VCN104が同じ地域内の別のVCNとピアリングすることを可能にするものである。ピアリングとは、トラフィックがインターネットなどのパブリックネットワークを経由することなく、または顧客オンプレミスネットワーク116を通してトラフィックをルーティングすることなく、VCNがプライベートIPアドレスを使用して通信することを意味する。好ましい実施形態において、VCNは、確立した各ピアリングに対して個別のLPGを有する。ローカルピアリングまたはVCNピアリングは、異なるアプリケーション間またはインフラストラクチャ管理機能間のネットワーク接続を確立するために使用される一般的な慣行である。
【0059】
サービスネットワーク110のサービスのプロバイダなどのサービスプロバイダは、異なるアクセスモデルを使用してサービスへのアクセスを提供することができる。パブリックアクセスモデルによれば、サービスは、インターネットなどのパブリックネットワークを介して顧客VCN内の計算インスタンスによって公的にアクセス可能なパブリックエンドポイントとして公開されてもよく、またはSGW126を介してプライベートにアクセスされてもよい。特定のプライベートアクセスモデルによれば、サービスは、顧客VCN内のプライベートサブネット内のプライベートIPエンドポイントとしてアクセスされてもよい。これは、プライベートエンドポイント(PE)アクセスと呼ばれ、サービスプロバイダがそのサービスを顧客のプライベートネットワーク内のインスタンスとして公開することを可能にする。プライベートエンドポイントリソースは、顧客VCN内のサービスを表す。各PEは、顧客が顧客VCN内のサブネットから選択したVNIC(PE-VNICと呼ばれ、1つまたは複数のプライベートIPを持つ)として現れる。従って、PEは、VNICを使用して顧客のプライベートVCNサブネット内でサービスを提供する方法を提供する。エンドポイントがVNICとして公開されるため、PE VNICは、VNICに関連する全ての機能、例えば、ルーティングルールおよびセキュリティリストなどを利用することができる。
【0060】
サービスプロバイダは、サービスを登録することによって、PEを介したアクセスを可能にする。プロバイダは、顧客テナントへのサービスの表示を規制するポリシーをサービスに関連付けることができる。プロバイダは、特にマルチテナントサービスの場合、単一の仮想IPアドレス(VIP)の下に複数のサービスを登録することができる。(複数のVCNにおいて)同じサービスを表すプライベートエンドポイントが複数存在する場合もある。
【0061】
その後、プライベートサブネット内の計算インスタンスは、PE VNICのプライベートIPアドレスまたはサービスDNS名を用いて、サービスにアクセスすることができる。顧客VCN内の計算インスタンスは、顧客VCN内のPEのプライベートIPアドレスにトラフィックを送信することによって、サービスにアクセスすることができる。プライベートアクセスゲートウェイ(PAGW)130は、顧客サブネットプライベートエンドポイントから/への全てのトラフィックの受信ポイント/送信ポイントとして機能するサービスプロバイダVCN(例えば、サービスネットワーク110内のVCN)に接続できるゲートウェイリソースである。PAGW130によって、プロバイダは、内部IPアドレスリソースを利用することなく、PE接続の数を拡張することができる。プロバイダは、単一のVCNに登録された任意の数のサービスに対して1つのPAGWを設定するだけでよい。プロバイダは、1人以上の顧客の複数のVCNにおいて、サービスをプライバシーエンドポイントとして示すことができる。顧客の観点から、PE VNICは、顧客のインスタンスに接続されているのではなく、顧客が対話したいサービスに接続されているように見える。プライベートエンドポイントに向けられたトラフィックは、PAGW130を介してサービスにルーティングされる。これらは、顧客対サービスプライベート接続(C2S接続)と呼ばれる。
【0062】
また、PE概念を用いて、トラフィックがFastConnect/IPsecリンクおよび顧客VCN内のプライベートエンドポイントを通って流れることを可能にすることで、サービスのプライベートアクセスを顧客オンプレミスネットワークおよびデータセンタに拡張することもできる。また、トラフィックがLPG132および顧客VCN内のPE間を通って流れることを可能にすることで、サービスのプライベートアクセスを顧客ピアリングVCNに拡張することもできる。
【0063】
顧客は、サブネットレベルでVCNのルーティングを制御することができるため、VCN104などの顧客VCNにおいて各ゲートウェイを使用するサブネットを指定することができる。VCNのルートテーブルを用いて、特定のゲートウェイを介してトラフィックをVCNの外部にルーティングできるか否かを判断することができる。例えば、特定の事例において、顧客VCN104内のパブリックサブネットのルートテーブルは、IGW120を介して非ローカルトラフィックを送信することができる。同じ顧客VCN104内のプライベートサブネットのルートテーブルは、SGW126を介してCSPサービスへのトラフィックを送信することができる。残りの全てのトラフィックは、NATゲートウェイ128を介して送信されてもよい。ルートテーブルは、VCNから出るトラフィックのみを制御する。
【0064】
VCNに関連するセキュリティリストは、インバウンド接続およびゲートウェイを介してVCNに入来するトラフィックを制御するために使用される。サブネット内の全てのリソースは、同じミュートテーブルおよびセキュリティリストを使用する。セキュリティリストは、VCNのサブネット内のインスタンスに出入りする特定の種類のトラフィックを制御するために使用されてもよい。セキュリティリストルールは、受信(インバウンド)ルールと、送信(アウトバウンド)ルールとを含んでもよい。例えば、受信ルールは、許可された送信元アドレス範囲を指定することができ、送信ルールは、許可された宛先アドレス範囲を指定することができる。セキュリティルールは、特定のプロトコル(例えば、TCP、ICMP)、特定のポート(例えば、SSHの場合ポート22、ウィンドウズ(登録商標)RDPの場合ポート3389)などを指定することができる。特定の実装形態において、インスタンスのオペレーティングシステムは、セキュリティリストルールと一致する独自のファイアウォールルールを実施することができる。ルールは、ステートフル(例えば、接続が追跡され、応答トラフィックに対する明示的なセキュリティのリストルールなしで応答が自動的に許可される)またはステートレスであってもよい。
【0065】
顧客VCN(すなわち、VCN104上に展開されたリソースまたは計算インスタンス)からのアクセスは、パブリックアクセス、プライベートアクセス、または専用アクセスとして分類されることができる。パブリックアクセスは、パブリックIPアドレスまたはNATを用いてパブリックエンドポイントにアクセスするためのアクセスモデルを指す。プライベートアクセスは、プライベートIPアドレス(例えば、プライベートサブネット内のリソース)を持つVCN104内の顧客ワークロードが、インターネットなどのパブリックネットワークを経由することなく、サービスにアクセスすることを可能にする。特定の実施形態において、CSPI101は、プライベートIPアドレスを持つ顧客VCNワークロードが、サービスゲートウェイを使用して、サービスのパブリックサービスエンドポイントにアクセスすることを可能にする。したがって、サービスゲートウェイは、顧客VCNと顧客プライベートネットワークの外部に存在するサービスのパブリックエンドポイントとの間に仮想リンクを確立することによって、プライベートアクセスモデルを提供する。
【0066】
さらに、CSPIは、FastConnectパブリックピアリングなどの技術を使用する専用パブリックアクセスを提供することができる。この場合、顧客オンプレミスインスタンスは、インターネットなどのパブリックネットワークを経由することなく、FastConnect接続を用いて顧客VCN内の1つ以上のサービスにアクセスすることができる。また、CSPIは、FastConnectプライベートピアリングを使用する専用プライベートアクセスを提供することもできる。この場合、プライベートIPアドレスを持つ顧客オンプレミスインスタンスは、FastConnect接続を用いて顧客VCNワークロードにアクセスすることができる。FastConnectは、パブリックインターネットを用いて顧客オンプレミスネットワークをCSPIおよびそのサービスに接続する代わりに使用されるネットワーク接続である。FastConnectは、インターネットベースの接続と比較して、より高い帯域幅オプションと信頼性の高い一貫したネットワーキング体験を持つ専用のプライベート接続を、簡単、柔軟且つ経済的に作成する方法を提供する。
【0067】
図1および上記の添付の説明は、例示的な仮想ネットワークにおける様々な仮想化要素を説明する。上述したように、仮想ネットワークは、基礎となる物理ネットワークまたは基板ネットワーク上に構築される。図2は、特定の実施形態に従って、仮想ネットワークの基盤を提供するCSPI200内の物理ネットワーク内の物理要素を示す簡略化アーキテクチャ図である。図示のように、CSPI200は、クラウドサービスプロバイダ(CSP)によって提供された要素およびリソース(例えば、計算リソース、メモリリソース、およびネットワーキングリソース)を含む分散環境を提供する。これらの要素およびリソースは、加入している顧客、すなわち、CSPによって提供された1つ以上のサービスに加入している顧客にクラウドサービス(例えば、IaaSサービス)を提供するために使用される。顧客が加入しているサービスに基づいて、CSPI200は、一部のリソース(例えば、計算リソース、メモリリソース、およびネットワーキングリソース)を顧客に提供する。その後、顧客は、CSPI200によって提供された物理的な計算リソース、メモリリソース、およびネットワーキングリソースを使用して、独自のクラウドベースの(すなわち、CSPIホスト型)カスタマイズ可能なプライベート仮想ネットワークを構築することができる。前述したように、これらの顧客ネットワークは、仮想クラウドネットワーク(VCN)と呼ばれる。顧客は、これらの顧客VCNに、計算インスタンスなどの1つ以上の顧客リソースを展開することができる。計算インスタンスは、仮想マシン、ベアメタルインスタンスなどであってもよい。CSPI200は、顧客が高可用性のホスト環境において広範なアプリケーションおよびサービスを構築および実行することを可能にする、インフラストラクチャおよび一連の補完的なクラウドサービスを提供する。
【0068】
図2に示す例示的な実施形態において、CSPI200の物理要素は、1つ以上の物理ホストマシンまたは物理サーバ(例えば、202、206、208)、ネットワーク仮想化デバイス(NVD)(例えば、210、212)、トップオブラック(TOR)スイッチ(例えば、214、216)、物理ネットワーク(例えば、218)、および物理ネットワーク218内のスイッチを含む。物理ホストマシンまたはサーバは、VCNの1つ以上のサブネットに参加している様々な計算インスタンスをホストし、実行することができる。計算インスタンスは、仮想マシンインスタンスおよびベアメタルインスタンスを含んでもよい。例えば、図1に示された様々な計算インスタンスは、図2に示された物理的ホストマシンによってホストされてもよい。VCN内の仮想マシン計算インスタンスは、1つのホストマシンによって実行されてもよく、または複数の異なるホストマシンによって実行されてもよい。また、物理ホストマシンは、仮想ホストマシン、コンテナベースのホストまたは機能などをホストすることができる。図1に示されたVICおよびVCN VRは、図2に示されたFTVDによって実行されてもよい。図1に示されたゲートウェイは、図2に示されたホストマシンおよび/またはNVDによって実行されてもよい。
【0069】
ホストマシンまたはサーバは、ホストマシン上で仮想化環境を作成するおよび可能にするハイパーバイザ(仮想マシンモニタまたはVMMとも呼ばれる)を実行することができる。仮想化または仮想化環境は、クラウドベースコンピューティングを容易にする。1つ以上の計算インスタンスは、ホストマシン上のハイパーバイザによって、ホストマシン上で作成され、実行され、管理されてもよい。ホストマシン上のハイパーバイザは、ホストマシンの物理的な計算リソース(例えば、計算リソース、メモリリソース、およびネットワーキングリソース)をホストマシン上で実行される様々な計算インスタンス間で共有させることができる。
【0070】
例えば、図2に示すように、ホストマシン202および208は、ハイパーバイザ260および266をそれぞれ実行する。これらのハイパーバイザは、ソフトウェア、ファームウエア、ハードウェア、またはそれらの組み合わせを使用して実装されてもよい。典型的には、ハイパーバイザは、ホストマシンのオペレーティングシステム(OS)に常駐するプロセスまたはソフトウェア層であり、OSは、ホストマシンのハードウエアプロセッサ上で実行される。ハイパーバイザは、ホストマシンの物理的な計算リソース(例えば、プロセッサ/コア、メモリリソース、ネットワーキングリソースなどの処理リソース)を、ホストマシンによって実行される様々な仮想マシン計算インスタンスの間で共有させる仮想化環境を提供する。例えば、図2において、ハイパーバイザ260は、ホストマシン202のOSに常駐し、ホストマシン202の計算リソース(例えば、処理リソース、メモリリソース、およびネットワーキングリソース)を、ホストマシン202によって実行されるコンピューティングインスタンス(例えば、仮想マシン)間で共有させることができる。仮想マシンは、独自のOS(ゲストOSと呼ばれる)を持つことができる。このゲストOSは、ホストマシンのOSと同じであってもよく、異なってもよい。ホストマシンによって実行される仮想マシンのOSは、同じホストマシンによって実行される他の仮想マシンのOSと同じであってもよく、異なってもよい。したがって、ハイパーバイザは、ホストマシンの同じ計算リソースを共有させながら、複数のOSを並行して実行することができる。図2に示されたホストマシンは、同じ種類のハイパーバイザを有してもよく、異なる種類のハイパーバイザを有してもよい。
【0071】
計算インスタンスは、仮想マシンインスタンスまたはベアメタルインスタンスであってもよい。図2において、ホストマシン202上の計算インスタンス268およびホストマシン208上の計算インスタンス274は、仮想マシンインスタンスの一例である。ホストマシン206は、顧客に提供されるベアメタルインスタンスの一例である。
【0072】
特定の例において、ホストマシンの全体は、単一の顧客に提供されてもよく、そのホストマシンによってホストされている1つ以上の計算インスタンス(仮想マシンまたはベアメタルインスタンスのいずれか)は、全て同じ顧客に属してもよい。他の例において、ホストマシンは、複数の顧客(すなわち、複数のテナント)間で共有されてもよい。このようなマルチテナントシナリオにおいて、ホストマシンは、異なる顧客に属する仮想マシン計算インスタンスをホストすることができる。これらの計算インスタンスは、異なる顧客の異なるVCNのメンバであってもよい。特定の実施形態において、ベアメタル計算インスタンスは、ハイパーバイザを設けていないベアメタルサーバによってホストされている。ベアメタル計算インスタンスが提供される場合、単一の顧客またはテナントは、ベアメタルインスタンスをホストするホストマシンの物理CPU、メモリ、およびネットワークインターフェースの制御を維持し、ホストマシンは、他の顧客またはテナントに共有されない。
【0073】
前述したように、VCNの一部である各計算インスタンスは、計算インスタンスがVCNのサブネットのメンバになることを可能にするVNICに関連付けられる。計算インスタンスに関連付けられたVNICは、計算インスタンスとの間のパケットまたはフレームの通信を容易にする。VNICは、計算インスタンスが作成されるときに当該計算インスタンスに関連付けられる。特定の実施形態において、ホストマシンによって実行される計算インスタンスについて、その計算インスタンスに関連付けられたVNICは、ホストマシンに接続されたNVDによって実行される。例えば、図2において、ホストマシン202は、VNIC276に関連付けられた仮想マシン計算インスタンス268を実行し、VNIC276は、ホストマシン202に接続されたNVD210によって実行される。別の例として、ホストマシン206によってホストされているベアメタルインスタンス272は、ホストマシン206に接続されたNVD212によって実行されるVNIC280に関連付けられる。さらに別の例として、VNIC284は、ホストマシン208によって実行される計算インスタンス274に関連付けられ、VNIC284は、ホストマシン208に接続されているNVD212によって実行される。
【0074】
ホストマシンによってホストされている計算インスタンスについて、そのホストマシンに接続されたNVDは、計算インスタンスがメンバであるVCNに対応するVCN VRを実行する。例えば、図2に示された実施形態において、NVD210は、計算インスタンス268がメンバであるVCNに対応するVCN VR277を実行する。また、NVD212は、ホストマシン206および208によってホストされている計算インスタンスに対応するVCNに対応する1つ以上のVCN VR283を実行することができる。
【0075】
ホストマシンは、当該ホストマシンを他の装置に接続するための1つ以上のネットワークインターフェイスカード(NIC)を含むことができる。ホストマシン上のNICは、ホストマシンを別の装置に通信可能に接続するための1つ以上のポート(またはインターフェイス)を提供することができる。例えば、ホストマシンおよびNVDに設けられた1つ以上のポート(またはインターフェイス)を用いて、当該ホストマシンを当該NVDに接続することができる。また、ホストマシンを他のホストマシンなどの他の装置に接続することもできる。
【0076】
例えば、図2において、ホストマシン202は、ホストマシン202のNIC232によって提供されるポート234とNVD210のポート236との間に延在するリンク220を使用してNVD210に接続されている。ホストマシン206は、ホストマシン206のNIC244によって提供されるポート246とNVD212のポート248との間に延在するリンク224を使用してNVD212に接続されている。ホストマシン208は、ホストマシン208のNIC250によって提供されるポート252とNVD212のポート254との間に延在するリンク226を使用してNVD212に接続されている。
【0077】
同様に、NVDは、通信リンクを介して、(スイッチファブリックとも呼ばれる)物理ネットワーク218に接続されているトップオブラック(TOR)スイッチに接続されている。特定の実施形態において、ホストマシンとNVDとの間のリンクおよびNVDとTORスイッチとの間のリンクは、イーサネット(登録商標)リンクである。例えば、図2において、NVD210および212は、リンク228および230を介して、TORスイッチ214および216にそれぞれ接続される。特定の実施形態において、リンク220、224、226、228、および230は、イーサネット(登録商標)リンクである。TORに接続されているホストマシンおよびNVDの集合体は、ラックと呼ばれることがある。
【0078】
物理ネットワーク218は、TORスイッチの相互通信を可能にする通信ファブリックを提供する。物理ネットワーク218は、多層ネットワークであってもよい。特定の実装形態において、物理ネットワーク218は、スイッチの多層Closネットワークであり、TORスイッチ214および216は、多層およびマルチノード物理スイッチングネットワーク218のリーフレベルノードを表す。2層ネットワーク、3層ネットワーク、4層ネットワーク、5層ネットワーク、および一般に「n」層ネットワークを含むがこれらに限定されない異なるClosネットワーク構成は、可能である。CIosネットワークの一例は、図5に示され、以下に説明される。
【0079】
ホストマシンとN個のVDとの間には、1対1構成、多対1構成、および1対多構成などの様々な異なる接続構成が可能である。1対1構成の実装例において、各ホストマシンは、それ自体の別個のNVDに接続されている。例えば、図2において、ホストマシン202は、ホストマシン202のNIC232を介してNVD210に接続されている。多対1の構成において、複数のホストマシンは、1つのNVDに接続されている。例えば、図2において、ホストマシン206および208は、それぞれNIC244および250を介して同じNVD212に接続されている。
【0080】
1対多の構成において、1つのホストマシンは、複数のNVDに接続されている。図3は、ホストマシンが複数のNVDに接続されているCSPI300内の一例を示す。図3に示すように、ホストマシン302は、複数のポート306および30Sを含むネットワークインターフェースカード(NIC)304を備える。ホストマシン300は、ポート306およびリンク320を介して第1のNVD310に接続され、ポート308およびリンク322を介して第2のNVD312に接続されている。ポート306および308は、イーサネット(登録商標)ポートであってもよく、ホストマシン302とNVD310および312との間のリンク320および322は、イーサネット(登録商標)リンクであってもよい。NVD310は、第1のTORスイッチ314に接続され、NVD312は、第2のTORスイッチ316に接続されている。NVD310および312とTORスイッチ314および316との間のリンクは、イーサネット(登録商標)リンクであってもよい。TORスイッチ314および316は、多層物理ネットワーク318内の層-0スイッチング装置を表す。
【0081】
図3に示す構成は、物理スイッチネットワーク318からホストマシン302への2つの別々の物理ネットワーク経路、すなわち、TORスイッチ314からNVD310を経由してホストマシン302への第1の経路と、TORスイッチ316からNVD312を経由してホストマシン302への第2の経路とを提供する。別々の経路は、ホストマシン302の強化された可用性(高可用性と呼ばれる)を提供する。経路の一方に問題がある(例えば、経路の一方のリンクが故障する)場合または装置に問題がある(例えば、特定のNVDが機能していない)場合、ホストマシン302との間の通信に他方の経路を使用することができる。
【0082】
図3に示された構成において、ホストマシンは、ホストマシンのNICによって提供された2つの異なるポートを用いて2つの異なるNVDに接続されている。他の実施形態において、ホストマシンは、ホストマシンと複数のNVDとの接続を可能にする複数のNICを含んでもよい。
【0083】
再び図2を参照して、NVDは、1つ以上のネットワーク仮想化機能および/または記憶仮想化機能を実行する物理装置または要素である。NVDは、1つ以上の処理ユニット(例えば、CPU、ネットワーク処理ユニット(NPU)、FPGA、パケット処理パイプライン)、キャッシュを含むメモリ、およびポートを有する任意の装置であってもよい。様々な仮想化機能は、NVDの1つ以上の処理ユニットによって実行されるソフトウェア/ファームウエアによって実行されてもよい。
【0084】
NVDは、様々な異なる形で実装されてもよい。例えば、特定の実施形態において、NVDは、内蔵プロセッサを搭載したスマートNICまたはインテリジェントNICと呼ばれるインターフェイスカードとして実装される。スマートNICは、ホストマシン上のNICとは別個の装置である。図2において、NVD210は、ホストマシン202に接続されているスマートNICとして実装されてもよく、NVD212は、ホストマシン206および208に接続されているスマートNICとして実装されてもよい。
【0085】
しかしながら、スマートNICは、NVD実装の一例にすぎない。様々な他の実装が可能である。例えば、いくつかの他の実装例において、NVDまたはNVDによって実行される1つ以上の機能は、CSPI200の1つ以上のホストマシン、1つ以上のTORスイッチ、および他の要素に組み込まれてもよく、またはそれらによって実行されてもよい。例えば、NVDは、ホストマシンに統合されてもよい。この場合、NVDによって実行される機能は、ホストマシンによって実行される。別の例として、NVDは、TORスイッチの一部であってもよく、またはTORスイッチは、TORスイッチがパブリッククラウドに使用される様々な複雑なパケット変換を実行することを可能にするNVDによって実行される機能を実行するように構成されてもよい。NVDの機能を実行するTORは、スマートTORと呼ばれることがある。ベアメタル(BM)インスタンスではなく仮想マシン(VM)インスタンスを顧客に提供するさらに他の実装形態において、NVDによって提供される機能は、ホストマシンのハイパーバイザの内部に実装されてもよい。いくつかの他の実装形態において、NVDの機能の一部は、一組のホストマシン上で動作する集中型サービスにオフロードされてもよい。
【0086】
図2に示すように、スマートNICとして実装される場合などの特定の実施形態において、NVDは、当該NVDを1つ以上のホストマシンおよび1つ以上のTORスイッチに接続することを可能にする複数の物理ポートを備えてもよい。NVD上のポートは、ホスト向きポート(「サウスポート」(south port)とも呼ばれる)またはネットワーク向きもしくはTOR向きポート(「ノースポート」(north port)とも呼ばれる)に分類することができる。NVDのホスト向きポートは、NVDをホストマシンに接続するために使用されるポートである。図2においてホスト向きポートの例は、NVD210のポート236、およびNVD212のポート248および254を含む。NVDのネットワーク向きポートは、NVDをTORスイッチに接続するために使用されるポートである。図2のネットワーク向きポートの例は、NVD210のポート256、およびNVD212のポート258を含む。図2に示すように、NVD210は、NVD210のポート256からTORスイッチ214まで延びるリンク228を介してTORスイッチ214に接続されている。同様に、NVD212は、NVD212のポート258からTORスイッチ216まで延びるリンク230を介してTORスイッチ216に接続されている。
【0087】
NVDは、ホスト向きポートを介して、ホストマシンからパケットおよびフレーム(例えば、ホストマシンによってホストされている計算インスタンスによって生成されたパケットおよびフレーム)を受信し、必要なパケット処理を実行した後、NVDのネットワーク向きポートを介してパケットおよびフレームをTORスイッチに転送することができる。NVDは、NVDのネットワーク向きポートを介してTORスイッチからパケットおよびフレームを受信し、必要なパケット処理を実行した後、NVDのホスト向きポートを介してパケットおよびフレームをホストマシンに転送することができる。
【0088】
特定の実施形態において、NVDとTORスイッチとの間に複数のポートおよび関連するリンクを設けてもよい。これらのポートおよびリンクを集約することによって、複数のポートまたはリンクのリンクアグリゲータグループ(LAGと称される)を形成することができる。リンクの集約は、2つのエンドポイント間(例えば、NVDとTORスイッチとの間)の複数の物理リンクを単一の論理リンクとして扱うことを可能にする。所定のLAG内の全ての物理リンクは、同じ速度で全二重モードで動作することができる。LAGは、2つのエンドポイント間の接続の帯域幅および信頼性を高めるのに役立つ。LAG内の物理リンクのうちの1つが故障した場合、トラフィックは、LAG内の別の物理リンクに動的かつ透過的に再割り当てられる。集約された物理リンクは、個々のリンクよりも高い帯域幅を提供する。LAGに関連付けられた複数のポートは、単一の論理ポートとして扱われる。トラフィックをLAGの複数の物理リンクに負荷分散することができる。2つのエンドポイント間に1つ以上のLAGを構成することができる。2つのエンドポイントは、例えば、NVDとTORスイッチとの間にあってもよく、ホストマシンとNVDとの間にであってもよい。
【0089】
NVDは、ネットワーク仮想化機能を実装または実行する。これらの機能は、NVDによって実行されるソフトウェア/ファームウエアによって実行される。ネットワーク仮想化機能の例は、限定されないが、パケットのカプセル化およびカプセル化解除機能、VCNネットワークを作成するための機能、VCNセキュリティリスト(ファイアウォール)機能などのネットワークポリシーを実装するための機能、VCN内の計算インスタンスとの間のパケットのルーティングおよび転送を容易にするための機能などを含む。特定の実施形態において、パケットを受信すると、NVDは、パケットを処理し、パケットをどのように転送またはルーティングするかを判断するパケット処理パイプラインを実行するように構成されている。このパケット処理パイプラインの一部として、NVDは、VCN内のシス(cis)に関連するVNICの実行、VCNに関連する仮想ルータ(VR)の実行、仮想ネットワーク内の転送またはルーティングを容易にするためのパケットのカプセル化およびカプセル解除、特定のゲートウェイ(例えば、ローカルピアリングゲートウェイ)の実行、セキュリティリストの実装、ネットワークセキュリティグループ、ネットワークアドレス変換(NAT)機能(例えば、ホスト毎にパブリックIPからプライベートIPへの変換)、スロットリング機能、および他の機能を提供する。
【0090】
いくつかの実施形態において、NVDにおけるパケット処理データ経路は、複数のパケットパイプラインを含んでもよい。各々のパケットパイプラインは、一連のパケット変換ステージから構成される。いくつかの実装形態において、パケットを受信すると、当該パケットは、解析され、単一のパイプラインに分類される。次いで、パケットは、破棄されるまたはNVDのインターフェースを介して送出されるまで、線形方式でステージ毎に処理される。これらのステージは、基本機能のパケット処理ビルディングブロック(例えば、ヘッダの検証、スロットルの実行、新しいレイヤ2ヘッダの挿入、L4ファイアウォールの実行、VCNカプセル化/カプセル解除)を提供し、その結果、既存のステージを組み立てることによって新しいパイプラインを構築することができ、新しいステージを作成して既存のパイプラインに挿入することによって新しい機能を追加することができる。
【0091】
NVDは、VCNの制御プレーンおよびデータプレーンに対応する制御プレーン機能およびデータプレーン機能の両方を実行することができる。VCN制御プレーンの例は、図17、18、19および20(参照番号1716、1816、1916および2016参照)に示され、以下に説明される。VCNデータプレーンの例は、図17、18、19および20(参照番号1718、1818、1918および2018参照)に示され、以下に説明される。制御プレーン機能は、データをどのように転送するかを制御するためのネットワークの構成(例えば、ルートおよびルートテーブルの設定、VNICの構成)に使用される機能を含む。特定の実施形態において、全てのオーバーレイと基板とのマッピングを集中的に計算し、NVDおよび仮想ネットワークエッジ装置(例えば、DRG、SGW、IGWなどの様々なゲートウェイ)に公開するVCN制御プレーンが提供される。また、同じメカニズムを使用してファイアウォールルールを公開することができる。特定の実施形態において、NVDは、当該NVDに関連するマッピングのみを取得する。データプレーン機能は、制御プレーンを使用して設定された構成に基づいて、パケットの実際のルーティング/転送を行う機能を含む。VCNデータプレーンは、顧客のネットワークパケットが基幹ネットワークを通過する前に、当該ネットワークパケットをカプセル化することによって実装される。カプセル化/カプセル解除機能は、NVDに実装される。特定の実施形態において、NVDは、ホストマシンに出入りする全てのネットワークパケットを傍受し、ネットワーク仮想化機能を実行するように構成されている。
【0092】
上述したように、NVDは、VNICおよびVCN VRを含む様々な仮想化機能を実行する。NVDは、VNICに接続された1つ以上のホストマシンによってホストされている計算インスタンスに関連するVNICを実行することができる。例えば、図2に示すように、NVD210は、NVD210に接続されたホストマシン202によってホストされている計算インスタンス268に関連するVNIC276の機能を実行する。別の例として、NVD212は、ホストマシン206によってホストされているベアメタル計算インスタンス272に関連するVNIC280を実行し、ホストマシン208によってホストされている計算インスタンス274に関連するVNIC284を実行する。ホストマシンは、異なる顧客に属する異なるVCNに属する計算インスタンスをホストすることができる。ホストマシンに接続されたNVDは、計算インスタンスに対応するVNICを実行する(すなわち、VNICに関連する機能を実行する)ことができる。
【0093】
また、NVDは、計算インスタンスのVCNに対応するVCN仮想ルータを実行する。例えば、図2に示された実施形態において、NVD210は、計算インスタンス268が属するVCNに対応するVCN VR277を実行する。NVD212は、ホストマシン206および208にホストされている計算インスタンスが属する1つ以上のVCNに対応する1つ以上のVCN VR283を実行する。特定の実施形態において、VCNに対応するVCN VRは、そのVCNに属する少なくとも1つの計算インスタンスをホストするホストマシンに接続された全てのNVDによって実行される。ホストマシンが異なるVCNに属する計算インスタンスをホストする場合、そのホストマシンに接続されたNVDは、異なるVCNに対応するVCN VRを実行することができる。
【0094】
VNICおよびVCN VRに加えて、NVDは、様々なソフトウエア(例えば、デーモン)を実行し、NVDによって実行される様々なネットワーク仮想化機能を容易にする1つ以上のハードウェア要素を含むことができる。簡略化のために、これらの様々な要素は、図2に示す「パケット処理要素」としてグループ化される。例えば、NVD210は、パケット処理要素286を含み、NVD212は、パケット処理要素288を含む。例えば、NVDのパケット処理要素は、NVDのポートおよびハードワーキングインターフェイスと相互作用することによって、NVDを使用して受信され、通信される全てのパケットを監視し、ネットワーク情報を記憶するように構成されたパケットプロセッサを含んでもよい。ネットワーク情報は、例えば、NVDによって処理される異なるネットワークフローを特定するためのネットワークフロー情報および各フローの情報(例えば、各フローの統計情報)を含んでもよい。特定の実施形態において、ネットワークフロー情報は、VNIC単位で記憶されてもよい。別の例として、パケット処理要素は、NVDによって記憶された情報を1つ以上の異なる複製ターゲットストアに複製するように構成された複製エージェント(replication agent)を含むことができる。さらに別の例として、パケット処理要素は、NVDのロギング機能を実行するように構成されたロギングエージェント(logging agent)を含んでもよい。また、パケット処理要素は、NVDの性能および健全性を監視し、場合によっては、NVDに接続されている他の要素の状態および健全性を監視するためのソフトウェアを含んでもよい。
【0095】
図1は、VCNと、VCN内のサブネットと、サブネット上に展開された計算インスタンスと、計算インスタンスに関連付けられたVNICと、VCNのVRと、VCNのために構成された一組のゲートウェイとを含む例示的な仮想またはオーバーレイネットワークの要素を示す。図1に示されたオーバーレイ要素は、図2に示された物理的要素のうちの1つ以上によって実行またはホストされてもよい。例えば、VCN内の計算インスタンスは、図2に示された1つ以上のホストマシンによって実行またはホストされてもよい。ホストマシンによってホストされている計算インスタンスの場合、その計算インスタンスに関連するVNICは、典型的には、そのホストマシンに接続されたNVDによって実行される(すなわち、VNIC機能は、そのホストマシンに接続されたNVDによって提供される)。VCNのVCN VR機能は、そのVCNの一部である計算インスタンスをホストまたは実行するホストマシンに接続されている全てのNVDによって実行される。VCNに関連するゲートウェイは、1つ以上の異なる種類のNVDによって実行されてもよい。例えば、いくつかのゲートウェイは、スマートNICによって実行されてもよく、他のゲートウェイは、1つ以上のホストマシンまたはNVDの他の実装形態によって実行されてもよい。
【0096】
上述したように、顧客VCN内の計算インスタンスは、様々な異なるエンドポイントと通信することができる。これらのエンドポイントは、送信元計算インスタンスと同じサブネットにあってもよく、異なるサブネット内であるが送信元計算インスタンスと同じVCNにあってもよく、または送信元計算インスタンスのVCN外部のエンドポイントを含んでもよい。これらの通信は、計算インスタンスに関連付けられたVNIC、VCN VR、およびVCNに関連付けられたゲートウェイを用いて促進される。
【0097】
VCN内の同じサブネット上の2つの計算インスタンス間の通信は、送信元計算インスタンスおよび宛先計算インスタンスに関連付けられたVNICを用いて促進される。送信元計算インスタンスおよび宛先計算インスタンスは、同じホストマシンによってホストされてもよく、異なるホストマシンによってホストされてもよい。送信元計算インスタンスから発信されたパケットは、送信元計算インスタンスをホストするホストマシンから、そのホストマシンに接続されたNVDに転送されてもよい。NVDにおいて、パケットは、パケット処理パイプラインを用いて処理され、このパイプラインは、送信元計算インスタンスに関連するVNICの実行を含むことができる。パケットの宛先エンドポイントが同じサブネットにあるため、送信元計算インスタンスに関連付けられたVNICの実行により、パケットは、宛先計算インスタンスに関連付けられたVNICを実行するNVDに転送され、NVDは、パケットを処理し、宛先計算インスタンスに転送する。送信元計算インスタンスおよび宛先計算インスタンスに関連するVNICは、(例えば、送信元計算インスタンスと宛先計算インスタンスの両方が同じホストマシンによってホストされている場合)同じNVD上で実行されてもよく、または(例えば、送信元計算インスタンスおよび宛先計算インスタンスが異なるNVDに接続された異なるホストマシンによってホストされている場合)異なるNVD上で実行されてもよい。VNICは、NVDによって記憶されたルーティング/転送テーブルを使用して、パケットのネクストホップを決定することができる。
【0098】
サブネット内の計算インスタンスから同じVCN内の異なるサブネット内のエンドポイントにパケットを通信する場合、送信元計算インスタンスから発信されたパケットは、送信元計算インスタンスをホストするホストマシンから、そのホストマシンに接続されたNVDに通信される。NVDにおいて、パケットは、1つ以上のVNICの実行を含むことができるパケット処理パイプラインおよびVCNに関連するVRを用いて処理される。例えば、NVDは、パケット処理パイプラインの一部として、送信元計算インスタンスに関連するVNICに対応する機能を実行または呼び出す(VNICを実行するとも呼ばれる)。VNICによって実行される機能は、パケット上のVLANタグを調べることを含んでもよい。パケットの宛先がサブネットの外部にあるため、VCN VR機能は、呼び出され、NVDによって実行される。その後、VCN VRは、パケットを、宛先計算インスタンスに関連付けられたVNICを実行するNVDにルーティングする。そして、宛先計算インスタンスに関連付けられたVNICは、パケットを処理し、パケットを宛先計算インスタンスに転送する。送信元計算インスタンスおよび宛先計算インスタンスに関連するVNICは、(例えば、送信元計算インスタンスと宛先計算インスタンスの両方が同じホストマシンによってホストされている場合)同じNVD上で実行されてもよく、(例えば、送信元計算インスタンスおよび宛先計算インスタンスが異なるNVDに接続された異なるホストマシンによってホストされている場合)異なるNVD上で実行されてもよい。
【0099】
パケットの宛先が送信元計算インスタンスのVCNの外部にある場合、送信元計算インスタンスから発信されたパケットは、送信元計算インスタンスをホストするホストマシンから、そのホストマシンに接続されたNVDに通信される。NVDは、送信元計算インスタンスに関連するVNICを実行する。パケットの宛先エンドポイントがVCNの外部にあるため、パケットは、そのVCNのVCN VRによって処理される。NVDは、VCN VR機能を呼び出し、その結果、パケットは、VCNに関連付けられた適切なゲートウェイを実行するNVDに転送される場合がある。例えば、宛先が顧客オンプレミスネットワーク内のエンドポイントである場合、パケットは、VCN VRによって、VCNのために構成されたDRGゲートウェイを実行するNVDに転送されてもよい。VCN VRは、送信元計算インスタンスに関連するVNICを実行するNVDと同じNVD上で実行されてもよく、異なるNVDによって実行されてもよい。ゲートウェイは、スマートNIC、ホストマシン、または他のNVD実装であるNVDによって実行されてもよい。次いで、パケットは、ゲートウェイによって処理され、意図した宛先エンドポイントへのパケットの通信を容易にするためのネクストホップに転送される。例えば、図2に示された実施形態において、計算インスタンス268から発信されたパケットは、(NIC232を用いて)リンク220を介してホストマシン202からNVD210に通信されてもよい。NVD210上のVNIC276は、送信元計算インスタンス268に関連するVNICであるため、呼び出される。VNIC276は、パケット内のカプセル化された情報を検査し、意図した宛先エンドポイントへのパケットの通信を容易にする目的でパケットを転送するためのネクストホップを決定し、決定したネクストホップにパケットを転送するように構成されている。
【0100】
VCN上に展開された計算インスタンスは、様々な異なるエンドポイントと通信することができる。これらのエンドポイントは、CSPI200によってホストされているエンドポイントと、CSPI200外部のエンドポイントとを含んでもよい。CSPI200によってホストされているエンドポイントは、(顧客VCN、または顧客に属さないVCNであり得る)同じVCNまたは他のVCN内のインスタンスを含んでもよい。CSPI200によってホストされているエンドポイント間の通信は、物理ネットワーク218を介して実行されてもよい。また、計算インスタンスは、CSPI200によってホストされていないまたはCSPI200の外部にあるエンドポイントと通信することもできる。これらのエンドポイントの例は、顧客オンプレミスネットワークまたはデータセンタ内のエンドポイント、またはインターネットなどのパブリックネットワークを介してアクセス可能なパブリックエンドポイントを含む。CSPI200外部のエンドポイントとの通信は、様々な通信プロトコルを用いて、パブリックネットワーク(例えば、インターネット)(図2に図示せず)またはプライベートネットワーク(図2に図示せず)を介して実行されてもよい。
【0101】
図2に示されたCSPI200のアーキテクチャは、単なる一例であり、限定することを意図していない。代替的な実施形態において、変形、代替、および修正が可能である。例えば、いくつかの実装形態において、CSPI200は、図2に示されたものよりも多いまたは少ないシステムまたは要素を有してもよく、2つ以上のシステムを組み合わせてもよく、または異なるシステム構成または配置を有してもよい。図2に示されたシステム、サブシステム、および他の要素は、それぞれのシステムの1つ以上の処理ユニット(例えば、プロセッサ、コア)によって実行されるソフトウェア(例えば、コード、命令、プログラム)、ハードウェア、またはそれらの組み合わせで実装されてもよい。ソフトウェアは、非一時的な記憶媒体(例えば、メモリ装置)に記憶されてもよい。
【0102】
図4は、特定の実施形態に従って、マルチテナント機能をサポートするためのI/O仮想化を提供するためのホストマシンとNVDとの間の接続を示す図である。図4に示すように、ホストマシン402は、仮想化環境を提供するハイパーバイザ404を実行する。ホストマシン402は、2つの仮想マシンインスタンス、すなわち、顧客/テナント#1に属するVM1 406と、顧客/テナント#2に属するVM2 408とを実行する。ホストマシン402は、リンク414を介してNVD412に接続されている物理NIC410を含む。計算インスタンスの各々は、NVD412によって実行されるVNICに接続されている。図4の実施形態において、VM1 406は、VNIC-VM1 420に接続され、VM2 408は、VNIC-VM2 422に接続されている。
【0103】
図4に示すように、NIC410は、2つの論理NIC、すなわち、論理NIC A 416および論理NIC B 418を含む。各仮想マシンは、それ自身の論理NICに接続され、それ自身の論理NICと共に動作するように構成される。例えば、VM1 406は、論理NIC A 416に接続され、VM2 408は、論理NIC B 418に接続されている。ホストマシン402が複数のテナントによって共有されている1つの物理NIC410のみからなるにもかかわらず、論理NICにより、各テナントの仮想マシンは、自分自身のホストマシンおよびNICを所有していると信じている。
【0104】
特定の実施形態において、各論理NICには、それ自身のVLAN IDが割り当てられる。したがって、テナント#1の論理NIC A 416には特定のVLAN IDが割り当てられ、テナント#2の論理NIC B 418には別のVLAN IDが割り当てられる。VM1 406からパケットが通信されると、ハイパーバイザは、テナント#1に割り当てられたタグをパケットに取り付けた後、リンク414を介してパケットをホストマシン402からNVD412に通信する。同様に、VM2 408からパケットが通信されると、ハイパーバイザは、テナント#2に割り当てられたタグをパケットに取り付けた後、リンク414を介してパケットをホストマシン402からNVD412に通信する。したがって、ホストマシン402からNVD412に通信されたパケット424は、特定のテナントおよび関連するVMを識別する関連タグ426を有する。NVD上でホストマシン402からパケット424を受信した場合、当該パケットに関連するタグ426を用いて、当該パケットがVNIC-VM1 420によって処理されるべきか、VNIC-VM2 422によって処理されるべきかを判断する。そして、パケットは、対応するVNICによって処理される。図4に示された構成は、各テナントの計算インスタンスが、自分自身のホストマシンおよびNICを所有していると信じることを可能にする。図4に示された構成は、マルチテナント機能をサポートするためのI/O仮想化を提供する。
【0105】
図5は、特定の実施形態に従って、物理ネットワーク500を示す概略ブロック図である。図5に示された実施形態は、Closネットワークとして構築される。Closネットワークは、高い二分割帯域幅および最大リソース利用率を維持しながら、接続冗長性を提供するように設計された特定の種類のネットワークトポロジである。Closネットワークは、一種の非ブロッキング、多段または多層スイッチングネットワークであり、段または層の数は、2、3、4、5などであってもよい。図5に示された実施形態は、層1、2および3を含む3層ネットワークである。TORスイッチ504は、Closネットワークの層-0スイッチを表す。1つ以上のNVDは、TORスイッチに接続されている。層-0スイッチは、物理ネットワークのエッジ装置とも呼ばれる。層-0スイッチは、リーフスイッチとも呼ばれる層-1スイッチに接続されている。図5に示された実施形態において、「n」個の層-0 TORスイッチは、「n」個の層-1スイッチに接続され、ポッドを形成する。ポッド内の各層-0スイッチは、ポッド内の全ての層-1スイッチに相互接続されるが、ポッド間のスイッチは、接続されない。特定の実装例において、2つのポッドは、ブロックと呼ばれる。各ブロックは、「n」個の層-2スイッチ(スパインスイッチとも呼ばれる)によってサービスを提供されるまたはそれに接続されている。物理ネットワークトポロジは、複数のブロックを含んでもよい。同様に、層-2スイッチは、「n」個の層-3スイッチ(スーパースパインスイッチとも呼ばれる)に接続されている。物理ネットワーク500を介したパケットの通信は、典型的には、1つ以上のレイヤ3通信プロトコルを使用して実行される。典型的には、TOR層を除く物理ネットワークの全ての層は、nウェイ冗長であり、したがって高い可用性を実現することができる。ポッドおよびブロックにポリシーを指定して、物理ネットワークのスイッチの相互可視性を制御することによって、物理ネットワークを拡張することができる。
【0106】
Closネットワークの特徴は、ある層-0スイッチから別の層-0スイッチに到達する(または、層-0スイッチに接続されたNVDから層-0スイッチに接続された別のNVDに到達する)最大ホップカウントが一定であることである。例えば、3層のClosネットワークにおいて、パケットが1つのNVDから別のNVDに到達するために最大7つのホップが必要とされる。この場合、送信元NVDおよびターゲットNVDは、Closネットワークのリーフ層に接続されている。同様に、4層のClosネットワークにおいて、パケットが1つのNVDから別のNVDに到達するために最大9つのホップが必要とされる。この場合、送信元NVDおよびターゲットNVDは、Closネットワークのリーフ層に接続されている。したがって、Closネットワークアーキテクチャは、データセンタ内およびデータセンタ間の通信に重要なネットワーク全体の遅延を一定に保つ。Closトポロジは、水平方向に拡張可能であり、コスト効率に優れている。各階層により多くのスイッチ(例えば、より多くのリーフスイッチおよびスパインスイッチ)を増設すること、および隣接する階層のスイッチ間にリンク数を増やすことによって、ネットワークの帯域幅/スループット容量を容易に増加させることができる。
【0107】
特定の実施形態において、CSPI内の各リソースには、クラウド識別子(CID)と呼ばれる固有識別子が割り当てられる。この識別子は、リソースの情報の一部として含まれる。この識別子を用いて、例えば、コンソールまたはAPIを介してリソースを管理することができる。CIDの例示的なシンタックスは、以下の通りである。
【0108】
ocid1.<RESOURCE TYPE>.<REALM>.[REGION].[FUTURE USE].<UNIQUE ID>である。式中、
「ocid1」は、CIDのバージョンを示す文字列である。
【0109】
「RESOURCE TYPE」は、リソースの種類(例えば、インスタンス、ボリューム、VCN、サブネット、ユーザ、グループ)を表す。
【0110】
「REALM」は、リソースが存在する領域を表す。例示的な値として、「c1」は、商業領域を表し、「c2」は、政府クラウド領域を表し、または「c3」は、連邦政府クラウド領域を表す。各領域は、独自のドメイン名を持つことができる。
【0111】
「REGION」は、リソースが属する地域を表す。地域がリソースに適用されない場合、この部分は空白であってもよい。
【0112】
「FUTURE USE」は、将来使用のために保留されていることを示す。
「UNIQUE ID」は、固有IDの部分である。このフォーマットは、リソースまたはサービスの種類によって異なる場合がある。
【0113】
B.例示的なレイヤ2VLANアーキテクチャ
このセクションでは、仮想化されたクラウド環境においてレイヤ2ネットワーキング機能を提供するための技術を説明する。レイヤ2機能は、仮想化されたクラウド環境によって提供されるレイヤ3ネットワーキング機能に加えて、およびそれに関連して、提供される。特定の実施形態では、仮想レイヤ2およびレイヤ3機能は、Oracle Corporationが提供するOracle Cloud Infrastructure (OCI)によって提供される。
[0132]
レイヤ2ネットワーク機能の導入後、このセクションでは、VLANのレイヤ2実現を説明する。その後、インターネットグループ管理プロトコル(IGMP)機能を含むレイヤ2VLANサービスについて説明する。
【0114】

企業顧客のオンプレミスアプリケーションをクラウドサービスプロバイダ(CSP)によって提供されるクラウド環境に移行させる企業顧客の数は、急速に増加し続けている。しかしながら、これらの顧客の多くは、クラウド環境に移行する道程が非常に多難であり得、顧客の既存のアプリケーションを、クラウド環境において動作可能にするために、再構築および再設計する必要があることを、すぐに認識する。これは、オンプレミス環境のために書かれたアプリケーションは、しばしば、監視、可用性、および規模に関して物理ネットワークの特徴に依存するからである。したがって、これらのオンプレミスアプリケーションは、クラウド環境において動作することができるようになる前に、再構築および再設計される必要がある。
【0115】
オンプレミスアプリケーションがクラウド環境に容易に移行できない理由はいくつかある。主な理由の1つは、現在のクラウド仮想ネットワークがOSIモデルのレイヤ3、例えばIPレイヤで動作し、アプリケーションによって必要とされるレイヤ2機能を提供しないことである。レイヤ3ベースのルーティングまたは転送は、パケットのレイヤ3ヘッダに含まれる情報に基づいて、たとえば、パケットのレイヤ3ヘッダに含まれる宛先IPアドレスに基づいて、パケットがどこに(たとえば、どの顧客インスタンスに)送信されるべきかを判断することを含む。これを容易にするために、仮想化されたクラウドネットワーク内のIPアドレスの位置は、集中制御およびオーケストレーションシステムまたはコントローラを介して判断される。これらは、例えば、仮想化されたクラウド環境内の顧客エンティティまたはリソースに関連付けられたIPアドレスを含んでもよい。
【0116】
多くの顧客は、現在のクラウド提供およびIaaSサービスプロバイダによっては現在のところ対処されていない、レイヤ2ネットワーキング能力に対する厳格な要件を有するアプリケーションを、顧客のオンプレミス環境において動作させている。例えば、トラフィックは、現在のクラウド提供であり、レイヤ3ヘッダを使用するレイヤ3プロトコルを使用してルーティングされ、アプリケーションによって必要とされるレイヤ2機能はサポートされない。これらのレイヤ2機能は、アドレス解決プロトコル(ARP)処理、媒体アクセス制御(MAC)アドレス学習、およびレイヤ2ブロードキャスト能力、レイヤ2(MACベースの)転送、レイヤ2ネットワーキング構築物などの機能を含み得る。本開示で説明されるように、仮想化されたクラウドネットワークにおいて、仮想化されたレイヤ2ネットワーキング機能を提供することによって、顧客は、いかなる実質的な再構築または再設計も必要とせずに、今や、顧客のレガシーアプリケーションをクラウド環境にシームレスに移行させることができる。例えば、ここで説明される仮想化されたレイヤ2ネットワーキング能力は、そのようなアプリケーション(例えば、VMware vSphere, vCenter, vSAN および NSX-Tコンポーネント)が、オンプレミス環境で行われるようにレイヤ2で通信することを可能にする。これらのアプリケーションは、パブリッククラウドにおいて同じバージョンおよび構成を実行することが可能であり、それによって、顧客は、レガシーアプリケーションに関連付けられる既存の知識、ツール、およびプロセスを含むレガシーオンプレミスアプリケーションを使用することが可能になる。顧客は、(例えば、VMware ソフトウェア定義データセンター(SDDC)を使用して)自身のアプリケーションからネイティブクラウドサービスにアクセスすることもできる。
【0117】
別の例として、フェイルオーバのためにレイヤ2ブロードキャストサポートを必要とするいくつかのレガシーオンプレミスアプリケーション(例えば、企業クラスタ化ソフトウェアアプリケーション、ネットワーク仮想アプライアンス)がある。例示的なアプリケーションは、Fortinet FortiGate, IBM(登録商標) QRadar, Palo Alto firewalls, Cisco ASA, Juniper SRX, および Oracle RAC(Real Application Clustering)を含む。本開示で説明するように、仮想化されたパブリッククラウドにおいて、仮想化されたレイヤ2ネットワーキングを提供することによって、これらのアプライアンスは、今や、変更されずに、仮想化されたパブリッククラウド環境において動作することができる。ここに記載されるように、オンプレミスに匹敵する仮想化されたレイヤ2ネットワーキング機能が提供される。本開示で説明する仮想化されたレイヤ2ネットワーキング機能は、従来のレイヤ2ネットワーキングをサポートする。これは、顧客定義のVLAN、ならびにユニキャスト、ブロードキャスト、およびマルチキャストレイヤ2トラフィック機能のサポートを含む。レイヤ2ベースのパケットのルーティングおよび転送は、レイヤ2プロトコルを使用することと、たとえば、パケットのレイヤ2ヘッダに含まれる情報を使用して、たとえばレイヤ2ヘッダに含まれる宛先MACアドレスに基づいて、パケットをルーティングまたは転送することとを含む。ARP, Gratuitousアドレス解決プロトコルl(GARP), および逆アドレス解決プロトコル (RARP)などの企業アプリケーション(例えば、クラスタリングソフトウェアアプリケーション)によって使用されるプロトコルも、今や、クラウド環境において機能し得る。
【0118】
従来の仮想化されたクラウドインフラストラクチャが、仮想化されたレイヤ3ネットワーキングをサポートし、レイヤ2ネットワーキングをサポートしない、いくつかの理由がある。レイヤ2ネットワークは、通常、レイヤ3ネットワークと同様にスケーリングしない。レイヤ2ネットワーク制御プロトコルは、スケーリングのために望まれる高度化のレベルを有していない。例えば、レイヤ3ネットワークは、レイヤ2ネットワークが取り組まなければならないパケットループ化について心配する必要がない。IPパケット(すなわち、レイヤ3パケット)は、有効期間(TTL)という概念を有するが、レイヤ2パケットはそうではない。レイヤ3パケットの内部に含まれるIPアドレスは、サブネット、CIDR範囲などのトポロジの概念を有するが、レイヤ2アドレス(例えば、MACアドレス)はそうではない。レイヤ3IPネットワークは、経路情報を見つけるための、パケットインターネット探査、経路探索といった、トラブルシューティングを容易にする組込みツールを有する。そのようなツールは、レイヤ2については利用可能ではない。レイヤ3ネットワークは、レイヤ2では利用可能ではないマルチパス機能をサポートする。特にネットワークにおいてエンティティ間で情報を交換するための高度な制御プロトコル(例えば、Border Gateway Protocol (BGP) および Open Shortest Path First (OSPF))の欠如のため、レイヤ2ネットワークは、ネットワークについて学習するためにブロードキャストおよびマルチキャストに依拠しなければならず、これはネットワーク性能に悪影響を与え得る。ネットワークが変化すると、レイヤ2のための学習プロセスは繰り返されなければならないが、これはレイヤ3では必要ではない。これらおよび他の理由から、クラウドIaaSサービスプロバイダにとっては、レイヤ2ではなくレイヤ3で動作するインフラストラクチャを提供する方が、より望ましい。
【0119】
しかしながら、レイヤ2機能は、その複数の欠点にもかかわらず、多くのオンプレミスアプリケーションによって必要とされる。例えば、インスタンスが計算インスタンス(例えば、ベアメタル、仮想マシンもしくはコンテナ)もしくはロードバランサ、nfsマウントポイント、または他のサービスインスタンスなどのサービスインスタンスであり得る仮想ネットワーク「V」において、顧客(顧客1)がIP1を有するインスタンスAおよびIP2を有するインスタンスBの2つのインスタンスを有する、仮想化されたクラウド構成を仮定する。仮想ネットワークVは、他の仮想ネットワークおよび下層の物理ネットワークから隔離された別個のアドレス空間である。たとえば、この隔離は、パケットカプセル化またはNATを含む様々な技術を使用して達成され得る。このため、顧客の仮想ネットワーク内のインスタンスのIPアドレスは、それがホストされる物理ネットワーク内のアドレスとは異なる。物理IPおよびすべての仮想IPアドレスの仮想インターフェースを知っている集中型SDN(ソフトウェア定義ネットワーキング)制御プレーンが提供される。パケットがインスタンスAから仮想ネットワークV内のIP2の宛先に送信されるとき、仮想ネットワークSDNスタックは、IP2がどこに位置するかを知る必要がある。それは、V用の仮想IPアドレスIP2がホストされている物理ネットワーク内のIPにパケットを送信することができるように、これを事前に知らなければならない。仮想IPアドレスの位置は、クラウド内で修正することができ、したがって、物理IPと仮想IPアドレスとの間の関係を変更する。仮想IPアドレスを移動させる(例えば、仮想マシンに関連付けられるIPアドレスを別の仮想マシンに移動させるか、または仮想マシンを新たな物理ホストにマイグレートする)たびに、SDN制御プレーンに対してAPI呼出しを行って、コントローラに、IPが移動されていることを知らせて、それが、SDNスタックにおいてパケットプロセッサ(データプレーン)を含むすべての参加者を更新することができるようにしなければならない。しかし、そのようなAPI呼出しを行わないアプリケーションのクラスがある。例は、様々なオンプレミスアプリケーション、VMwareなどの様々な仮想化ソフトウェアベンダによって提供されるアプリケーションなどを含む。仮想化されたクラウド環境において仮想レイヤ2ネットワークを容易にすることの価値は、そのようなAPI呼出しを行うようにプログラムされていないようなアプリケーションのサポート、または非IPレイヤ3およびMAC学習のためのサポートなど、他のレイヤ2ネットワーキング機能に依存するアプリケーションのサポートを可能にする。
【0120】
仮想レイヤ2ネットワークは、ブロードキャストドメインを作成し、学習は、ブロードキャストドメインのメンバによって実行される。仮想レイヤ2ドメインでは、このレイヤ2ドメイン内の任意のホスト上の任意のMAC上に任意のIPが存在し得、システムは、標準的なレイヤ2ネットワーキングプロトコルを使用して学習し、システムは、MACおよびIPがその仮想レイヤ2ネットワーク内のどこに存在するかに関して中央コントローラによって明示的に伝えられる必要がなく、これらのネットワーキングプリミティブを仮想化する。これは、低レイテンシフェイルオーバを必要とするアプリケーション、複数のノードに対するブロードキャストまたはマルチキャストプロトコルをサポートする必要があるアプリケーション、ならびにIPアドレスおよびMACアドレスがどこで有効であるかを判断するためにSDN制御プレーンまたはAPIエンドポイントへのAPI呼出しをどのように行うかを知らないレガシーアプリケーションが実行されることを可能にする。したがって、仮想化されたクラウド環境においてレイヤ2ネットワーキング能力を提供することは、IPレイヤ3レベルでは利用可能でない機能性をサポートできるよう求められる。
【0121】
仮想化されたクラウド環境において仮想レイヤ2を提供することの別の技術的利点は、非IPプロトコルを含む様々な異なるレイヤ3プロトコル(IPV4、IPV6など)がサポートされることを可能にすることである。例えば、IPX, AppleTalkなどの様々な非IPプロトコルをサポートすることができる。既存のクラウドIaaSプロバイダは、それらの仮想化されたクラウドネットワークにおいてレイヤ2機能を提供しないので、それらは、これらの非IPプロトコルをサポートすることはできない。本開示で説明されるようなレイヤ2ネットワーキング機能を提供することによって、レイヤ3におけるプロトコル、およびレイヤ2レベル機能の可用性を必要とし、それに依存するアプリケーションに対するサポートを提供することができる。
【0122】
本開示で説明される技術を使用して、レイヤ3およびレイヤ2機能の両方が、仮想化されたクラウドインフラストラクチャにおいて提供される。前述のように、レイヤ3ベースのネットワーキングは、レイヤ2ネットワーキングによっては提供されない特定の効率、特にスケーリングに充分に適している効率を提供する。レイヤ3機能に加えてレイヤ2機能を提供することにより、レイヤ2機能をよりスケーラブルな態様で提供しながら、レイヤ3によって提供されるそのような効率性を(たとえば、よりスケーラブルなソリューションを提供するために)活用することが可能になる。例えば、仮想化されたレイヤ3は、学習目的のためにブロードキャストを使用しなければならないことを回避する。レイヤ3を、その効率性のために提供し、ならびに、同時に、仮想化されたレイヤ2を、それを必要とするアプリケーション、およびレイヤ2機能を有さずに機能することはできないアプリケーションを有効にするため、および非IPプロトコルなどをサポートするために提供することによって、仮想化されたクラウド環境における完全な柔軟性が顧客に提供される。
【0123】
顧客ら自身は、レイヤ2環境がレイヤ3環境とともに存在するハイブリッド環境を有し、仮想化されたクラウド環境は、今やこれらの環境の両方をサポートすることができる。顧客は、サブネットなどのレイヤ3ネットワークおよび/またはVLANなどのレイヤ2ネットワークを有することができ、これらの2つの環境は、仮想化されたクラウド環境内で互いにやりとりすることができる。
【0124】
仮想化されたクラウド環境はまた、マルチテナンシをサポートする必要もある。マルチテナンシは、レイヤ3機能およびレイヤ2機能の両方を同じ仮想化されたクラウド環境においてプロビジョニングすることを技術的に困難かつ複雑にする。例えば、レイヤ2ブロードキャストドメインは、クラウドプロバイダのインフラストラクチャ内で多くの異なる顧客にわたって管理されなければならない。本開示に記載される実施形態は、これらの技術的問題を克服する。
【0125】
仮想化プロバイダ(例えば、VMware)の場合、物理レイヤ2ネットワークをエミュレートする仮想化されたレイヤ2ネットワークは、ワークロードが変更されずに実行されることを可能にする。次いで、そのような仮想化プロバイダによって提供されるアプリケーションは、クラウドインフラストラクチャによって提供される仮想化されたレイヤ2ネットワーク上で実行することができる。たとえば、そのようなアプリケーションは、レイヤ2ネットワーク上で実行される必要があるインスタンスのセットを含み得る。顧客がそのようなアプリケーションを自身のオンプレミス環境から仮想化されたクラウド環境にリフトおよびシフトすることを望む場合、単にアプリケーションを取り込んでそれをクラウド内で実行することはできず、なぜならば、これらのアプリケーションは、現在の仮想化されたクラウドプロバイダによっては提供されない下層のレイヤ2ネットワークに依拠するからである(例えば、レイヤ2ネットワーク機能は、仮想マシンのマイグレーションを実行するため、またはMACおよびIPアドレスが有効であるところで移動するために使用される)。これらの理由から、そのようなアプリケーションは、仮想化されたクラウド環境においてネイティブに動作することはできない。ここで説明される技術を使用して、クラウドプロバイダは、仮想化されたレイヤ3ネットワークを提供することに加えて、仮想化されたレイヤ2ネットワークも提供する。ここで、そのようなアプリケーションスタックは、クラウド環境内で変更されずに実行することができ、クラウド環境内でネスト化された仮想化を実行することができる。顧客は今や、クラウド内で自分自身のレイヤ2アプリケーションを実行し、それらを管理することができる。アプリケーションプロバイダは、これを容易にするために、自身のソフトウェアに変更を加える必要はない。そのようなレガシーアプリケーションまたはワークロード(例えば、レガシーロードバランサ、レガシーアプリケーション、KVM、Openstack、クラスタリングソフトウェア)は、今や、仮想化されたクラウド環境で変更されずに実行することができる。
【0126】
ここに説明されるような仮想化されたレイヤ2機能を提供することによって、非IPプロトコルを含む、種々のレイヤ3プロトコルが、今や、仮想化されたクラウド環境によってサポートされることができる。イーサネットを例にとると、様々な非IPプロトコルを含む様々な異なるEtherTypes(どのようなタイプのレイヤ3パケットが送信されているかを伝え;レイヤ3においてどのようなプロトコルを期待すべきかを伝える、レイヤ2ヘッダ内のフィールド)をサポートすることができる。EtherTypesは、イーサネット(登録商標)フレーム内の2オクテットフィールドである。これは、どのプロトコルがフレームのペイロードにカプセル化され、ペイロードがどのように処理されるかを判断するためにデータリンク層によって受信端で使用されるかを示すために使用される。EtherTypesはまた、802.1Q VLANタグ付けの基礎として使用され、VLANからのパケットを、イーサネットトランク上で他のVLANトラフィックと多重化される送信のために、カプセル化する。EtherTypesの例は、IPV4、IPV6、アドレス解決プロトコル(ARP)、AppleTalk、IPXなどを含む。レイヤ2プロトコルをサポートするクラウドネットワークは、レイヤ3レイヤにおいて任意のプロトコルをサポートすることができる。同様に、クラウドインフラストラクチャがレイヤ3プロトコルに対するサポートを提供するとき、クラウドインフラストラクチャは、TCP、UDP、ICMPなどのレイヤ4における様々なプロトコルをサポートすることができる。ネットワークは、仮想化がレイヤ3で提供されるとき、レイヤ4プロトコルにアグノスティックであり得る。同様に、ネットワークは、仮想化がレイヤ2において提供されるとき、レイヤ3プロトコルにアグノスティックであり得る。この技術は、FDDI、インフィニバンドなどを含む任意のレイヤ2ネットワークタイプをサポートするように拡張することができる。
【0127】
したがって、物理ネットワーク用に記述された多くのアプリケーション、特にブロードキャストドメインを共有するコンピュータノードのクラスタとともに動作するアプリケーションは、L3仮想ネットワークにおいてサポートされないレイヤ2機能を使用する。以下の6つの例は、レイヤ2ネットワーキング能力を提供しないことから生じ得る複雑さを強調する:
(1)先行するAPI呼出しなしでのMACおよびIPの割り当て。ネットワークアプライアンスおよびハイパーバイザ(VMware等)は、クラウド仮想ネットワークのために構築されなかった。それらは、MACが一意である限りMACを使用することができ、DHCPサーバから動的アドレスを取得するか、またはクラスタに割り当てられた任意のIPを使用することができる、と仮定する。それらがこれらレイヤ2アドレスおよびレイヤ3アドレスの割り当てについて制御プレーンに通知するように構成できる機構は、存在しないことが多い。MACおよびIPがどこにあるかが分からない場合、レイヤ3仮想ネットワークは、トラフィックをどこに送るべきかがわからない。
(2)高可用性およびライブマイグレーションのためのMACならびにIPの低レイテンシ再割り当て。多くのオンプレミスアプリケーションは、高可用性のためにARPを使用してIPおよびMACを再割り当てし、-クラスタまたはHAペア内のインスタンスが応答することを停止すると、新たにアクティブなインスタンスは、Gratuitous ARP (GARP)を送信して、サービスIPをそのMACに再割り当てするか、または逆ARP (RARP) を送信して、サービスMACをそのインターフェースに再割り当てする。これは、ハイパーバイザ上でインスタンスをライブマイグレーションするときにも重要であり:新たなホストは、ゲストトラフィックが新たなホストに送信されるようにゲストが移動するとRARPを送信しなければならない。割り当ては、API呼出しなしで行われるだけでなく、非常に低いレイテンシ(サブミリ秒)であることも必要である。これは、RESTエンドポイントへのHTTPS呼出しでは達成できない。
(3)MACアドレスによるインターフェース多重化。ハイパーバイザが単一のホスト上で複数の仮想マシンをホストし、そのすべてが同じネットワーク上にあるとき、ゲストインターフェースは、それらのMACによって区別される。これは、同じ仮想インターフェース上の複数のMACに対するサポートを必要とする。
(4)VLANサポート。単一の物理仮想マシンホストは、VLANタグの使用によって示されるように、複数のブロードキャストドメイン上にある必要があることになる。例えば、VMware ESXはトラフィック分離のためにVLANを使用する(例えば、ゲスト仮想マシンは、あるVLAN上で通信し、ストレージは別のVLAN上で通信し、ホスト仮想マシンはさらに別のVLAN上で通信してもよい)。
(5)ブロードキャストおよびマルチキャストトラフィックの使用。ARPはL2ブロードキャストを必要とし、クラスタおよびHAアプリケーションのためにブロードキャストおよびマルチキャストトラフィックを使用するオンプレミスアプリケーションの例がある。
(6)非IPトラフィックのサポート。L3ネットワークは、通信するためにIPv4またはIPv6ヘッダを必要とするので、IP以外のL3プロトコルの使用は機能しないことになる。L2仮想化は、VLAN内のネットワークがL3プロトコルに依存しないものであり得ることを意味し、-L3ヘッダは、IPv4、IPv6、IPX、または他の何かによるかもしれず-、さらには全く存在しないこともあり得る。
【0128】
レイヤ2VLAN実現例
ここで開示されるように、レイヤ2(L2)ネットワークは、クラウドネットワーク内で作成することができる。この仮想L2ネットワークは、ここではVLANと呼ばれる仮想化されたL2VLANなどの1つまたはいくつかのレイヤ2仮想ネットワークを含む。各VLANは、複数の計算インスタンスを含むことができ、それらの各々は、少なくとも1つのL2仮想ネットワークインターフェース(例えば、L2 VNIC)およびL2仮想スイッチに関連付けることができる。いくつかの実施形態では、L2仮想ネットワークインターフェースおよびL2仮想スイッチの各ペアは、NVD上でホストされる。NVDは、複数のそのようなペアをホストすることができ、各ペアは、異なる計算インスタンスに関連付けられる。L2仮想スイッチの集合は、VLANのエミュレートされた単一のL2スイッチを表す。L2仮想ネットワークインターフェースは、エミュレートされた単一L2スイッチ上のL2ポートの集合を表す。VLANは、ここでは実体仮想ルータ(RVR)またはL2 VSRSとも呼ばれるVLANスイッチングおよびルーティングサービス(VSRS)を介して、他のVLAN、レイヤ3(L3)ネットワーク、オンプレミスネットワーク、および/または他のネットワークに接続することができる。このアーキテクチャの例を以下で説明する。
【0129】
ここで図6を参照すると、コンピューティングネットワークの一実施形態の概略図が示されている。VCN602は、CSPI601に存在する。VCN602は、VCN602を他のネットワークに接続する複数のゲートウェイを含む。これらのゲートウェイは、VCN602を、例えば、オンプレミスデータセンタ606などのオンプレミスネットワークに接続することができるDRG604を含む。ゲートウェイは、たとえば、VCN602を別のVCNに接続するためのLPG、ならびに/またはVCN602をインターネットに接続するためのIGWおよび/もしくはNATゲートウェイを含み得るゲートウェイ600をさらに含み得る。VCN602のゲートウェイは、VCN602をサービスネットワーク612に接続することができるサービスゲートウェイ610をさらに含み得る。サービスネットワーク612は、例えば、自律型データベース614および/もしくはオブジェクトストア616を含む、1つまたはいくつかのデータベースならびに/またはストアを含み得る。サービスネットワークは、例えばパブリックIP範囲であり得るIP範囲の集約を含む概念的なネットワークを含み得る。いくつかの実施形態では、これらのIP範囲は、CSPI601プロバイダによって提供されるパブリックサービスのいくつかまたはすべてをカバーすることができる。これらのサービスは、例えば、インターネットゲートウェイまたはNATゲートウェイを介してアクセスすることができる。いくつかの実施形態では、サービスネットワークは、サービスネットワーク内のサービスが、ローカル領域から、その目的のための専用ゲートウェイ(サービスゲートウェイ)を通して、アクセスされる方法を提供する。いくつかの実施形態では、これらのサービスのバックエンドは、例えば、それら自体のプライベートネットワークにおいて実現することができる。いくつかの実施形態では、サービスネットワーク612は、さらなる追加のデータベースを含むことができる。
【0130】
VCN602は、複数の仮想ネットワークを含むことができる。これらのネットワークは、各々、1つまたはいくつかの計算インスタンスを含むことができ、1つまたはいくつかの計算インスタンスは、それらのそれぞれのネットワーク内、ネットワーク間、またはVCN602の外部で通信することができる。VCN602の仮想ネットワークの1つは、L3サブネット620である。L3サブネット620は、VCN602内で作成された構成の単位または細分化である。サブネット620は、VCN602の仮想化されたクラウド環境において仮想レイヤ3ネットワークを含むことができ、VCN602は、CPSI601の下層の物理ネットワーク上でホストされる。図6は単一のサブネット620を示すが、VCN602は1つ以上のサブネットを有することができる。VCN602内の各サブネットは、そのVCN内の他のサブネットと重複せず、VCNのアドレス空間内のアドレス空間サブセットを表す、オーバーレイIPアドレス(例えば、10.0.0.0/24および10.0.1.0/24)の連続範囲と関連付けられることができる。いくつかの実施形態では、このIPアドレス空間は、CPSI601に関連付けられるアドレス空間から隔離することができる。
【0131】
サブネット620は、1つ以上の計算インスタンスを含み、具体的には、第1の計算インスタンス622-Aおよび第2の計算インスタンス622-Bを含む。計算インスタンス622-A、622-Bは、サブネット620内で互いに通信することができ、またはサブネット620の外部の他のインスタンス、デバイス、および/もしくはネットワークと通信することができる。サブネット620の外部の通信は、仮想ルータ(VR)624によって可能にされる。VR624は、サブネット620とVCN602の他のネットワークとの間の通信を可能にする。サブネット620の場合、VR624は、サブネット620(例えば、計算インスタンス622-A、622-B)が、VCN602内の他のネットワーク上のエンドポイント、およびVCN602の外部の他のエンドポイントと通信することを可能にする論理ゲートウェイを表す。
【0132】
VCN602は、追加のネットワークをさらに含むことができ、具体的には、仮想L2ネットワークの例である1つまたはいくつかのL2 VLAN(ここではVLANと呼ばれる)を含むことができる。これらの1つまたはいくつかのVLANは、各々、VCN602のクラウド環境に局在化され、および/またはCPSI601の下層の物理ネットワークによってホストされる、仮想レイヤ2ネットワークを含むことができる。図6の実施形態では、VCN602は、VLAN A630およびVLAN B640を含む。VCN602内の各VLAN630、640は、そのVCN内の他のサブネットまたはVLAN等の、当該VCN内の他のネットワークと重複せず、VCNのアドレス空間内のアドレス空間サブセットを表す、オーバーレイIPアドレス(例えば、10.0.0.0/24 および 10.0.1.0/24)の連続範囲と関連付けられることができる。いくつかの実施形態では、VLANのこのIPアドレス空間は、CPSI601に関連付けられるアドレス空間から隔離され得る。VLAN630、640の各々は、1つ以上の計算インスタンスを含むことができ、具体的には、VLAN A630は、たとえば、第1の計算インスタンス632-Aおよび第2の計算インスタンス632-Bを含むことができる。いくつかの実施形態では、VLAN A630は、追加の計算インスタンスを含むことができる。VLAN B640は、例えば、第1の計算インスタンス642-Aと、第2の計算インスタンス642-Bとを含むことができる。計算インスタンス632-A、632-B、642-A、642-Bの各々は、IPアドレスおよびMACアドレスを有することができる。これらのアドレスは、任意の所望の方法で割り当てられるかまたは生成され得る。いくつかの実施形態では、これらのアドレスは、計算インスタンスのVLANのCIDR内にあり得、いくつかの実施形態では、これらのアドレスは、任意のアドレスであり得る。VLANの計算インスタンスがVLANの外部のエンドポイントと通信する実施形態では、これらのアドレスの一方または両方はVLAN CIDRからのものであるが、すべての通信がVLAN内である場合、これらのアドレスはVLAN CIDR内のアドレスに限定されない。アドレスが制御プレーンによって割り当てられるネットワークとは対照的に、VLAN内の計算インスタンスのIPおよび/またはMACアドレスは、そのVLANのユーザ/顧客によって割り当てられ得、次いで、これらのIPおよび/またはMACアドレスは、以下に論じられる学習のためのプロセスに従って、VLAN内の計算インスタンスによって発見および/または学習され得る。
【0133】
各VLANはVLAN スイッチングおよびルーティングサービス(VSRS)を含むことができ、具体的には、VLAN A630はVSRS A634を含み、VLAN B640はVSRS B644を含む。各VSRS634、644は、VLAN内でレイヤ2スイッチングおよびローカル学習に参加し、また、ARP、NDP、およびルーティングを含むすべての必要なレイヤ3ネットワーク機能を実行する。VSRSは、IPをMACにマッピングしなければならないので、ARP(レイヤ2プロトコルである)を実行する。
【0134】
これらのクラウドベースのVLANでは、各仮想インターフェースまたは仮想ゲートウェイは、仮想MACアドレスであり得る、1つ以上の媒体アクセス制御(MAC)アドレスと関連付けられることができる。VLAN内で、例えば、ベアメタル、VM、もしくはコンテナであり得る1つ以上の計算インスタンス632-A、632-B、642-A、642-B、および/または1つ以上のサービスインスタンスは、仮想スイッチを介して互いに直接通信することができる。他のVLANまたはL3ネットワークなどとの、VLANの外部の通信は、VSRS634、644を介して可能にされる。VSRS634、644は、VLANネットワークに対してIPルーティングなどのレイヤ3機能を提供する分散型サービスである。いくつかの実施形態では、VSRS634、644は、IPネットワークおよびL2ネットワークの交差点に位置し、クラウドベースのL2ドメイン内でIPルーティングおよびL2学習に参加することができる、水平にスケーラブルな高可用性ルーティングサービスである。
【0135】
VSRS634、644は、インフラストラクチャ内で複数のノードにわたって分散され得、VSRS634、644機能は、スケーラブルであり得、具体的には、水平にスケーラブルであり得る。いくつかの実施形態では、VSRS634、644の機能を実現するノードの各々は、ルータおよび/またはスイッチの機能を互いに共有および複製する。さらに、これらのノードは、それら自体を、単一のVSRS634、644として、VLAN630、640内のインスタンスのすべてに対して提示することができる。VSRS634、644は、CSPI601内の、具体的には仮想ネットワーク内の、任意の仮想化デバイス上に実現され得る。したがって、いくつかの実施形態では、VSRS634、644は、NIC、SmartNIC、スイッチ、Smartスイッチまたは汎用計算ホストを含む仮想ネットワーク仮想化デバイスのいずれか上で実現され得る。
【0136】
VSRS634、644は、クラウドネットワークをサポートする、例えば、1つまたはいくつかのx86サーバ等の1つもしくはいくつかのサーバ、もしくは1つもしくはいくつかのNIC、具体的には、1つもしくはいくつかのSmartNIC等の1つもしくはいくつかのネットワーキングデバイス等の、1つまたはいくつかのハードウェアノード上に常駐するサービスであることができる。いくつかの実施形態では、VSRS634、644は、サーバフリート上に実現され得る。したがって、VSRS634、644は、ルーティングおよびセキュリティポリシーを評価することとともにL2およびL3学習に参加し、それを共有する、仮想ネットワーキング実施者の、集中管理されるフリートであるかまたはエッジに分散されてもよい、ノードのフリートにわたって分散されるサービスであり得る。いくつかの実施形態では、VSRSインスタンスの各々は、新たなマッピング情報がVSRSインスタンスによって学習されるので、この新たなマッピング情報で他のVSRSインスタンスを更新することができる。例えば、VSRSインスタンスが、そのVLAN内の1つまたはいくつかのCIについてIP、インターフェース、および/またはMACマッピングを学習すると、VSRSインスタンスは、その更新された情報をVCN内の他のVSRSインスタンスに提供することができる。このクロスアップデートを介して、第1のVLANに関連付けられるVSRSインスタンスは、他のVLAN内のCIついてのIP、インターフェース、および/またはMACマッピングを含むマッピングを知ることができ、いくつかの実施形態では、VCN602内の他のVLAN内のCIについてのIP、インターフェース、および/またはMACマッピングを含むマッピングを知ることができる。VSRSがサーバフリート上に存在し、および/またはノードのフリートにわたって分散されるとき、これらの更新は大幅に促進され得る。
【0137】
いくつかの実施形態では、VSRS634、644はまた、DHCPリレー;DHCP(ホスティング);DHCPv6;IPv6近隣探索プロトコルなどの近隣探索プロトコル;DNS;ホスティングDNSv6;IPv6のためのSLAAC;NTP;メタデータサービス;およびブロックストアマウントポイントを含むが、それらに限定されない、ネットワーキングに必要な1つまたはいくつかのより上位のサービスをホストしてもよい。いくつかの実施形態では、VSRSは、複数のネットワークアドレス空間の間で変換するための1つ以上のネットワークアドレス変換(NAT)機能をサポートすることができる。いくつかの実施形態では、VSRSは、アンチスプーフィング、アンチMACスプーフィング、IPv4のためのARPキャッシュポイズニング対策、IPv6ルータ広告(RA)ガード、DHCPガード、アクセス制御リスト(ACL)を使用したパケットフィルタリング;および/または逆経路転送チェックを組み込むことができる。VSRSは、例えば、ARP、GARP、パケットフィルタ(ACL)、DHCPリレー、および/またはIPルーティングプロトコルを含む機能を実現することができる。VSRS634、644は、例えば、MACアドレスを学習し、有効期限切れのMACアドレスを無効にし、MACアドレスの移動を取り扱い、MACアドレス情報を調べることができ、MAC情報のフラッディングの取り扱い、ストーム制御の取り扱い、ループ防止、例えば、クラウド内のIGMP等のプロトコルを介したレイヤ2マルチキャスト、ログを含む統計収集、SNMPを使用する統計、監視、ならびに/またはブロードキャスト、総トラフィック、ビット、スパニングツリーパケットなどについての統計を収集および使用することができる。
【0138】
仮想ネットワーク内で、VSRS634、644は、異なるインスタンス化として現れ得る。いくつかの実施形態では、VSRSのこれらのインスタンス化の各々は、VLAN630、640に関連付けることができ、いくつかの実施形態では、各VLAN630、640は、VSRS634、644のインスタンス化を有することができる。いくつかの実施形態では、VSRS634、644の各インスタンス化は、VSRS634、644のインスタンス化が関連付けられるVLAN630、640に対応する1つまたはいくつかの固有のテーブルを有することができる。VSRS634、644の各インスタンス化は、VSRS634、644のそのインスタンス化に関連付けられる固有のテーブルを生成および/またはキュレートすることができる。したがって、単一のサービスが1つまたはいくつかのクラウドネットワークのためにVSRS634、644機能を提供してもよい一方で、クラウドネットワーク内のVSRS634、644の個々のインスタンス化は、固有のレイヤ2転送テーブルおよびレイヤ3転送テーブルを有することができ、一方で、複数のそのような顧客ネットワークは、重なるレイヤ2転送テーブルおよびレイヤ3転送テーブルを有することができる。
【0139】
いくつかの実施形態では、VSRS634、644は、複数のテナントにわたって競合するVLANおよびIP空間をサポートし得る。これは、同じVSRS634、644上に複数のテナントを有することを含み得る。いくつかの実施形態では、これらのテナントのいくつかまたはすべては、同じIPアドレス空間、同じMAC空間、および同じVLAN空間のうちのいくつかまたはすべてを使用するよう選択することができる。これは、アドレスを選択する際にユーザに極度の柔軟性を提供することができる。いくつかの実施形態では、このマルチテナンシは、各テナントに別個の仮想ネットワークを提供することによってサポートされ、この仮想ネットワークは、クラウドネットワーク内のプライベートネットワークである。各仮想ネットワークには一意の識別子が与えられる。同様に、いくつかの実施形態では、各ホストは、一意の識別子を有することができ、および/または各仮想インターフェースもしくは仮想ゲートウェイは、一意の識別子を有することができる。いくつかの実施形態では、これらの一意の識別子、具体的にはテナントに対する仮想ネットワークの一意の識別子は、各通信において符号化することができる。各仮想ネットワークに一意の識別子を提供し、これを通信内に含めることによって、VSRS634、644の単一のインスタンス化は、重複するアドレスおよび/または名前空間を有する複数のテナントに応対することができる。
【0140】
VSRS634、644は、VLAN630、640内でのL2ネットワークとの作成および/もしくはそれとの通信を容易にし、ならびに/またはそれを可能にするために、これらのスイッチング機能および/またはルーティング機能を実行することができる。このVLAN630、640は、クラウドコンピューティング環境内で、より具体的には、そのクラウドコンピューティング環境における仮想ネットワーク内において、見出され得る。
【0141】
例えば、VLAN630、640の各々は、複数の計算インスタンス632-A、632-B、642-A、642-Bを含む。VSRS634、644は、あるVLAN630、640における計算インスタンスと、別のVLAN630、640またはサブネット620における計算インスタンスとの間の通信を可能にする。いくつかの実施形態では、VSRS634、644は、あるVLAN630、640内の計算インスタンスと、別のVCN、インターネットを含むVCNの外部の別のネットワーク、オンプレミスデータセンタなどとの間の通信を可能にする。そのような実施形態では、例えば、計算インスタンス632-Aなどの計算インスタンスは、VLAN、この例ではVLAN A630の外側のエンドポイントに通信を送信することができる。計算インスタンス(632-A)は、VSRS A634に通信を送信することができ、VSRS A634は、その通信を、所望のエンドポイントと通信可能に結合されたルータ624、644またはゲートウェイ604、608、610に向けることができる。所望のエンドポイントと通信可能に結合されたルータ624、644またはゲートウェイ604、608、610は、計算インスタンス(632-A)から通信を受信することができ、その通信を所望のエンドポイントに向けることができる。
【0142】
ここで図7を参照すると、VLAN700の論理およびハードウェア概略図が示されている。理解されるように、VLAN700は、複数のエンドポイントを含み、具体的には、複数の計算インスタンスおよびVSRSを含む。複数の計算インスタンス(CI)は、1つまたはいくつかのホストマシン上でインスタンス化される。いくつかの実施形態では、これは、各CIが固有のホストマシン上でインスタンス化されるように一対一の関係にあることができ、および/またはいくつかの実施形態では、これは、複数のCIが単一の共通ホストマシン上でインスタンス化されるように多対一の関係にあることができる。様々な実施形態では、CIは、L2プロトコルを使用して互いに通信するように構成されることによって、レイヤ2CIであることができる。図7は、いくつかのCIが固有のホストマシン上でインスタンス化され、いくつかのCIが共通のホストマシンを共有するシナリオを示す。図7に見られるように、インスタンス1(CI1)704-Aはホストマシン1 702-A上でインスタンス化され、インスタンス2(CI2)704-Bはホストマシン2 702-B上でインスタンス化され、インスタンス3(CI3)704-Cおよびインスタンス4(CI4)704-Dは共通のホストマシン702-C上でインスタンス化される。
【0143】
CI704-A、704-B、704-C、704-Dの各々は、VLAN700内の他のCI704-A、704-B、704-C、704-D、およびVSRS714と通信可能に結合される。具体的には、CI704-A、704-B、704-C、704-Dの各々は、VLAN700内の他のCI704-A、704-B、704-C、704-D、およびVSRS714に、L2 VNICおよびスイッチを介して接続される。各CI704-A、704-B、704-C、704-Dは、固有のL2 VNICおよびスイッチに関連付けられる。スイッチは、ローカルであり、L2 VNICに固有に関連付けられ、L2 VNICのために展開される、L2仮想スイッチであり得る。具体的には、CI1 704-AはL2 VNIC1 708-Aおよびスイッチ1 710-Aに関連付けられ、CI2 704-BはL2 VNIC2 708-Bおよびスイッチ710-Bに関連付けられ、CI3 704-CはL2 VNIC3 708-Cおよびスイッチ3 710-Cに関連付けられ、CI4 704-Dは、L2 VNIC4 708-Dおよびスイッチ4 710-Dに関連付けられる。
【0144】
いくつかの実施形態では、各L2 VNIC708およびその関連付けられるスイッチ710は、NVD706上でインスタンス化され得る。このインスタンス化は、単一のL2 VNIC708およびその関連付けられるスイッチ710が固有のNVD706上でインスタンス化されるように一対一の関係にあることができ、またはこのインスタンス化は、複数のL2 VNIC708およびそれらの関連付けられるスイッチ710が単一の共通のNVD706上でインスタンス化されるように多対一の関係にあることができる。具体的には、L2 VNIC1 708-Aおよびスイッチ1 710-Aは、NVD1 706-A上でインスタンス化され、L2 VNIC2 708-Bおよびスイッチ2 710-Bは、NVD2上でインスタンス化され、L2 VNIC3 708-Cおよびスイッチ3 710-CならびにL2 VNIC4 708-Dおよびスイッチ710-Dの両方は、共通のNVD、すなわちNVD 706-C上でインスタンス化される。
【0145】
いくつかの実施形態では、VSRS714は、複数のテナントにわたって競合するVLANおよびIP空間をサポートすることができる。これは、同じVSRS714上に複数のテナントを有することを含むことができる。いくつかの実施形態では、これらのテナントのいくつかまたはすべては、同じIPアドレス空間、同じMAC空間、および同じVLAN空間のうちのいくつかまたはすべてを使用するよう選択することができる。これは、アドレスを選択する際にユーザに極度の柔軟性を提供することができる。いくつかの実施形態では、このマルチテナンシは、各テナントに別個の仮想ネットワークを提供することによってサポートされ、この仮想ネットワークは、クラウドネットワーク内のプライベートネットワークである。各仮想ネットワーク(例えば、各VLANまたはVCN)には、VLAN識別子であり得るVCN識別子などの一意の識別子が与えられる。この一意の識別子は、例えば、制御プレーンによって、具体的には、CSPIの制御プレーンによって選択されることができる。いくつかの実施形態では、この一意のVLAN識別子は、パケットカプセル化において含まれ得る、および/または使用され得る、1つまたはいくつかのビットを含み得る。同様に、いくつかの実施形態では、各ホストは、一意の識別子を有することができ、および/または各仮想インターフェースもしくは仮想ゲートウェイは、一意の識別子を有することができる。いくつかの実施形態では、これらの一意の識別子、具体的にはテナントに対する仮想ネットワークの一意の識別子は、各通信において符号化することができる。各仮想ネットワークに一意の識別子を提供し、これを通信内に含めることによって、VSRSの単一のインスタンス化は、重複するアドレスおよび/または名前空間を有する複数のテナントに応対することができる。いくつかの実施形態では、VSRS714は、通信に関連付けられる、具体的には通信のVCNヘッダ内の、VCN識別子および/またはVLAN識別子に基づいて、パケットがどのテナントに属するかを判断することができる。ここで開示される実施形態では、VLANに出入りする通信は、VLAN識別子を含むことができるVCNヘッダを有することができる。VLAN識別子を含むVCNヘッダに基づいて、VSRS714はテナンシを判断することができ、言い換えれば、受信側VSRSは、どのVLANおよび/またはどのテナントに通信を送信するかを判断することができる。加えて、VLANに属する各計算インスタンス(例えば、L2計算インスタンス)には、その計算インスタンスに関連付けられるL2 VNICを識別する一意のインターフェース識別子が与えられる。インターフェース識別子は、(例えば、フレームのヘッダに含まれることによって)コンピュータインスタンスからのトラフィックおよび/またはコンピュータインスタンスへのトラフィックに含まれ得、計算インスタンスに関連付けられるL2 VNICを識別するためにNVDによって使用され得る。言い換えれば、インターフェース識別子は、計算インスタンスおよび/またはそれの関連付けられるL2 VNICを一意に示すことができる。
【0146】
図7に示されるように、スイッチ710-A、710-B、710-C、710-Dは共に、ここでは分散型スイッチ712とも呼ばれる、L2分散型スイッチ712を形成することができる。顧客の観点からは、L2分散型スイッチ712内の各スイッチ710-A、710-B、710-C、710-Dは、VLAN内のCIのすべてに接続する単一のスイッチである。しかしながら、単一のスイッチのユーザエクスペリエンスをエミュレートするL2分散型スイッチ712は、無限にスケーラブルであり、ローカルスイッチ(たとえば、図7の例示的な例では、スイッチ710-A、710-B、710-C、710-D)の集合を含む。図7に示すように、各CIは、NVDに接続されたホストマシン上で実行される。NVDに接続されたホスト上の各CIについて、NVDは、計算インスタンスに関連付けられるレイヤ2VNICおよびローカルスイッチ(たとえば、NVDにローカルであり、レイヤ2VNICに関連付けられ、L2分散型スイッチ712の1つのメンバまたは構成要素であるL2仮想スイッチ)をホストする。レイヤ2VNICは、レイヤ2VLAN上において計算インスタンスのポートを表す。ローカルスイッチは、VNICをレイヤ2VLANの他の計算インスタンスに関連付けられる他のVNIC(例えば、他のポート)に接続する。
【0147】
CI704-A、704-B、704-C、704-Dの各々は、VLAN700内のCI704-A、704-B、704-C、704-Dの他のものと、またはVSRS714と通信することができる。CI704-A、704-B、704-C、704-Dのうちの1つは、CI704-A、704-B、704-C、704-Dのうちの受信側CIまたはVSRS714のMACアドレスおよびインターフェース識別子にフレームを送信することによって、フレームをCI704-A、704-B、704-Cのうちの別のCIまたはVSRS714に送信する。MACアドレスおよびインターフェース識別子は、フレームのヘッダに含まれ得る。ここで上記で説明したように、インターフェース識別子は、CI704-A、704-B、704-C、704-Dのうちの受信側CIまたはVSRS714のL2 VNICを示すことができる。
【0148】
一実施形態では、CI1 704-Aは送信元CIであり得、L2 VNIC708-Aは送信元L2 VNICであり得、スイッチ710-Aは送信元L2仮想スイッチであり得る。この実施形態では、CI3 704-Cは宛先CIであり得、L2 VNIC3 708-Cは宛先L2 VNICであり得る。送信元CIは、フレームを、送信元MACアドレスおよび宛先MACアドレスとともに送信することができる。このフレームは、送信元VNICおよび送信元スイッチをインスタンス化するNVD706-Aによってインターセプトされ得る。
【0149】
L2 VNIC708-A、708-B、708-C、708-Dは、VLAN700について、各々、MACアドレスをL2 VNICのインターフェース識別子にマッピングすることを学習することができる。このマッピングは、VLAN700内から受信されるフレームおよび/または通信に基づいて学習されることができる。この、以前に決定されたマッピングに基づいて、送信元VNICは、VLAN内の宛先CIに関連付けられた宛先インターフェースのインターフェース識別子を判断することができ、フレームをカプセル化することができる。いくつかの実施形態では、このカプセル化は、GENEVEカプセル化、具体的には、カプセル化されるフレームのL2(イーサネット(登録商標))ヘッダを含むL2 GENEVEカプセル化を含むことができる。カプセル化されたフレームは、宛先MAC、宛先インターフェース識別子、送信元MAC、および送信元インターフェース識別子を識別することができる。
【0150】
送信元VNICは、カプセル化されたフレームを送信元スイッチに渡すことができ、送信元スイッチは、フレームを宛先VNICに向けることができる。フレームを受信すると、宛先VNICは、フレームをカプセル化解除し、次いで、フレームを宛先CIに提供することができる。
【0151】
ここで図8を参照すると、複数の接続されたL2 VLAN800の論理概略図が示されている。図8に示される特定の実施形態では、両方のVLANは同じVCNに位置する。理解されるように、複数の接続されたL2 VLAN800は、第1のVLANであるVLAN A802-Aと、第2のVLANであるVLAN B802-Bとを含むことができる。これらのVLAN802-A、802-Bの各々は、1つまたはいくつかのCIを含むことができ、それらの各々は、関連付けられたL2 VNICおよび関連付けられたL2仮想スイッチを有することができる。さらに、これらのVLAN802-A、802-Bの各々は、VSRSを含むことができる。
【0152】
具体的には、VLAN A802-Aは、L2 VNIC1 806-Aおよびスイッチ1 808-Aに接続されたインスタンス1 804-Aと、L2 VNIC2 806-Bおよびスイッチ808-Bに接続されたインスタンス2 804-Bと、L2 VNIC3 806-Cおよびスイッチ3 808-Cに接続されたインスタンス3 804-Cとを含むことができる。VLAN B 802-Bは、L2 VNIC4 806-Dおよびスイッチ4 808-Dに接続されたインスタンス4 804-Dと、L2 VNIC5 806-Eおよびスイッチ808-Eに接続されたインスタンス5 804-Eと、L2 VNIC6 806-Fおよびスイッチ3 808-Fに接続されたインスタンス6 804-Fとを含むことができる。VLAN A802-AはVSRS A810-Aをさらに含むことができ、VLAN B802-BはVSRS B810-Bを含むことができる。VLAN A802-AのCI804-A、804-B、804-Cの各々は、VSRS A810-Aに通信可能に結合されることができ、VLAN B802-BのCI804-D、804-E、804-Fの各々は、VSRS B810-Bに通信可能に結合されることができる。
【0153】
VLAN A802-Aは、VLAN B802-Bに、それぞれのVSRS810-A、810-Bを介して、通信可能に結合されることができる。各VSRSは、同様に、ゲートウェイ812に結合されることができ、ゲートウェイは、各VLAN802-A、802-B内のCI804-A、804-B、804-C、804-D、804-E、804-Fに対するアクセスを、VLAN802-A、802-Bが位置するVCNの外部の他のネットワークに提供することができる。いくつかの実施形態では、これらのネットワークは、例えば、1つまたはいくつかのオンプレミスネットワーク、別のVCN、サービスネットワーク、インターネットなどの公衆ネットワークなどを含むことができる。
【0154】
VLAN A802-A内のCI804-A、804-B、804-Cの各々は、各VLAN802-A、802-BのVSRS810-A、810-Bを介して、VLAN B802-B内のCI804-D、804-E、804-Fと通信することができる。たとえば、VLAN802-A、802-Bのうちの1つにおけるCI804-A、804-B、804-C、804-D、804-E、804-Fのうちの1つは、VLAN802-A、802-Bの他方におけるCI804-A、804-B、804-C、804-D、804-E、804-Fに、フレームを送信することができる。このフレームは、送信元VLANのVSRSを介して送信元VLANを出ることができ、宛先VLANに入り、宛先VSRSを介して宛先CIにルーティングされることができる。
【0155】
一実施形態では、CI1 804-Aは送信元CIであり得、VNIC806-Aは送信元VNICであり得、スイッチ808-Aは送信元スイッチであり得る。この実施形態では、CI 5 804-Eは宛先CIであり得、L2 VNIC5 806-Eは宛先VNICであり得る。VSRS A810-Aは、SVSRSとして識別される送信元VSRSであり得、VSRS B810-Bは、DVSRSとして識別される宛先VSRSであり得る。
【0156】
送信元CIは、フレームをMACアドレスとともに送信することができる。このフレームは、送信元VNICおよび送信元スイッチをインスタンス化するNVDによってインターセプトされ得る。送信元VNICは、フレームをカプセル化する。いくつかの実施形態では、このカプセル化は、GENEVEカプセル化、具体的にはL2 GENEVEカプセル化を含むことができる。カプセル化されたフレームは、宛先CIの宛先アドレスを識別することができる。いくつかの実施形態では、この宛先アドレスはまた、宛先VSRSの宛先アドレスを含むこともできる。宛先CIの宛先アドレスは、宛先IPアドレス、宛先CIの宛先MAC、および/または宛先CIに関連付けられる宛先VNICの宛先インターフェース識別子を含むことができる。宛先VSRSの宛先アドレスは、宛先VSRSのIPアドレス、宛先VSRSに関連付けられる宛先VNICのインターフェース識別子、および/または宛先VSRSのMACアドレスを含むことができる。
【0157】
送信元VSRSは、送信元スイッチからフレームを受信することができ、フレームの宛先アドレスからVNICマッピングを検索することができ、その宛先アドレスは宛先IPアドレスであり得、パケットを宛先VSRSに転送することができる。宛先VSRSは、フレームを受信することができる。フレームに含まれる宛先アドレスに基づいて、宛先VSRSは、フレームを宛先VNICに転送することができる。宛先VNICは、フレームを受信し、カプセル化解除することができ、次いで、宛先CIにフレームを提供することができる。
【0158】
ここで図9を参照すると、複数の接続されたL2 VLANおよびサブネット900の論理概略図が示されている。図9に示す特定の実施形態では、VLANおよびサブネットの両方が同じVCNに位置する。これは、VLANおよびサブネットの両方の、仮想ルータおよびVSRSが、ゲートウェイを介して接続されるのではなく、直接接続されるために、示される。
【0159】
理解されるように、これは、第1のVLAN、VLAN A902-A、第2のVLAN、VLAN B902-B、およびサブネット930を含むことができる。これらのVLAN902-A、902-Bの各々は、1つまたはいくつかのCIを含むことができ、それらの各々は、関連付けられたL2 VNICおよび関連付けられたL2スイッチを有することができる。さらに、これらのVLAN902-A、902-Bの各々は、VSRSを含むことができる。同様に、L3サブネットであり得るサブネット930は、1つまたはいくつかのCIを含むことができ、それらの各々は、関連付けられたL3 VNICを有することができ、L3サブネット930は仮想ルータ916を含むことができる。
【0160】
具体的には、VLAN A902-Aは、L2 VNIC1 906-Aおよびスイッチ1 908-Aに接続されたインスタンス1 904-Aと、L2 VNIC2 906-Bおよびスイッチ2 908-Bに接続されたインスタンス2 904-Bと、L2 VNIC3 906-Cおよびスイッチ3 908-Cに接続されたインスタンス3 904-Cとを含むことができる。VLAN B 902-Bは、L2 VNIC4 906-Dおよびスイッチ4 908-Dに接続されたインスタンス4 904-Dと、L2 VNIC5 906-Eおよびスイッチ5 908-Eに接続されたインスタンス5 904-Eと、L2 VNIC6 906-Fおよびスイッチ6 908-Fに接続されたインスタンス6 904-Fとを含むことができる。VLAN A902-Aはさらに、VSRS A910-Aを含むことができ、VLAN B902-BはVSRS B910-Bを含むことができる。VLAN A902-AのCI904-A、904-B、904-Cの各々は、VSRS A910-Aに通信可能に結合されることができ、VLAN B902-BのCI904-D、904-E、904-Fの各々は、VSRS B910-Bに通信可能に結合されることができる。L3サブネット930は、1つまたはいくつかのCIを含むことができ、具体的には、L3 VNIC7 906-Gに通信可能に結合されるインスタンス7 904-Gを含むことができる。L3サブネット930は仮想ルータ916を含むことができる。
【0161】
VLAN A902-Aは、VLAN B902-Bに、それぞれのVSRS910-A、910-Bを介して通信可能に結合されることができる。L3サブネット930は、仮想ルータ916を介してVLAN A902-AおよびVLAN B902-Bと通信可能に結合されることができる。仮想ルータ916およびVSRSインスタンス910-A、910-Bの各々は、同様に、ゲートウェイ912に結合されることができ、ゲートウェイ912は、各VLAN902-A、902-Bおよびサブネット930におけるCI904-A、904-B、904-C、904-D、904-E、904-F、904-Gに対するアクセスを、VLAN902-A、902-Bおよびサブネット930が位置するVCNの外部の他のネットワークに、与えることができる。いくつかの実施形態では、これらのネットワークは、例えば、1つまたはいくつかのオンプレミスネットワーク、別のVCN、サービスネットワーク、インターネットなどの公衆ネットワークなどを含むことができる。
【0162】
各VSRSインスタンス910-A、910-Bは、関連付けられたVLAN902-A、902-Bを出るフレームのための発信経路と、関連付けられたVLAN902-A、902-Bに入るフレームのための着信経路とを提供することができる。VLAN902-A、902-BのVSRSインスタンス910-A、910-Bから、フレームは、同じVCN上もしくは異なるVCNもしくはネットワーク上のいずれかの別のVLAN内のL2 CI等のL2エンドポイント、および/または同じVCNもしくは異なるVCNもしくはネットワーク上のサブネット内のL3 CIなどのL3エンドポイントを含む、任意の所望のエンドポイントに送信されることができる。
【0163】
一実施形態では、CI1 904-Aは送信元CIであり得、VNIC906-Aは送信元VNICであり得、スイッチ908-Aは送信元スイッチであり得る。この実施形態では、CI7 904-Gは宛先CIであり得、VNIC7 906-Gは宛先VNICであり得る。VSRS A910-Aは、SVSRSとして識別される送信元VSRSであり得、仮想ルータ(VR)916は、宛先VRであり得る。
【0164】
送信元CIは、フレームをMACアドレスとともに送信することができる。このフレームは、送信元VNICおよび送信元スイッチをインスタンス化するNVDによってインターセプトされ得る。送信元VNICは、フレームをカプセル化する。いくつかの実施形態では、このカプセル化は、GENEVEカプセル化、具体的にはL2 GENEVEカプセル化を含むことができる。カプセル化されたフレームは、宛先CIの宛先アドレスを識別することができる。いくつかの実施形態では、この宛先アドレスはまた、送信元CIのVLANのVSRSの宛先アドレスを含むこともできる。宛先CIの宛先アドレスは、宛先IPアドレス、宛先CIの宛先MAC、および/または宛先CIの宛先VNICの宛先インターフェース識別子を含むことができる。
【0165】
送信元VSRSは、送信元スイッチからフレームを受信することができ、フレームの宛先アドレスからVNICマッピングを検索することができ、その宛先アドレスは宛先IPアドレスであり得、フレームを宛先VRに転送することができる。宛先VRは、フレームを受信することができる。フレームに含まれる宛先アドレスに基づいて、宛先VRは、フレームを宛先VNICに転送することができる。宛先VNICは、フレームを受信し、カプセル化解除することができ、次いで、宛先CIにフレームを提供することができる。
【0166】
仮想L2ネットワーク内におけるL2 VNICおよび/またはL2仮想スイッチによる学習
ここで図10を参照すると、VLAN1000内のVLAN内通信および学習の一実施形態の概略図が示されている。ここでの学習は、L2 VNIC、送信元CIのVLANのVSRS、および/またはL2仮想スイッチが、MACアドレスとL2 VNIC//VSRS VNICとの間(より具体的には、L2計算インスタンスまたはVSRSに関連付けられるMACアドレスと、VSRS VNICに関連付けられるこれらのL2計算インスタンスのL2 VNICに関連付けられるインターフェース識別子との間)の関連付けをどのように学習するかに特有である。一般に、学習は着信トラフィックに基づく。この学習は、インターフェース対MACアドレス学習の局面に関して、L2計算インスタンスが宛先MACアドレスを学習するために実現し得る学習プロセス(たとえば、ARPプロセス)とは異なる。(例えば、L2 VNIC/L2仮想スイッチおよびL2計算インスタンスの)2つの学習プロセスは、図12において共同で実現されるとしてものとして示されている。
【0167】
理解されるように、VLAN1000は、L2 VNIC1 1002-AおよびL2スイッチ1 1004-Aをインスタンス化するNVD1 1001-Aと通信可能に結合される計算インスタンス1 1000-Aを含む。VLAN1000はまた、L2 VNIC2 1002-BおよびL2スイッチ2 1004-Aをインスタンス化するNVD2 1001-Bと通信可能に結合される計算インスタンス2 1000-Bを含む。VLAN1000はまた、サーバフリート上で実行され、VSRS VNIC1002-CおよびVSRSスイッチ1004-Cを含むVSRS1015を含む。スイッチ1004-A、1004-B、1004-Cのすべては、共に、L2分散型スイッチ1050を形成する。VSRS1015は、エンドポイント1008と通信可能に結合され、エンドポイント1008は、ゲートウェイを含むことができ、具体的には、例えば別のVSRSの形態のL2/L3ルータ、または例えば仮想ルータの形態のL3ルータを含むことができる。
【0168】
VLAN1000をホストするVCNの制御プレーン1010は、VLAN1000上の各L2 VNICおよび各L2 VNICのネットワーク配置を識別する情報を維持する。たとえば、この情報は、L2 VNICについて、L2 VNICに関連付けられたインターフェース識別子、および/またはL2 VNICをホストするNVDの物理IPアドレスを含むことができる。制御プレーン1010は、VLAN1000内のインターフェースをこの情報で(例えば、周期的に、またはオンデマンドで)更新する。したがって、VLAN1000内の各L2 VNIC1002-A、1002-B、1002-Cは、制御プレーン1010から情報を受信し、VLAN内のインターフェースを識別し、この情報をテーブルにポピュレートする。L2 VNICによってポピュレートされたテーブルは、L2 VNICをホストするNVDにローカルに記憶され得る。VNIC1002-A、1002-B、1002-Cがすでに現在のテーブルを含む場合、VNIC1002-A、1002-B、1002-Cは、VNIC1002-A、1002-B、1002-Cの現在のテーブルと制御プレーン1010から受信された情報/テーブルとの間のいかなる矛盾も判断することができる。VNIC1002-A、1002-B、1002-Cは、いくつかの実施形態では、制御プレーン1010から受信した情報と一致するようにそのテーブルを更新することができる。
【0169】
図10に見られるように、フレームは、L2スイッチ1004-A、1004-B、1004-Cを介して送信され、受信側VNIC1002-A、1002-B、1002-Cによって受信される。フレームがVNIC1002-A、1002-B、1002-Cによって受信されると、そのVNICは、そのフレームの送信元インターフェース(送信元VNIC)および送信元MACアドレスのマッピングを学習する。制御プレーン1010から受信された情報のそのテーブルに基づいて、VNICは、(受信されたフレームからの)送信元MACアドレスを、送信元VNICのインターフェース識別子ならびにそのVNICのIPアドレスおよび/またはそのVNICをホストするNVDのIPアドレスにマッピングすることができる(インターフェース識別子およびIPアドレスが表から入手可能である場合)。したがって、L2 VNIC1002-A、1002-B、1002-Cは、受信された通信および/またはフレームに基づいて、インターフェース識別子のMACアドレスへのマッピングを学習する。各VNIC1002-A、1002-B、1002-Cは、そのL2転送(FWD)テーブル1006-A、1006-B、1006-Cを、この学習されたマッピング情報とともに、有することができる。いくつかの実施形態では、L2転送テーブルは、MACアドレスを含み、インターフェース識別子または物理IPアドレスのうちの少なくとも1つと関連付ける。そのような実施形態では、MACアドレスは、L2計算インスタンスに割り当てられたアドレスであり、L2計算インスタンスに関連付けられるL2 VNICによってエミュレートされるポートに対応し得る。インターフェース識別子は、L2 VNICおよび/またはL2計算インスタンスを一意に識別することができる。仮想IPアドレスは、L2 VNICのそれとすることができる。また、物理IPアドレスは、L2 VNICをホストするNVDのそれとすることができる。L2 VNICによって更新されたL2転送は、L2 VNICをホストするNVD上にローカルに記憶され得、フレームを方向付けるためにL2 VNICに関連付けられたL2仮想スイッチによって使用され得る。いくつかの実施形態では、共通VLAN内のVNICは、それらのマッピングテーブルのすべてまたは部分を互いに共有することができる。
【0170】
上記のネットワークアーキテクチャに照らして、トラフィックフローがここにおいて次に説明される。説明を明確にするために、トラフィックフローは、計算インスタンス2 1000-B、L2 VNIC2 10002-B、L2スイッチ2 1004-B、およびNVD2 1001-Bに関連して説明される。この説明は、他の計算インスタンスとの間のトラフィックフローに等価に適用される。
【0171】
ここで上述したように、VLANは、L3物理ネットワークの上のオーバーレイL2ネットワークとして、VCN内で実現される。VLANのL2計算インスタンスは、送信元MACアドレスおよび宛先MACアドレスとしてオーバーレイMACアドレス(仮想MACアドレスとも呼ばれる)を含むL2フレームを送信または受信することができる。L2フレームはまた、送信元IPアドレスおよび宛先IPアドレスとしてオーバーレイIPアドレス(仮想IPアドレスとも呼ばれる)を含むパケットをカプセル化することもできる。計算インスタンスのオーバーレイIPアドレスは、いくつかの実施形態では、VLANのCIDR範囲に属することができる。他のオーバーレイIPアドレスは、CIDR範囲(この場合、L2フレームはVLAN内を流れる)またはCIDR範囲外(この場合、L2フレームは、他のネットワークに宛てられるか、または他のネットワークから受信される)に属することができる。L2フレームはまた、VLANを一意に識別し、同じNVD上の複数のL2 VNICと区別するために使用され得る、VLANタグを含むことができる。L2フレームは、計算インスタンスのホストマシンから、別のNVDから、またはVSRSをホストするサーバフリートから、トンネルを介して、NVDによって、カプセル化されたパケットで、受信され得る。これらの異なる場合において、カプセル化されたパケットは、物理ネットワーク上で送信されるL3パケットであり得、送信元IPアドレスおよび宛先IPアドレスは、物理IPアドレスである。GENEVEカプセル化を含む、異なるタイプのカプセル化が可能である。NVDは、受信したパケットをカプセル化解除してL2フレームを抽出することができる。同様に、L2フレームを送信するために、NVDは、それをL3パケットにカプセル化し、それを物理基板上で送信することができる。
【0172】
インスタンス2 1000-BからのVLAN内発信トラフィックの場合、NVD2 1001-Bは、イーサネットリンクを介してインスタンス2 1000-Bのホストマシンからフレームを受信する。フレームは、L2 VNIC2 1000-Bを識別するインターフェース識別子を含む。フレームは、送信元MACアドレスとしてインスタンス2 1000-BのオーバーレイMACアドレス(例えば、M.2)を含み、宛先MACアドレスとしてインスタンス1 1000-AのオーバーレイMACアドレス(例えば、M.1)を含む。インターフェース識別子が与えられると、NVD2 1001-Bは、さらなる処理のためにフレームをL2 VNIC2 1002-Bに渡す。L2 VNIC2 1002-Bは、フレームをL2スイッチ2 1004-Bに転送する。L2転送テーブル1006-Bに基づいて、L2スイッチ2 1004-Bは、宛先MACアドレスが既知であるかどうかを判断する(たとえば、L2転送テーブル1006-B中のエントリと突き合わせる)。
【0173】
既知である場合、L2スイッチ2 1004-Bは、L2 VNIC1 1002-Aが、関連するトンネルエンドポイントである、と判断し、フレームをL2 VNIC1 1002-Aに転送する。転送は、フレームのパケットにおけるカプセル化およびパケットのカプセル化解除(たとえば、GENEVEカプセル化およびカプセル化解除)を含むことができ、パケットは、フレームと、宛先アドレスとしてのNVD1 1001-Aの物理IPアドレス(たとえば、IP.1)と、送信元アドレスとしてのNVD 2 1001-Bの物理IPアドレス(例えば、IP.2)とを含む。
【0174】
未知の場合、L2スイッチ2 1004-Bは、VLANの様々なVNIC(たとえば、VLANのL2 VNIC1 1002-Aおよび任意の他のL2 VNICを含む)にフレームをブロードキャストし、ブロードキャストされたフレームは、関連するNVD間で処理(たとえば、カプセル化、送信、カプセル化解除)される。いくつかの実施形態では、このブロードキャストは、物理ネットワークにおいて実行され、またはより具体的には、物理ネットワークにおいてエミュレートされ、VLAN内のVSRSを含んで、各L2 VNICに、別々に、フレームをカプセル化することができる。したがって、ブロードキャストは、物理ネットワークにおいて一連の複製されたユニキャストパケットを介してエミュレートされる。次いで、各L2 VNICは、フレームを受信し、L2 VNIC2 1002-Bのインターフェース識別子と送信元MACアドレス(例えば、M.2)と送信元物理IPアドレス(例えば、IP.2)との間の関連付けを学習する。
【0175】
計算インスタンス1 1000-Aから計算インスタンス2 1000-BへのVLAN内着信トラフィックの場合、NVD2 1001-Bは、NVD1からパケットを受信する。パケットは、送信元アドレスとしてのIP.1およびフレームを有し、フレームは、宛先MACアドレスとしてM.2および送信元MACアドレスとしてM.1を含む。フレームはまた、L2 VNIC1 1002-Aのネットワーク識別子を含む。カプセル化解除で、VNIC2は、フレームを受信し、このインターフェース識別子がM.1および/またはIP.1に関連付けられていることを学習し、以前に未知である場合には、この学習された情報を、L2転送テーブル1006-Bにおいて、スイッチ2に、後の発信トラフィックのために、記憶する。代替として、カプセル化解除で、L2 VNIC2 1002-Bは、フレームを受信し、このインターフェース識別子がM.1および/またはIP.1に関連付けられることを学習し、この情報が既知である場合には、有効時間をリフレッシュする。
【0176】
VLAN1000内のインスタンス2 1000-Bから別のVLAN内のインスタンスに送信される発信トラフィックについては、VSRS VNICおよびVSRSスイッチが使用されることを除いて、上記の発信トラフィックと同様の流れが存在し得る。特に、宛先MACアドレスは、VLAN1000のL2ブロードキャスト内にない(それは、他のL2VLAN内にある)。したがって、宛先インスタンスのオーバーレイ宛先IPアドレス(たとえば、IP.A)が、この発信トラフィックのために使用される。例えば、L2 VNIC2 1002-Bは、IP.AがVLAN1000のCIDR範囲外にある、と判断する。したがって、L2 VNIC2 1002-Bは、宛先MACアドレスをデフォルトゲートウェイMACアドレス(たとえば、M.DG)に設定する。M.DGに基づいて、L2スイッチ2 1004-Bは、発信トラフィックをVSRS VNICに(例えば、トンネルを介して、適切なエンドツーエンドカプセル化で)送信する。VSRS VNICは、発信トラフィックをVSRSスイッチに転送する。次に、VSRSスイッチは、ルーティング機能を実行し、ここで、オーバーレイ宛先IPアドレス(例えば、IP.A)に基づいて、VLAN1000のVSRSスイッチは、発信トラフィックを他のVLANのVSRSスイッチに(例えば、これら2つのVLAN間の仮想ルータを介して、適切なエンドツーエンドカプセル化で)送信する。次に、他のVLANのVSRSスイッチは、IP.AがこのVLANのCIDR範囲内にある、と判断することによって、スイッチング機能を実行し、IP.Aに基づいてそのARPキャッシュの検索を実行して、IP.Aに関連付けられる宛先MACアドレスを判断する。ARPキャッシュ内に一致がない場合、宛先MACアドレスを判断するために、他のVLANの異なるL2 VNICに、ARP要求が送信される。そうでない場合には、VSRSスイッチは、発信トラフィックを、関連するVNICに、(例えば、トンネルを介して適切なカプセル化で)送信する。
【0177】
別のVLAN内のインスタンスからVLAN1000内のインスタンスへの着信トラフィックの場合、トラフィックフローは、逆方向であること除いて上記と同様である。VLAN1000内のインスタンスからL3ネットワークへの発信トラフィックの場合、トラフィックフローは、VLAN1000のVSRSスイッチが仮想ルータを介して仮想L3ネットワーク内の宛先VNICにパケットを直接ルーティングする(例えば、パケットを別のVSRSスイッチを介してルーティングする必要がない)ことを除いて、上記と同様である。仮想L3ネットワークからVLAN1000内のインスタンスへの着信トラフィックの場合、トラフィックフローは、パケットが、パケットをVLAN内でフレームとして送信するVLAN1000AのVSRSスイッチによって受信されることを除いて、上記と同様である。VLAN1000と他のネットワークとの間のトラフィック(発信または着信)については、VSRSスイッチが同様に使用され、そのルーティング機能が発信で使用されて、適切なゲートウェイ(例えば、IGW、NGW、DRG、SGW、LPG)を介してパケットを送信し、そのスイッチング機能が着信で使用されて、VLAN1000内でフレームを送信する。
【0178】
ここで図11を参照すると、VLAN1100(例えば、クラウドベースの仮想L2ネットワーク)の実施形態の概略図が示されており、具体的には、VLANの実現図が示されている。
【0179】
ここで上述したように、VLANは、「n」個の計算インスタンス1102-A、1102-B、1102-Nを含むことができ、その各々はホストマシン上で実行される。前述のように、計算インスタンスとホストマシンとの間の一対一の関連付け、または複数の計算インスタンスと単一のホストマシンとの間の多対一の関連付けが存在し得る。各計算インスタンス1102-A、1102-B、1102-Nは、L2計算インスタンスとすることができ、その場合、それは、少なくとも1つの仮想インターフェース(例えば、L2 VNIC)1104-A、1104-B、1104-Nおよびスイッチ1106-A、1106-B、1106-Nに関連付けられる。スイッチ1106-A、1106-B、1106-Nは、L2仮想スイッチであり、共にL2分散スイッチ型1107を形成する。
【0180】
ホストマシン上の計算インスタンス1102-A、1102-B、1102-Nに関連付けられるL2 VNIC1104-A、1104-B、1104-Nおよびスイッチ1106-A、1106-B、1106-Nのペアは、ホストマシンに接続されたNVD1108-A、1108-B、1108-N上のソフトウェアモジュールのペアである。各L2 VNIC1104-A、1104-B、1104-Nは、顧客の認知された単一スイッチ(ここではvスイッチと呼ぶ)のL2ポートを表す。一般に、ホストマシン「i」は、計算インスタンス「i」を実行し、NVD「i」に接続される。次いで、NVD「i」は、L2 VNIC「i」およびスイッチ「i」を実行する。L2 VNIC「i」は、vスイッチのL2ポート「i」を表す。「i」は1と「n」との間の正の整数である。ここでも、一対一の関連付けが説明されるが、他のタイプの関連付けも可能である。例えば、単一のNVDを複数のホストに接続することができ、各々が、VLANに属する1つ以上の計算インスタンスを実行する。そうである場合、NVDは、計算インスタンスのうちの1つに各々が対応する、L2 VNICおよびスイッチの複数のペアをホストする。
【0181】
VLANは、VSRS1110のインスタンスを含むことができる。VSRS1110は、スイッチングおよびルーティング機能を実行し、VSRS VNIC1112およびVSRSスイッチ1114のインスタンスを含む。VSRS VNIC1112は、vスイッチ上のポートを表し、このポートは、仮想ルータを介してvスイッチを他のネットワークに接続する。示されるように、VSRS1110は、サーバフリート1116上でインスタンス化され得る。
【0182】
制御プレーン1118は、L2 VNIC1104-A、1104-B、1104-NおよびVLANにおけるそれらの配置を識別する情報を追跡することができる。制御プレーン1110はさらに、この情報をVLAN内のL2インターフェース1104-A、1104-B、1104-Nに提供することができる。
【0183】
図11に示すように、VLANは、物理ネットワーク1120の上に構築することができるクラウドベースの仮想L2ネットワークとすることができる。いくつかの実施形態では、この物理ネットワーク1120は、NVD1108-A、1108-B、1108-Nを含むことができる。
【0184】
概して、VLANの第1のL2計算インスタンス(例えば、計算インスタンス1 1102-A)は、L2プロトコルを使用してVLANの第2の計算インスタンス(例えば、計算インスタンス2 1102-B)と通信することができる。例えば、あるフレームは、VLANを介してこれらの2つのL2計算インスタンス間で送信されることができる。それにもかかわらず、フレームは、フレームが下層の物理ネットワーク1120を介して送信され得るように、カプセル化され、トンネリングされ、ルーティングされ、および/または他の処理を受けることができる。
【0185】
例えば、計算インスタンス1 1102-Aは、計算インスタンス2 1102-B宛てのフレームを送信する。ホストマシン1とNVD1との間のネットワーク接続、NVD1と物理ネットワーク1120との間のネットワーク接続、物理ネットワーク1120とNVD2との間のネットワーク接続、およびNVD2とホストマシン2との間のネットワーク接続(例えば、TCP/IP接続、イーサネット(登録商標)接続、トンネリング接続など)に応じて、異なるタイプの処理がフレームに適用され得る。例えば、フレームは、フレームが計算インスタンス2に到達するまで、NVD1によって受信され、カプセル化され、以下同様である。フレームが下層の物理リソース間で送信され得るようにこの処理が仮定され、簡潔かつ明瞭にするために、その説明は、VLANおよび関連するL2動作の説明から省略する。
【0186】
仮想L2ネットワーク通信
複数の形態の通信が、仮想L2ネットワーク内で、または仮想L2ネットワークを用いて生じ得る。これらは、VLAN内通信を含み得る。そのような実施形態では、送信元計算インスタンスは、送信元計算インスタンス(CI)と同じVLANにある宛先計算インスタンスに通信を送信することができる。通信は、送信元CIのVLANの外部のエンドポイントに送信することもできる。これは、たとえば、第1のVLAN内の送信元CIと第2のVLAN内の宛先CIとの間の通信、第1のVLAN内の送信元CIとL3サブネット内の宛先CIとの間の通信、および/または第1のVLAN内の送信元CIから送信元CIのVLANを含むVCNの外部の宛先CIへの通信を含むことができる。この通信は、さらに、例えば、宛先CIのVLANの外部の送信元CIから、宛先CIにおいて、通信を受信することを含むことができる。この送信元CIは、別のVLAN内、L3サブネット内、または送信元CIのVLANを含むVCNの外部にあり得る。
【0187】
VLAN内の各CIは、トラフィックフローにおいて能動的役割を果たすことができる。これは、ここではインターフェース対MACアドレスとも称される、インターフェース識別子対MACアドレスの学習、VLAN内のL2転送テーブルを維持するためのVLAN内のインスタンスのマッピング、ならびに通信(例えば、L2通信の場合ではフレーム)の送信および/または受信を含む。VSRSは、VLAN内の通信において、およびVLANの外部の送信元CIまたは宛先CIとの通信において、能動的役割を果たすことができる。VSRSは、L2ネットワーク内およびL3ネットワーク内における存在を維持して、発信および着信通信を可能にすることができる。
【0188】
ここで図12を参照すると、VLAN内通信のためのプロセス1200の一実施形態を示すフローチャートが示されている。いくつかの実施形態では、プロセス1200は、共通VLAN内の計算インスタンスによって実行され得る。このプロセスは、具体的には、送信元CIがVLAN内の宛先CIに通信を送信するが、その宛先CIのIP対MACアドレスマッピングを知らない場合に実行され得る。これは、例えば、送信元CIが、VLANにおいてIPアドレスを有する宛先CIにパケットを送信するが、送信元CIがそのIPアドレスに対するMACアドレスを知らない場合に起こり得る。この場合、ARPプロセスを実行して、宛先MACアドレスおよびIP対MACアドレスマッピングを学習することができる。
【0189】
送信元CIがIP対MACアドレスマッピングを知っている場合、送信元CIは、宛先CIに直接パケットを送信することができ、ARPプロセスが実行される必要はない。いくつかの実施形態では、このパケットは、VLAN内通信における送信元VNICがL2 VNICである送信元VNICによってインターセプトされ得る。送信元VNICが宛先MACアドレスについてインターフェース対MACアドレスマッピングを知っている場合、送信元VNICは、パケットを例えばL2カプセル化でカプセル化することができ、対応するフレームを、宛先MACアドレスに向けて、VLAN内通信における宛先VNICがL2 VNICである宛先VNICに、転送することができる。
【0190】
送信元VNICがMACアドレスについてインターフェース対MACアドレスマッピングを知らない場合、送信元VNICは、インターフェース対MACアドレス学習プロセスの局面を実行することができる。これは、送信元VNICがVLAN内のすべてのインターフェースにフレームを送信することを含むことができる。いくつかの実施形態では、このフレームは、ブロードキャストを介してVLAN内のインターフェースのすべてに送信され得る。いくつかの実施形態では、このブロードキャストは、物理ネットワークにおいてシリアルユニキャストの形態で実現され得る。このフレームは、宛先MACおよびIPアドレスと、インターフェース識別子と、送信元VNICのMACアドレスおよびIPアドレスとを含むことができる。VLAN内のVNICの各々は、このフレームを受信することができ、送信元VNICのインターフェース対MACアドレスマッピングを学習することができる。
【0191】
受信側VNICの各々はさらに、フレームをカプセル化解除し、カプセル化解除されたフレーム(たとえば、対応するパケット)をそれらの関連付けられるCIに転送することができる。各CIは、転送されたパケットを評価することができるネットワークインターフェースを含むことができる。転送されたパケットを受信したCIが宛先MACおよび/またはIPアドレスと一致しない、とネットワークインターフェースが判断した場合、パケットはドロップされる。転送されたフレームを受信したCIが宛先MACおよび/またはIPアドレスと一致する、とネットワークインターフェースが判断した場合、パケットはCIによって受信される。いくつかの実施形態では、パケットの宛先MACおよび/またはIPアドレスに一致するMACおよび/またはIPアドレスを有するCIは、送信元CIに応答を送信することができ、それによって、送信元VNICは、宛先CIのインターフェース対MACアドレスマッピングを学習することができ、それによって、送信元CIは、宛先CIのIP対MACアドレスマッピングを学習することができる。
【0192】
送信元CIがIP対MACアドレスマッピングを知らない場合、または宛先CIに対する送信元CIのIP対MACアドレスマッピングが古い場合、プロセス1200を実行することができる。かくして、IP対MACアドレスマッピングが既知となると、送信元CIはパケットを送信することができる。IP対MACアドレスマッピングが既知でない場合、プロセス1200を実行することができる。インターフェース対MACアドレスマッピングが既知でない場合、上で概説したインターフェース対MACアドレス学習プロセスを実行することができる。インターフェース対MACアドレスマッピングが既知である場合、送信元VNICは、対応するフレームを宛先VNICに送信することができる。プロセス1200はブロック1202から始まり、送信元CIは、宛先CIのIP対MACアドレスマッピングが送信元CIに未知である、と判断する。いくつかの実施形態では、これは、送信元CIが、パケットについて宛先IPアドレスを判断することと、その宛先IPアドレスが送信元CIのマッピングテーブルに記憶されたMACアドレスに関連付けられていないと判断することとを含み得る。代替として、送信元CIは、その宛先CIについてIP対MACアドレスマッピングが古い、と判断し得る。マッピングは、いくつかの実施形態では、マッピングがある時間制限内で更新および/または検証されていない場合、古くあり得る。宛先CIのIP対MACアドレスマッピングが未知である、および/または送信元CIに古いと判断すると、送信元CIは、宛先IPアドレスについてARP要求を開始し、イーサネットブロードキャストのためにARP要求を送信する。
【0193】
ブロック1204において、ここでは送信元インターフェースとも呼ばれる送信元VNICは、送信元CIからARP要求を受信する。送信元インターフェースは、VLAN上のすべてのインターフェースを識別し、VLANブロードキャストドメイン上のすべてのインターフェースにARP要求を送信する。前述のように、制御プレーンは、VLAN上のインターフェースのすべてを知っており、その情報をVLANとのインターフェースに提供するので、送信元インターフェースは、同様に、VLAN内のインターフェースのすべてを知っており、VLAN内のインターフェースの各々にARP要求を送信することができる。これを行うために、送信元インターフェースは、ARP要求を複製し、VLAN上のインターフェースの各々のためにARP要求のうちの1つをカプセル化する。各カプセル化されたARP要求は、送信元CIインターフェース識別子と、送信元CI MACアドレスおよびIPアドレスと、ターゲットIPアドレスと、宛先CIインターフェース識別子とを含む。送信元CIインターフェースは、複製されカプセル化されたARP要求(たとえば、ARPメッセージ)をシリアルユニキャストとして送ることによってイーサネットブロードキャストを複製し、1つのARP要求がVLAN内の各インターフェースに送られる。
【0194】
ブロック1206において、VLANブロードキャストドメイン内の各インターフェースは、ARPメッセージを受信し、カプセル化解除する。ARPメッセージを受信するVLANブロードキャストドメイン内のインターフェースの各々は、このメッセージが送信元CI MACアドレスおよびIPアドレスならびに送信元CIインターフェース識別子を識別するので、送信元CIの送信元VNICのインターフェース対MACアドレスマッピング(例えば、送信元CIのMACアドレスに対する送信元インターフェースのインターフェース識別子)を学習する。送信元CIについてインターフェース対MACアドレスマッピングを学習することの一部として、インターフェースの各々は、そのマッピングテーブル(たとえば、そのL2転送テーブル)を更新することができ、更新されたマッピングをその関連付けられたスイッチおよび/またはCIに提供することができる。各受信側インターフェースは、VSRSを除いて、カプセル化解除されたパケットをそれらの関連付けられたCIに転送することができる。転送されたカプセル化解除されたパケットのCI受信者、具体的にはそのCIのネットワークインターフェースは、ターゲットIPアドレスがCIのIPアドレスと一致するかどうかを判断することができる。そのインターフェースに関連付けられるCIのIPアドレスが宛先CI IPアドレスと一致しない場合、いくつかの実施形態では、パケットはそのCIによってドロップされ、さらなるアクションは行われない。VSRSの場合、VSRSは、ターゲットIPアドレスがVSRSのIPアドレスと一致するかどうかを判断することができる。VSRSのIPアドレスが、受信されたパケットにおいて指定されたターゲットIPアドレスと一致しない場合、いくつかの実施形態では、パケットはVSRSによってドロップされ、さらなるアクションは行われない。
【0195】
受信されたパケットにおいて指定された宛先CI IPアドレスが、受信側インターフェースに関連付けられるCI(宛先CI)のIPアドレスと一致する、と判断された場合、ブロック1208に示すように、宛先CIは、ユニキャストARP応答であり得る応答を送信元インターフェースに送信する。この応答は、宛先CI MACアドレスおよび宛先CI IPアドレスと、送信元CI IPアドレスおよびMACアドレスとを含む。この応答は、ブロック1210に示すように、宛先インターフェースによって受信され、それは、ユニキャストARP応答をカプセル化する。いくつかの実施形態では、このカプセル化は、GENEVEカプセル化を含むことができる。宛先インターフェースは、カプセル化されたARP応答を、宛先スイッチを介して送信元インターフェースに転送することができる。この応答は、宛先CI MACアドレスおよびIPアドレスならびに宛先CIインターフェース識別子と、送信元CI MACアドレスおよびIPアドレスならびに送信元CIインターフェース識別子とを含む。
【0196】
ブロック1212において、送信元インターフェースは、ARP応答を受信し、それをカプセル化解除する。送信元インターフェースはさらに、カプセル化および/またはカプセル化されたフレームに含まれる情報に基づいて、宛先CIについてのインターフェース対MACアドレスマッピングを学習することができる。送信元インターフェースは、いくつかの実施形態では、ARP応答を送信元CIに転送することができる。
【0197】
ブロック1214において、送信元CIはARP応答を受信する。いくつかの実施形態では、送信元CIは、ARP応答に含まれる情報に基づいてマッピングテーブルを更新することができ、具体的には、宛先CIのMACアドレスおよびIPアドレスに基づいてIP対MACアドレスマッピングを反映するようにマッピングテーブルを更新することができる。その後、送信元CIは、このMACアドレスに基づいて宛先CIにパケットを送信することができる。このパケットは、送信元CIのMACアドレスおよびインターフェース識別子を送信元MACアドレスおよび送信元インターフェースとして含み、宛先CIのMACアドレスおよびインターフェース識別子を宛先MACアドレスおよび宛先インターフェースとして含むことができる。
【0198】
ブロック1216において、送信元インターフェースは、送信元CIからパケットを受信することができる。送信元インターフェースは、パケットをカプセル化することができ、いくつかの実施形態では、このカプセル化は、GENEVEカプセル化を使用する。送信元インターフェースは、対応するフレームを宛先CIに、具体的には宛先インターフェースに転送することができる。カプセル化されたフレームは、送信元CIのMACアドレスおよびインターフェース識別子を送信元MACアドレスおよび送信元インターフェース識別子として含み、宛先CIのMACアドレスおよびインターフェース識別子を宛先MACアドレスおよび宛先インターフェースとして含むことができる。
【0199】
ブロック1218において、宛先インターフェースは、送信元インターフェースからフレームを受信する。宛先インターフェースは、フレームをカプセル化解除することができ、次いで、対応するパケットを宛先CIに転送することができる。ブロック1220において、宛先CIは、宛先インターフェースからパケットを受信する。
【0200】
IGMP
L2物理ネットワークでは、フレームは、グループMACアドレスに関連付けられるデバイスのグループにマルチキャストされ得る。そうするために、このネットワークのスイッチは、ネットワークの異なるデバイスがグループMACアドレスを有するマルチキャストグループに追加されるべきかどうかを要求するIGMPクエリを、ネットワークの異なるデバイスに送信する。あるデバイスのIGMP応答が、そのデバイスがマルチキャストグループのメンバーであるべきであることを示す場合、スイッチは、そのデバイスのMACアドレスを、IGMPテーブルにおいて、そのグループMACアドレスに関連付ける。その後、スイッチは、グループMACアドレス宛のフレームを受信すると、そのフレームをマルチキャストグループのデバイスのMACアドレス宛の複数のフレームに複製し、複製したフレームを関連するデバイスに送信する。
【0201】
比較して、ここで説明するように、レイヤ2仮想ネットワークは、単一のスイッチを含まない。代わりに、分散型スイッチが実現され(ここではvスイッチまたはL2 vスイッチと呼ばれる)、1つ以上のNVD上でホストされる複数のL2 VNICおよびL2仮想スイッチを含む。したがって、レイヤ2仮想ネットワークの異なる計算インスタンスにIGMPクエリを送信するための単一の中央スイッチは存在しなくてもよい。代わりに、IGMPクエリは、L2仮想スイッチにわたって配信される必要がある。さらに、IGMP応答は、単一の中央スイッチによって受信されない。代わりに、各L2仮想スイッチが、対応する計算インスタンスからIGMP応答を受信し得る。グループマルチキャストを可能にするためには、複数のL2仮想スイッチが集める受信された応答からIGMPテーブルを作成して、それを複数のL2仮想スイッチに配信する必要がある。
【0202】
図13は、L2仮想ネットワーク構成を定義するのに適した例示的な環境を示す。実施形態では、環境は、1つ以上のネットワーク(図示せず)を介して顧客デバイス1320と通信するコンピュータシステム1310を含む。コンピュータシステム1310は、VCN1312をホストするハードウェアコンピューティングリソースのセットを含むことができる。ハードウェアコンピューティングリソースのうちの1つ以上によってホストされる制御プレーンは、顧客デバイス1320から入力を受信し、処理し、VCN1312内にL2仮想ネットワーク(図13ではL2VLAN1314として示される)を展開することができる。
【0203】
ある例では、顧客デバイス1320からの入力は、様々なタイプの情報を含むことができる。この情報は、コンソールまたはAPI呼出しを介して指定することができ、顧客指定される構成情報の中でもとりわけ、L2 VLAN構成1322を含むことができる。
【0204】
L2 VLAN構成1322は、例えば、L2 VLAN1314に含まれるべきL2計算インスタンスの数、タイプ、および構成を示すことができる。加えて、L2 VLAN構成1322は、顧客認知vスイッチ上のポートの顧客指定名、(L2計算インスタンスであり得る)計算インスタンスのMACアドレス、およびポートとMACアドレス(または、より一般的には、計算インスタンス)との間の関連付けを示すことができる。例えば、顧客は、L2 VLAN1314が2つのL2計算インスタンスを含む必要があることを指定することができ、第1のL2計算インスタンスはMACアドレスM.1を有し、P1と名付けられた第1のポートに関連付けられ、第2のL2計算インスタンスはMACアドレスM.2を有し、P2と名付けられた第2のポートに関連付けられる。
【0205】
制御プレーンは、種々の情報を受信し、次いで、L2 VLAN1314の異なるリソースを展開および管理する。例えば、L2 VLAN1314は、L2 VLAN構成1322に従って構成され、ホストマシン上でホストされる要求された計算インスタンスと、NVD上でホストされるL2 VNIC-L2仮想スイッチのペアとを含む。制御プレーンはまた、顧客指定のL2 VLAN構成1322とL2 VLAN1314の実際のトポロジとの間のマッピングを維持することができる。たとえば、マッピングは、L2 VNICがvスイッチのポートをエミュレートし、L2 VNIC(例えば、そのインターフェース識別子、そのMACアドレス(指定されない場合)、および/またはL2 VNICをホストするNVDのIPアドレス)をポートの名前(および指定される場合には、指定されたMACアドレス)と関連付けることができることを示す。マッピングはまた、L2 VNICおよび関連付けられるL2仮想スイッチを関連する計算インスタンスと関連付けることができ、L2 VNICおよびL2仮想スイッチをホストするNVDと、計算インスタンスをホストするホストマシンとを示す。
【0206】
図14は、レイヤ2仮想ネットワークにおける例示的なIGMP技術を示す図である。レイヤ2仮想ネットワークは、ここではVLANと呼ばれる。図14の上部は、VLANの実現図1410を示す。図14の下部は、VLANの顧客プレゼンテーション1420を示す。顧客プレゼンテーション1420は、レイヤ2仮想ネットワークが展開される顧客に、このネットワークのL2 vスイッチがIGMP対応ポートであるという認知を与える。実現図1410は、IGMP技術がどのように実現され得るかを示し、L2 vスイッチのポートは、L2 VNICによってエミュレートされ、このL2 VNICは、関連付けられるL2仮想スイッチとともに、IGMP機能をサポートすることができる。
【0207】
ある例では、ここにおいて上記で説明したように、NVDのL2 VNICは、着信トラフィックに基づいてインターフェース対MACアドレスマッピングを学習する。そのようなマッピングは、VLANの識別子とともに制御プレーン(例えば、制御プレーン、またはより一般的には、VLANを含むVCNのコンピュータシステム)に送られ得る。制御プレーンは、異なるL2 VNICをホストする異なるNVDから同様のマッピングを受信し、とりわけ、インターフェース識別子と、MACアドレスと、(たとえば、NVDの)物理IPアドレスと、VLAN識別子との間のマッピングを生成することができる。
【0208】
例えば、VNIC1は、M.2(計算インスタンス2のオーバーレイMACアドレス)はID.2(L2 VNIC2のインターフェース識別子)およびIP.2(NVD2の物理アドレス)に関連付けられること、ならびにM.n(計算インスタンスnのオーバーレイMACアドレス)はID.n(L2 VNIC nのインターフェース識別子)およびIP.n(NVD nの物理アドレス)に関連付けられることを学習する。同様に、VNIC2は、M.1(計算インスタンス1のオーバーレイMACアドレス)はID.1(L2 VNIC1のインターフェース識別子)およびIP.1(NVD1の物理アドレス)に関連付けられることを学習する。これらの関連付けは、マッピングの一部として制御プレーンに報告され、制御プレーンは、{顧客1;M.1→ID.1;IP.1;VLAN A}、{顧客1,M.2→ID.2,IP.2;VLAN A},...,{顧客1,M.n→ID.n,IP.n;VLAN A}のマッピングを生成することができる。
【0209】
さらに、制御プレーンは、顧客指定ポート名と物理ネットワーク上のVLANのリソースの分布との間のマッピングを生成して維持することができる。例えば、このマッピングは、ポート「i」が計算インスタンス「i」用に構成され、L2 VNIC「i」に対応し、それは、次いで、L2仮想スイッチ「i」に関連付けられ、このペアがNVD「i」によってホストされることを示す。このマッピングは、{顧客1;CI.1→P.1;P.1→M.1;M.1→ID.1,SW.1,IP.1;VLAN A}として表され得、ここで、「CI.1」は計算インスタンス1を(顧客によって定義された命名法を使用して)識別し、P.1はポート1を(顧客によって定義された命名法を使用して)識別し、M.1は計算インスタンス1に関連付けられるMACアドレスを識別し、ID.1はL2 VNIC1を識別し、SW.1はL2仮想スイッチ1を識別し、IP.1はNVD1のIPアドレスを特定し、VLAN AはVLANを識別する。
【0210】
したがって、制御プレーンは、VLANの顧客定義構成(例えば、計算インスタンス1はポート1などに接続される、等)、物理ネットワーク上の実際のネットワーク実現に対するVLANのマッピング、および顧客定義構成と実際の実現とを関連付けるマッピングを維持する。そのような情報は、制御プレーンがVLAN内のIGMP機能を統合することを可能にすることができる。
【0211】
例えば、マッピングに基づいて、制御プレーンは、VLANの計算インスタンスに関連付けられるL2仮想スイッチをホストするNVDを判断する(例えば、NVD1、NVD2、...、NVDn)。制御プレーンは、VLAN内の定期的なIGMPクエリについてこれらのNVDの各々に要求を送信する(例えば、NVD1、NVD2、...、NVDn)。この定期的な時間間隔は、30秒または何らかの他の所定の値であり得る。NVD(例えば、NVD1)は、要求を受信し、適用可能なL2 VNIC(例えば、L2 VNIC1)を判断する。次に、L2 VNIC(例えば、L2 VNIC1)は、IGMPクエリを、関連付けられる計算インスタンス(例えば、計算インスタンス1)に送信して、計算インスタンスがマルチキャストグループに追加されるべきかどうか(または以前に追加された場合にはマルチキャストグループから除去されるべきかどうか)を判断する。追加(または除去)に関する計算インスタンスのIGMP応答に応じて、L2 VNICは、関連付けられるL2仮想スイッチ(例えば、L2仮想スイッチ1)を更新し、L2仮想スイッチがそのローカルIGMP構成を更新することができるようにする(たとえば、追加の場合は、計算インスタンスのオーバーレイMACアドレスとマルチキャストグループのグループMACアドレス(たとえば、「M.G」)との間の関連を付けを含ませ、除去の場合は、この関連付けをローカルIGMPテーブルから削除する)。異なる計算インスタンスの応答(またはローカルIGMPテーブルに対する更新)も、制御プレーンに報告され、制御プレーンは、次いで、マッピングを更新して、計算インスタンス1およびnはマルチキャストグループのメンバーであるが、計算インスタンス2はそうではないことを示すIGMP構成(例えば、{顧客1,M.1→ID.1;IP.1;VLAN A,M.Gリスナ:yes},{顧客1M.2→ID.2,IP.2;VLAN A,リスナ:no},...,{顧客1,M.n→ID.n;IP.n;VLAN A,M.Gリスナ:yes})を含むようにする。制御プレーンは、収集されたIGMP構成(例えば、以下の形式をとるIGMPテーブル:{M.1,M.G,リスナ:yes},{M.2,M.G,リスナ:no},...,{M.n,M.G,リスナ:yes})の全体または部分をNVDに送信することができる。次に、NVDは、後続のフレームマルチキャストで使用するために、受信されたIGMP構成の関連部分でそれらのローカルL2仮想スイッチを更新する。
【0212】
マルチキャストは、ローカルに記憶されたIGMPテーブルに基づいてNVDにより実行され得る。例えば、NVD1は、計算インスタンス1のフレームを受信し、このフレームは、宛先MACアドレスとしてマルチキャストMACアドレス(例えば、M.G)を含む。そのローカルIGMPテーブル1に基づいて、L2仮想スイッチ1は、M.n(計算インスタンスnのMACアドレス)およびM.3(図14には示されていない計算インスタンス3のMACアドレス)がM.Gに関連付けられていると判断する。したがって、L2仮想スイッチ1は、フレームを2回複製し、その結果、宛先MACアドレスとしてM.nを有する第1のフレームと、宛先MACアドレスとしてM.3を有する第2のフレームとが得られる。これらの複製されたフレームは、L2 VNIC nおよびL2 VNIC 3に送られる(L2 VNIC3は、第3の計算インスタンス3に対応し、図14には示されていない)。
【0213】
ここにおいて上記でさらに説明されるように、VSRS VNICおよびVSRSスイッチをホストするNVDは、VLANとVLANの外部のリソースとの間の通信のために使用され得る。制御プレーンによって収集されるIGMP構成は、このNVDに送ることができる。したがって、マルチキャストグループに対する話者がVLANの外側にあるとき、VSRS VNICは、関連付けられるトラフィックを受信することができる。そのスイッチング機能に基づいて、VSRSスイッチは、マルチキャストグループに関連付けられるVLANの計算インスタンスを判断し、これらの計算インスタンスに関連付けられるレイヤ2VNICにマルチキャストフレームを送信する。
【0214】
図15は、レイヤ2仮想ネットワークにおいてIGMPテーブルを生成するためのプロセスを示すフローチャートである。ある実施形態では、プロセス1500は、下層物理ネットワーク上でのレイヤ2仮想ネットワークの展開を管理する制御プレーンまたは別のVCNシステムによって実行されることができる。明確にするために、プロセス1500は、異なる計算インスタンスのためにL2 VNICおよびL2仮想スイッチのペアを各々がホストする2つのNVDに関連して説明される。しかしながら、このプロセスは、異なる数のNVD、L2 VNIC-L2仮想スイッチペア、および/または計算インスタンスが存在する場合にも、同様に適用される。
【0215】
プロセス1500は、ブロック1502において開始し、制御プレーンは、第1のNVDから、L2仮想ネットワークの第1の計算インスタンスのIGMP応答に関する第1の情報を受信する。ある実施形態では、第1の情報は、第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示す。この計算インスタンスは、第1のNVDと通信可能に結合されたホストマシン上でホストされ得る。第1のNVDは、第1の計算インスタンスに関連付けられる第1のL2 VNICおよび第1のL2仮想スイッチをホストすることができる。ある実施形態では、制御プレーンは、IGMPクエリを実行する要求を第1のNVDに送信することができる。第1の情報は、第1のNVDから、要求に対する応答において受信される。そのような実施形態では、制御プレーンは、マッピング情報に基づいて、第1のNVDが、L2仮想ネットワークの計算インスタンスと関連付けられる第1のL2 VNICおよび第1のL2仮想スイッチをホストすることを判断することができ、この判断に基づいて要求を送信することができる。
【0216】
ブロック1504において、制御プレーンは、第2のNVDから、L2仮想ネットワークの第2の計算インスタンスのIGMP応答に関する第2の情報を受信する。ある実施形態では、第2の情報も、第2の計算インスタンスがマルチキャストグループに追加されるべきであることを示す。この計算インスタンスは、第2のNVDと通信可能に結合された同じまたは異なるホストマシン上でホストされ得る。第2のNVDは、第2の計算インスタンスに関連付けられる第2のL2 VNICおよび第2のL2仮想スイッチをホストすることができる。プロセス1500は、2つの異なるNVDに関連して説明されるが、このプロセスは、単一のNVDが複数のL2 VNICおよびL2仮想スイッチのペアをホストする場合にも適用される。ある実施形態では、制御プレーンは、IGMPクエリを実行する要求を第2のNVDに送信することができる。第2の情報は、第2のNVDから、要求に対する応答において受信される。そのような実施形態では、制御プレーンは、マッピング情報に基づいて、第2のNVDが、L2仮想ネットワークの第2の計算インスタンスと関連付けられる第2のL2 VNICおよび第2のL2仮想スイッチをホストすることを判断することができ、この判断に基づいて要求を送信することができる。ブロック1502および1504における要求は、ブロードキャストまたはユニキャストなどの任意のタイプの機構を使用して、並列にまたは連続的に送信され得る。
【0217】
ブロック1506において、制御プレーンは、第1の情報および第2の情報に基づいてIGMPテーブルを生成する。ある実施形態では、IGMPテーブルは、第1の計算インスタンスのMACアドレスおよび第2の計算インスタンスのMACアドレスをマルチキャストグループのグループMACアドレスと関連付け、2つのMACアドレスがリスナであることを示す。制御プレーンはまた、L2仮想ネットワークの別の計算インスタンスがマルチキャストグループに追加されるべきではない(またはマルチキャストグループから除去されるべきである)ことを示す情報を受信していてもよい。この場合、IGMPテーブルは、MACアドレスをグループMACアドレスとを関連付けないか、またはMACアドレスがリスナではないという関連付けを含むことができる。計算インスタンスのMACアドレスは、L2仮想ネットワークの顧客定義構成および物理ネットワーク上のL2仮想ネットワークのリソースの展開に関して制御プレーンによって維持されるマッピング情報に基づいて判断され得る。グループMACアドレスは、制御プレーンによって生成されるか、または顧客入力に基づいて定義され得る。
【0218】
ブロック1508において、制御プレーンは、IGMPテーブルの少なくとも第1の部分を第1のNVDに送信する。ある実施形態では、第1のNVDは、マルチキャストグループに関連付けられている第1の計算インスタンスに関する第1の情報を既に有する。したがって、制御プレーンは、IGMPテーブル全体を第1のNVDに送る必要はない。代わりに、制御プレーンは、第1のNVDにまだ利用可能でない可能性がある情報を含む、IGMPテーブルの部分を送信してもよい。例えば、この部分は、第2の計算インスタンスに関する情報(たとえば、第2の計算インスタンスとマルチキャストグループとの関連付け)を含み、第1の計算インスタンスに関する情報(たとえば、第1の計算インスタンスとマルチキャストグループとの関連付け)を含まない。他の実施形態では、IGMPテーブル全体が、第1のNVDに送信される。
【0219】
ブロック1510において、制御プレーンは、IGMPテーブルの少なくとも第2の部分を第2のNVDに送信する。ある実施形態では、第2のNVDは、マルチキャストグループに関連付けられる第2の計算インスタンスに関する第2の情報を既に有する。したがって、制御プレーンは、IGMPテーブル全体を第2のNVDに送信する必要はない。代わりに、制御プレーンは、第2のNVDにまだ利用可能でない可能性がある情報を含む、IGMPテーブルの部分を送信してもよい。例えば、この部分は、第1の計算インスタンスに関する情報(たとえば、第1の計算インスタンスとマルチキャストグループとの関連付け)を含み、第2の計算インスタンスに関する情報(たとえば、第2の計算インスタンスとマルチキャストグループとの関連付け)を含まない。他の実施形態では、IGMPテーブル全体が第2のNVDに送信される。
【0220】
図16は、レイヤ2仮想におけるにおいてIGMPテーブルを更新するためのプロセスを示すフローチャートである。ある実施形態では、プロセス1600は、下層の物理ネットワーク上でのレイヤ2仮想ネットワークの展開を管理する制御プレーンまたは別のVCNシステムによって実行されることができる。明確にするために、プロセス1600は、あるNVDからのある更新に関連して説明される。しかしながら、プロセス1600は、複数の更新が同じNVDまたは異なるNVDから受信される場合にも同様に適用される。IGMPテーブルは(たとえば、プロセス1500を実行することに基づいて)既に生成されていると仮定する。
【0221】
プロセス1600はブロック1602で始まり、制御プレーンは、第1のNVDから、マルチキャストグループに対する更新を示す第1の情報を受信する。ある実施形態では、第1の情報は、第1の計算インスタンスがマルチキャストグループから除去されるべきであること(マルチキャストグループにすでに追加されている場合)、またはマルチキャストグループに追加されるべきであること(マルチキャストグループに既に追加されていない場合、またはマルチキャストグループから以前に除去された場合)を示す。第1の情報は、第1のNVDが実現するプッシュ機構に基づいて受信することができ、または第1の情報は、IGMPクエリについての更新に対する制御プレーンからの要求に対する応答において受信することができる。
【0222】
ブロック1604において、制御プレーンは、IGMPテーブルに対する更新を生成する。ある実施形態では、第1の情報が、第1の計算デバイスが除去されるべきであることを示すとき、制御プレーンは、IGMPテーブルから、第1の計算インスタンスのマルチキャストグループとの関連付けを除去することによって(たとえば、第1の計算インスタンスのMACアドレスをグループMACアドレスと関連付けるエントリを削除することによって、または第1の計算インスタンスがマルチキャストグループに対するリスナではないことを示すことによって)、IGMPテーブルを更新する。逆に、第1の情報が、第1の計算デバイスが追加されるべきであることを示すとき、制御プレーンは、第1の計算インスタンスのマルチキャストグループとの関連付けをIGMPテーブルに追加することによって(たとえば、第1の計算インスタンスのMACアドレスをグループMACアドレスに関連付けるエントリを挿入することによって、または第1の計算インスタンスがマルチキャストグループに対するリスナであることを示すことによって)、IGMPテーブルを更新する。第1の実施形態では、この時点で、第1のNVDは、第1の計算インスタンスのマルチキャストグループに対するメンバシップに対する更新を反映するよう、それ自体のローカルIGMPテーブルを更新していてもよい。したがって、制御プレーンは、更新または更新されたIGMPテーブルを第1のNVDに送信する必要はない。そのような実施形態では、ブロック1606および1608を実行することができる。第2の実施形態では、制御プレーンは、定期的に、更新を受信すると、または閾値を超える数の更新を受信すると、更新されたIGMPテーブルおよび/または更新を、L2仮想ネットワークのL2 VNICおよびL2仮想スイッチのペアをホスティングするすべてのNVDに送信してもよい。
【0223】
ブロック1606において、制御プレーンは、更新が送信されるべきNVDのセットを判断する。上述のように、セットは、第1の実施形態では、第1のNVD以外の1つ以上のNVDを含むことができ、第2の実施形態では、第1のNVDを含むNVDを含むことができる。制御プレーンは、L2仮想ネットワークに関するマッピング情報に基づいてNVDのセットを判断することができる。第1の実施形態では、制御プレーンは第1のNVDを含まない。L2仮想ネットワークの第2の計算インスタンスに関連付けられる第2のL2 VNICおよびL2仮想スイッチをホストする第2のNVDについて、制御プレーンはまた、第2の計算インスタンスがマルチキャストグループのメンバーであるかどうかを判断することができる。第2の計算インスタンスがマルチキャストグループのメンバーである場合、制御プレーンは、フレームが第2の計算インスタンスから発生し、グループMACアドレスに宛てられる場合、このフレームは、もはや複製される必要はなくてもよく(更新が第1の計算インスタンスを除去する場合)、または複製される必要があってもよい(更新が第1の計算インスタンスを追加する場合)ため、第2のNVDは更新を受信するべきであると判断することができる。そうでない場合、制御プレーンは、第2のNVDは更新を受信する必要がないと判断することができる。第2の実施形態では、第1のNVDおよび第2のNVDはセットに追加される(例えば、それらの識別子がセットに含まれる)であろう。
【0224】
ブロック1608において、制御プレーンは、更新をNVDのセットに送信する。ある実施形態では、制御プレーンは、更新されたIGMPテーブル全体を送信する。いくつかの他の実施形態では、制御プレーンは、IGMPテーブルの更新された部分(例えば、追加されたエントリ、またはIGMPテーブルから除去され、セットからの各NVDがそのローカルIGMPテーブルから除去するエントリについての指示)のみを送信する。
【0225】
図17は、レイヤ2仮想ネットワークにおいてIGMPクエリを実行するためのプロセスを示すフローチャートである。ある実施形態では、プロセス1700は、第1の計算インスタンスに関連付けられる第1のL2 VNICおよび第1のL2仮想スイッチをホストするNVDによって実行することができ、L2仮想ネットワークは、L2 VNIC、L2仮想スイッチ、および第1の計算インスタンスを含む。明確にするために、プロセス1700は、単一のL2 VNIC-L2仮想スイッチのペアをホストするNVDに関連して説明される。しかしながら、このプロセスは、NVDが複数のそのようなペアをホストするときにも同様に適用される。この場合、NVDは、各L2仮想スイッチについてローカルIGMPテーブルを記憶することができ、またはNVDは、単一のローカルIGMPテーブルを記憶することができ、このテーブル内のエントリを異なるL2仮想スイッチに関連付ける。
【0226】
プロセス1700はブロック1702で開始し、NVDはIGMPクエリについて要求を受信する。ある実施形態では、要求は、L2仮想ネットワークを含むVCNの制御プレーンから(または別のVCNシステムから)定期的に受信される。制御プレーンによって記憶されたマッピング情報に基づいて、要求は、第1の計算インスタンスの識別子および/または第1の計算インスタンスのポートをエミュレートする第1のL2 VNICの識別子を含んでもよい。
【0227】
ブロック1704において、NVDは、IGMPクエリを第1の計算インスタンスに送信する。ある実施形態では、NVDは、要求および第1の計算インスタンスをホストするホストマシンに基づいて第1の計算インスタンスを識別する。次いで、NVDは、第1の計算インスタンスのIGMP応答が要求されることを示す要求をホストマシンに送信することができる。
【0228】
ブロック1706において、NVDは、第1の計算インスタンスのIGMP応答を受信する。ある実施形態では、IGMP応答は、IGMPクエリに対する応答として受信され、第1の計算インスタンスがマルチキャストグループに追加されるべきである(以前に追加されていない場合)か、またはマルチキャストグループから除去されるべきである(以前に追加されている場合)ことを示す。
【0229】
ブロック1708において、NVDは、IGMP応答に関する第1の情報を記憶する。ある実施形態では、第1の情報は、第1の計算インスタンスがマルチキャストグループに追加されるべきか、それともマルチキャストグループから除去されるべきかを示す。加えて、NVD(例えば、第1のL2 VNICまたは第1のL2仮想スイッチ)は、第1の計算インスタンスのマルチキャストグループとの関連付けを含むことができ、この関連付けは、第1のL2仮想スイッチのローカルIGMPテーブルに(たとえば、第1の計算インスタンスのMACアドレスをグループMACアドレスに関連付けるエントリを挿入することによって、または第1の計算インスタンスがマルチキャストグループに対するリスナであることを示すことによって、)記憶することができる。除去のために、NVD(例えば、第1のL2 VNICまたは第1のL2仮想スイッチ)は、ローカルIGMPテーブル)から、第1の計算インスタンスのマルチキャストグループとの関連付けを除去することができる(たとえば、対応するエントリが削除されるか、または第1の計算インスタンスがマルチキャストグループに対するリスナではないことを示す第1の情報)。
【0230】
ブロック1710において、NVDは、第1の情報をコンピュータシステムに送信する。ある実施形態では、コンピュータシステムは制御プレーンを含む。第1の情報は、マルチキャストグループにおける第1の計算インスタンスのメンバシップステータスを示す。
【0231】
ブロック1712において、NVDは、IGMPテーブルの少なくとも一部を受信する。ある実施形態では、NVDは、コンピュータシステムが第1の情報に基づいて生成および/または維持するIGMPテーブル全体を受信する。ある実施形態では、NVDは、このIGMPテーブルの一部分のみを受信し、この部分は、マルチキャストグループにおける第1の計算インスタンスのメンバシップに関する情報を含まず(なぜならば、この情報は、既にNVDに知られていてもよく、第1の情報に対応するので)、マルチキャストグループにおける第2の計算インスタンスのメンバシップに関する情報を含む。第2の計算インスタンスの一例は、代わりに第2の異なるNVDによってホストされる第2のL2 VNICおよび第2のL2仮想スイッチに関連付けられる計算インスタンスを含む。
【0232】
ブロック1714において、NVDはローカルIGMPテーブルを記憶する。ある実施形態では、NVDは、ブロック1712で受信された部分に基づいて、既に記憶されているローカルIGMPテーブルを更新する。例えば、受信された部分からのエントリがローカルIGMPテーブルに追加される。いくつかの他の実施形態では、NVDは、IGMPテーブル全体を受信する。その場合、NVDは、ローカルIGMPを受信されたIGMPテーブルと置き換えることができ、または両方のテーブルを比較し、ローカルIGMPテーブルから欠落しており、受信されたIGMPテーブルから利用可能なエントリを、ローカルIGMPテーブルに追加することができる。
【0233】
図18は、レイヤ2仮想ネットワークにおいてIGMPテーブルを使用するためのプロセスを示すフローチャートである。ある実施形態では、プロセス1800は、第1の計算インスタンスに関連付けられる第1のL2 VNICおよび第1のL2仮想スイッチをホストするNVDによって実行され得、L2仮想ネットワークは、L2 VNIC、L2仮想スイッチ、および第1の計算インスタンスを含む。明確にするために、プロセス1800は、単一のL2 VNIC-L2仮想スイッチのペアをホストするNVDに関連して説明される。しかしながら、このプロセスは、NVDが複数のそのようなペアをホストするときにも同様に適用される。この場合、NVDは、各L2仮想スイッチについてローカルIGMPテーブルを記憶することができ、またはNVDは、単一のローカルIGMPテーブルを記憶することができ、このテーブル内のエントリを異なるL2仮想スイッチに関連付ける。いずれにしても、IGMPテーブルエントリを調べて、フレームが複製されるべきかどうかを判断することができる。
【0234】
プロセス1800はブロック1802で開始し、ここでNVDはヘッダ情報を有するフレームを受信する。ある実施形態では、フレームは、ホストマシンを介して第1の計算インスタンスから受信することができる(例えば、フレームは、第1の計算インスタンスから送信されている発信フレームである)。
【0235】
ブロック1804において、NVDは、フレームが複製される必要があるかどうかを判断する。フレームが複製される場合、ブロック1806がブロック1804に続き、そうでない場合、ブロック1810がブロック1804に続く。ある実施形態では、この判断は、ヘッダ情報およびIGMPテーブルエントリを伴う。特に、NVDは、ヘッダ情報を解析して宛先MACアドレスを判断し、この宛先MACアドレスがマルチキャストグループのグループMACアドレスと一致するかどうかを判断する(たとえば、第1のL2 VNICは、フレームを第1のL2仮想スイッチに渡し、次いで、第1のL2仮想スイッチは、そのIGMPテーブルエントリの検索を実行する)。宛先MACアドレスがグループMACアドレスであると仮定すると、NVD(たとえば、第1のL2仮想スイッチ)は、フレームが複製されるべきであることと、グループMACアドレスに関連付けられる第2の計算インスタンスのMACアドレスと、コピーの数(これは、判断された第2の計算インスタンスの数に等しい)とを判断する。
【0236】
ブロック1806において、NVDは、フレームの複製を生成する。ある実施形態では、NVD(例えば、第1のL2仮想スイッチ)は、ペイロードをコピーし、宛先としてグループMACアドレスの代わりに第2の計算インスタンスのMACアドレスを含むようにヘッダ情報を変更する。このコピーは、ブロック1806で判断された第2の計算インスタンスの数に応じて必要に応じて繰り返すことができる。
【0237】
ブロック1808において、NVDは複製を送信する。ある実施形態では、複製されたフレームは、第1のL2仮想スイッチによって、第2の計算インスタンスと関連付けられる第2のL2 VNICに送信され、第2の計算インスタンスは、宛先MACアドレスを有する。このコピーは、ブロック1806で判断された第2の計算インスタンスの数に応じて必要に応じて繰り返すことができる。
【0238】
ブロック1810において、NVDはフレームを送信する。ここで、ヘッダ情報は宛先として第2の計算インスタンスのMACアドレスを含むため、フレームは、本来、マルチキャストグループではなく、第2の計算インスタンス宛である。したがって、ある実施形態では、フレームは、第1のL2仮想スイッチによって、第2の計算インスタンスと関連付けられる第2のL2 VNICに送信される。
【0239】
C.例示的なサービスとしてのインフラストラクチャのアーキテクチャ
上述したように、IaaS(Infrastructure as a Service)は、1つの特定の種類のクラウドコンピューティングである。IaaSは、パブリックネットワーク(例えば、インターネット)を介して仮想化計算リソースを提供するように構成されてもよい。IaaSモデルにおいて、クラウドコンピューティングプロバイダは、インフラストラクチャ要素(例えば、サーバ、記憶装置、ネットワークノード(例えば、ハードウェア)、展開ソフトウェア、プラットフォーム仮想化(例えば、ハイパーバイザ層)など)をホストすることができる。場合によっては、IaaSプロバイダは、インフラストラクチャ要素に付随する様々なサービス(例えば、課金、監視、ロギング、セキュリティ、負荷分散およびクラスタリングなど)を提供することができる。したがって、これらのサービスがポリシー駆動型であり得るため、IaaSユーザは、アプリケーションの可用性および性能を維持するために、負荷分散を駆動するためのポリシーを実装することができる。
【0240】
いくつかの例において、IaaS顧客は、インターネットなどの広域ネットワーク(WAN)を介してリソースおよびサービスにアクセスすることができ、クラウドプロバイダのサービスを使用してアプリケーションスタックの残りの要素をインストールすることができる。例えば、ユーザは、IaaSプラットフォームにログインして、仮想マシン(VM)を作成し、各VMにオペレーティングシステム(OS)をインストールし、データベースなどのミドルウェアを展開し、ワークロードおよびバックアップの記憶バケットを作成し、VMに企業ソフトウェアをインストールすることができる。顧客は、プロバイダのサービスを使用して、ネットワークトラフィックのバランシング、アプリケーションのトラブルシューティング、パフォーマンスの監視、災害復旧の管理などを含む様々な機能を実行することができる。
【0241】
殆どの場合、クラウドコンピューティングモデルは、クラウドプロバイダの参加を必要とする。クラウドプロバイダは、IaaSの提供(例えば、オファー、レンタル、販売)に特化した第3者サービスであってもよいが、その必要はない。また、企業は、プライベートクラウドを配置し、インフラストラクチャサービスを提供するプロバイダになることもできる。
【0242】
いくつかの例において、IaaSの配置は、用意したアプリケーションサーバなどに新しいアプリケーションまたは新しいバージョンのアプリケーションを配置するプロセスである。IaaSの配置は、サーバを用意する(例えば、ライブラリ、デーモンなどをインストールする)プロセスを含んでもよい。IaaSの配置は、多くの場合、クラウドプロバイダによって、ハイパーバイザ層(例えば、サーバ、記憶装置、ネットワークハードウエア、および仮想化)の下で管理される。したがって、顧客は、OS、ミドルウェア、および/またはアプリケーションの展開(例えば、セルフサービス仮想マシン(例えば、オンデマンドでスピンアップできるもの)などを行うことができる。
【0243】
いくつかの例において、IaaSのプロビジョニングは、使用されるコンピュータまたは仮想ホストを取得すること、およびコンピュータまたは仮想ホスト上に必要なライブラリまたはサービスをインストールすることを含んでもよい。殆どの場合、配置は、プロビジョニングを含まず、まずプロビジョニングを実行する必要がある。
【0244】
場合によっては、IaaSのプロビジョニングには2つの異なる課題がある。第1に、何かを実行する前に、インフラストラクチャの初期セットをプロビジョニングするという課題がある。第2に、全てのものをプロビジョニングした後に、既存のインフラストラクチャを進化させる(例えば、新しいサービスの追加、サービスの変更、サービスの削除)という課題がある。場合によっては、インフラストラクチャの構成を宣言的に定義することを可能にすることによって、これらの2つの課題に対処することができる。言い換えれば、インフラストラクチャ(例えば、どの要素が必要とされるか、およびこれらの要素がどのように相互作用するか)は、1つ以上の構成ファイルによって定義されてもよい。したがって、インフラストラクチャの全体的なトポロジ(例えば、どのリソースがどれに依存し、どのように連携するか)は、宣言的に記述することができる。いくつかの例において、トポロジが定義されると、構成ファイルに記述された異なる要素を作成および/または管理するためのワークフローを生成することができる。
【0245】
いくつかの例において、インフラストラクチャは、多くの相互接続された要素を含むことができる。例えば、コアネットワークとしても知られている1つ以上の仮想プライベートクラウド(VPC)(例えば、構成可能な計算リソースおよび/または共有されている計算リソースの潜在的なオンデマンドプール)が存在してもよい。いくつかの例において、ネットワークのセキュリティがどのように設定されるかを定義するためにプロビジョニングされる1つ以上のセキュリティグループルールと、1つ以上の仮想マシン(VM)とが存在する可能性がある。ロードバランサ、データベースなどの他のインフラストラクチャ要素もプロビジョニングされてもよい。ますます多くのインフラストラクチャ要素が望まれるおよび/または追加されるにつれて、インフラストラクチャは、漸進的に進化することができる。
【0246】
いくつかの例において、様々な仮想コンピューティング環境にわたってインフラストラクチャコードの展開を可能にするために、連続展開技法を採用してもよい。また、記載された技法は、これらの環境内のインフラストラクチャ管理を可能にすることができる。いくつかの例において、サービスチームは、1つ以上の、通常多くの異なる生産環境(例えば、時には全世界に及ぶ種々の異なる地理的場所にわたって)に展開されることが望まれるコードを書き込むことができる。しかしながら、いくつかの例において、コードを展開するためのインフラストラクチャを最初に設定しなければならない。いくつかの例において、プロビジョニングは、手動で行うことができ、プロビジョニングツールを用いてリソースをプロビジョニングすることができ、および/またはインフラストラクチャをプロビジョニングした後に、展開ツールを用いてコードを展開することができる。
【0247】
図19は、少なくとも1つの実施形態に従って、IaaSアーキテクチャの例示的なパターンを示すブロック図1900である。サービスオペレータ1902は、仮想クラウドネットワーク(VCN)1906およびセキュアホストサブネット1908を含み得るセキュアホストテナンシ1904に通信可能に結合されてもよい。いくつかの例において、サービスオペレータ1902は、1つ以上のクライアントコンピューティング装置を使用することができる。1つ以上のクライアントコンピューティング装置は、例えば、Microsoft Windows Mobile(登録商標)のようなソフトウェア、および/またはiOS、Windowsフォン、アンドロイド(登録商標)、ブラックベリー8およびパームOSなどのさまざまなモバイルオペレーティングシステムを実行することができ、インターネット、電子メール、ショートメッセージサービス(SMS)、ブラックベリー(登録商標)または他の通信プロトコルが有効化された手持ち式携帯装置(例えば、iPhone(登録商標)、携帯電話、Ipad(登録商標)、タブレット、携帯情報端末(PDA)またはウェアラブル装置(Google(登録商標)Glass(登録商標)ヘッドマウントディスプレイ)であってもよい。クライアントコンピューティング装置は、例示として、Microsoft Windows(登録商標)オペレーティングシステム、Apple Macintosh(登録商標)オペレーティングシステムおよび/またはLinux(登録商標)オペレーティングシステムのさまざまなバージョンを実行するパーソナルコンピュータおよび/またはラップトップコンピュータを含む汎用のパーソナルコンピュータであってもよい。代替的には、クライアントコンピューティング装置は、例えば、さまざまなGNU/Linuxオペレーティングシステム、例えば、Google Chrome(登録商標)OSを含むがこれに限定されない市販のUNIX(登録商標)またはUNIXに類似するさまざまなオペレーティングシステムを実行するワークステーションコンピュータであってもよい。代替的にまたは追加的には、クライアントコンピューティング装置は、VCN1906および/またはインターネットにアクセスできるネットワークを介して通信可能な他の電子機器、例えば、シンクライアントコンピュータ、インターネット対応のゲームシステム(例えば、Kinect(登録商標)ジェスチャ入力装置を備えるまたは備えないMicrosoft Xbox(登録商標)ゲームコンソール)、および/またはパーソナルメッセージング装置であってもよい。
【0248】
VCN1906は、SSH VCN1912に含まれるLPG1910を介して、セキュアシェル(SSH)VCN1912に通信可能に結合できるローカルピアリングゲートウェイ(LPG)1910を含むことができる。SSH VCN1912は、SSHサブネット1914を含むことができ、SSH VCN1912は、制御プレーンVCN1916に含まれるLPG1910を介して、制御プレーンVCN1916に通信可能に結合されることができる。また、SSH VCN1912は、LPG1910を介して、データプレーンVCN1918に通信可能に結合されることができる。制御プレーンVCN1916およびデータプレーンVCN1918は、IaaSプロバイダによって所有および/または運営され得るサービステナンシ1919に含まれてもよい。
【0249】
制御プレーンVCN1916は、境界ネットワーク(例えば、企業イントラネットと外部ネットワークとの間の企業ネットワークの部分)として機能する制御プレーンDMZ(demilitarized zone)層1920を含むことができる。DMZベースのサーバは、特定の信頼性を有し、セキュリティ侵害を封じ込めることができる。さらに、DMZ層1920は、1つ以上のロードバランサ(LB)サブネット1922と、アプリサブネット1926を含むことができる制御プレーンアプリ層1924と、データベース(DB)サブネット1930(例えば、フロントエンドDBサブネットおよび/またはバックエンドDBサブネット)を含むことができる制御プレーンデータ層1928とを含むことができる。制御プレーンDMZ層1920に含まれたLBサブネット1922は、制御プレーンアプリ層1924に含まれるアプリサブネット1926と制御プレーンVCN1916に含まれ得るインターネットゲートウェイ1934とに通信可能に結合されてもよく、アプリサブリ1926は、制御プレーンデータ層1928に含まれるDBサブネット1930と、サービスゲートウェイ1936と、ネットワークアドレス変換(NAT)ゲートウェイ1938とに通信可能に結合されてもよい。制御プレーンVCN1916は、サービスゲートウェイ1936およびNATゲートウェイ1938を含むことができる。
【0250】
制御プレーンVCN1916は、データプレーンミラーアプリ層1940を含むことができ、データプレーンミラーアプリ層1940は、アプリサブネット1926を含むことができる。データプレーンミラーアプリ層1940に含まれたアプリサブネット1926は、計算インスタンス1944を実行することができる仮想ネットワークインターフェイスコントローラ(VNIC)1942を含むことができる。計算インスタンス1944は、データプレーンミラーアプリ層1940のアプリサブネット1926を、データプレーンアプリ層1946に含まれ得るアプリサブネット1926に通信可能に結合することができる。
【0251】
データプレーンVCN1918は、データプレーンアプリ層1946と、データプレーンDMZ層1948と、データプレーンデータ層1950とを含むことができる。データプレーンDMZ層1948は、データプレーンアプリ層1946のアプリサブネット1926およびデータプレーンVCN1918のインターネットゲートウェイ1934に通信可能に結合され得るLBサブネット1922を含むことができる。アプリサブネット1926は、データプレーンVCN1918のサービスゲートウェイ1936およびデータプレーンVCN1918のNATゲートウェイ1938に通信可能に結合されてもよい。また、データプレーンデータ層1950は、データプレーンアプリ層1946のアプリサブネット1926に通信可能に結合され得るDBサブネット1930を含むことができる。
【0252】
制御プレーンVCN1916のインターネットゲートウェイ1934およびデータプレーンVCN1918のインターネットゲートウェイ1934は、パブリックインターネット1954に通信可能に結合され得るメタデータ管理サービス1952に通信可能に結合されてもよい。パブリックインターネット1954は、制御プレーンVCN1916のNATゲートウェイ1938およびデータプレーンVCN1918のNATゲートウェイ1938に通信可能に結合されてもよい。制御プレーンVCN1916のサービスゲートウェイ1936およびデータプレーンVCN1918のサービスゲートウェイ1936は、クラウドサービス1956に通信可能に結合されてもよい。
【0253】
いくつかの例において、制御プレーンVCN1916またはデータプレーンVCN1918のサービスゲートウェイ1936は、パブリックインターネット1954を経由することなく、クラウドサービス1956へのアプリケーションプログラミングインターフェイス(API)呼び出しを行うことができる。サービスゲートウェイ1936からのクラウドサービス1956へのAPI呼び出しは、一方向であり得る。サービスゲートウェイ1936は、クラウドサービス1956へのAPI呼び出しを行うことができ、クラウドサービス1956は、要求データをサービスゲートウェイ1936に送信することができる。しかしながら、クラウドサービス1956は、サービスゲートウェイ1936へのAPI呼び出しを開始しないことがある。
【0254】
いくつかの例において、セキュアホストテナンシ1904は、孤立であり得るサービステナンシ1919に直接に接続されてもよい。セキュアホストサブネット1908は、孤立のシステムとの双方向通信を可能にするLPG1910を介して、SSHサブネット1914と通信することができる。セキュアホストサブネット1908をSSHサブネット1914に接続することによって、セキュアホストサブネット1908は、サービステナンシ1919内の他のエンティティにアクセスすることができる。
【0255】
制御プレーンVCN1916は、サービステナンシ1919のユーザが所望のリソースを設定またはプロビジョニングすることを可能にする。制御プレーンVCN1916においてプロビジョニングされた所望のリソースは、データプレーンVCN1918において展開または使用されてもよい。いくつかの例において、制御プレーンVCN1916は、データプレーンVCN1918から隔離されてもよく、制御プレーンVCN1916のデータプレーンミラーアプリ層1940は、データプレーンミラーアプリ層1940およびデータプレーンアプリ層1946に含まれ得るVNIC1942を介して、データプレーンVCN1918のデータプレーンアプリ層1946と通信することができる。
【0256】
いくつかの例において、システムのユーザまたは顧客は、要求をメタデータ管理サービス1952に通信することができるパブリックインターネット1954を介して、例えば、作成、読み取り、更新、または削除(CRUD)操作などの要求を行うことができる。メタデータ管理サービス1952は、インターネットゲートウェイ1934を介して、要求を制御プレーンVCN1916に通信することができる。要求は、制御プレーンDMZ層1920に含まれるLBサブネット1922によって受信されてもよい。LBサブネット1922は、要求が有効であると判断することができ、この判断に応答して、LBサブネット1922は、要求を制御プレーンアプリ層1924に含まれるアプリサブネット1926に送信することができる。要求が検証され、パブリックインターネット1954への呼び出しを必要とする場合、パブリックインターネット1954への呼び出しを、パブリックインターネット1954への呼び出しを行うことができるNATゲートウェイ1938に送信することができる。要求を記憶するためのメモリは、DBサブネット1930に格納されてもよい。
【0257】
いくつかの例において、データプレーンミラーアプリ層1940は、制御プレーンVCN1916とデータプレーンVCN1918との間の直接通信を容易にすることができる。例えば、構成に対する変更、更新、または他の適切な修正は、データプレーンVCN1918に含まれるリソースに適用されることが望ましい場合がある。制御プレーンVCN1916は、VNIC1942を介してデータプレーンVCN1918に含まれるリソースと直接に通信することができるため、構成に対する変更、更新、または他の適切な修正を実行することができる。
【0258】
いくつかの実施形態において、制御プレーンVCN1916およびデータプレーンVCN1918は、サービステナンシ1919に含まれてもよい。この場合、システムのユーザまたは顧客は、制御プレーンVCN1916またはデータプレーンVCN1918のいずれかを所有または操作しなくてもよい。代わりに、IaaSプロバイダは、制御プレーンVCN1916およびデータプレーンVCN1918を所有または操作してもよく、これらの両方は、サービステナンシ1919に含まれてもよい。この実施形態は、ネットワークの隔離を可能にすることによって、ユーザまたは顧客が他のユーザのリソースまたは他の顧客のリソースと対話することを防止できる。また、この実施形態は、システムのユーザまたは顧客が、記憶するための所望のレベルのセキュリティを有しない可能性のあるパブリックインターネット1954に依存する必要なく、データベースをプライベートに記憶することを可能にすることができる。
【0259】
他の実施形態において、制御プレーンVCN1916に含まれるLBサブネット1922は、サービスゲートウェイ1936から信号を受信するように構成されてもよい。この実施形態において、制御プレーンVCN1916およびデータプレーンVCN1918は、パブリックインターネット1954を呼び出すことなく、IaaSプロバイダの顧客によって呼び出されるように構成されてもよい。顧客が使用するデータベースは、IaaSプロバイダによって制御され、パブリックインターネット1954から隔離され得るサービステナンシ1919に格納され得るため、IaaSプロバイダの顧客は、この実施形態を望む場合がある。
【0260】
図20は、少なくとも1つの実施形態に従って、IaaSアーキテクチャの別の例示的なパラメータを示すブロック図2000である。サービスオペレータ2002(例えば、図19のサービスオペレータ1902)は、仮想クラウドネットワーク(VCN)2006(例えば、図19のVCN1906)およびセキュアホストサブネット2008(例えば、図19のセキュアホストサブネット1908)を含み得るセキュアホストテナンシ2004(例えば、図19のセキュアホストテナンシ1904)に通信可能に結合されてもよい。VCN2006は、SSH VCN2012に含まれるLPG1910を介してセキュアシェル(SSH)VCN2012(例えば、図19のSSH VCN1912)に通信可能に結合され得るローカルピアリングゲートウェイ(LPG)2010(例えば、図19のLPG1910)を含むことができる。SSH VCN2012は、SSHサブネット2014(例えば、図19のSSHサブネット1914)を含むことができ、SSH VCN2012は、制御プレーンVCN2016に含まれるLPG2010を介して制御プレーンVCN2016(例えば、図19の制御プレーンVCN1916)に通信可能に結合することができる。制御プレーンVCN2016は、サービステナンシ2019(例えば、図19のサービステナンシ1919)に含まれてもよく、データプレーンVCN2018(例えば、図19のデータプレーンVCN1918)は、システムのユーザまたは顧客によって所有または運営され得る顧客テナンシ2021に含まれてもよい。
【0261】
制御プレーンVCN2016は、LBサブネット2022(例えば、図19のLBサブネット1922)を含むことができる制御プレーンDMZティア2020(例えば、図19の制御プレーンDMZ層1920)と、アプリサブネット2026(例えば、図19のアプリサブネット1926)を含むことができる制御プレーンアプリ層2024(例えば、図19の制御プレーンアプリ層1924)と、データベース(DB)サブネット2030(例えば、図19のDBサブネット1930と同様)を含むことができる制御プレーンデータティア2028(例えば、図19の制御プレーンデータ層1928)とを含むことができる。制御プレーンDMZ層2020に含まれるLBサブネット2022は、制御プレーンアプリ層2024に含まれるアプリサブネット2026と、制御プレーンVCN2016に含まれ得るインターネットゲートウェイ2034(例えば、図19のインターネットゲートウェイ1934)とに通信可能に結合されてもよい。アプリサブネット2026は、制御プレーンデータ層2028に含まれるDBサブネット2030、サービスゲートウェイ2036(例えば、図19のサービスゲートウェイ)およびネットワークアドレス変換(NAT)ゲートウェイ2038(例えば、図19のNATゲートウェイ1938)に通信可能に結合されてもよい。制御プレーンVCN2016は、サービスゲートウェイ2036およびNATゲートウェイ2038を含むことができる。
【0262】
制御プレーンVCN2016は、アプリサブネット2026を含むことができるデータプレーンミラーアプリ層2040(例えば、図19のデータプレーンミラーアプリ層1940)を含むことができる。データプレーンミラーアプリ層2040に含まれるアプリサブネット2026は、(例えば、図19の計算インスタンス1944と同様の)計算インスタンス2044を実行することができる仮想ネットワークインターフェイスコントローラ(VNIC)2042(例えば、VNIC1942)を含むことができる。計算インスタンス2044は、データプレーンミラーアプリ層2040に含まれるVNIC2042およびデータプレーンアプリ層2046に含まれるVNIC2042を介して、データプレーンミラーアプリ層2040のアプリサブネット2026と、データプレーンアプリ層2046(例えば、図19のデータプレーンアプリ層1946)に含まれ得るアプリサブネット2026との間の通信を促進することができる。
【0263】
制御プレーンVCN2016に含まれるインターネットゲートウェイ2034は、パブリックインターネット2054(例えば、図19のパブリックインターネット1954)に通信可能に結合され得るメタデータ管理サービス2052(例えば、図19のメタデータ管理サービス1952)に通信可能に結合されてもよい。パブリックインターネット2054は、制御プレーンVCN2016に含まれるNATゲートウェイ2038に通信可能に結合されてもよい。制御プレーンVCN2016に含まれるサービスゲートウェイ2036は、クラウドサービス2056(例えば、図19のクラウドサービス1956)に通信可能に結合されてもよい。
【0264】
いくつかの例において、データプレーンVCN2018は、顧客テナンシ2021に含まれてもよい。この場合、IaaSプロバイダは、顧客ごとに制御プレーンVCN2016を提供することができ、IaaSプロバイダは、顧客ごとに、サービステナンシ2019に含まれる固有の計算インスタンス2044を構成することができる。各計算インスタンス2044は、サービステナンシ2019に含まれる制御プレーンVCN2016と、顧客テナンシ2021に含まれるデータプレーンVCN2018との間の通信を許可することができる。計算インスタンス2044は、サービステナンシ2019に含まれる制御プレーンVCN2016においてプロビジョニングされるリソースを、顧客テナンシ2021に含まれるデータプレーンVCN2018に展開することまたは使用することを許可することができる。
【0265】
他の例において、IaaSプロバイダの顧客は、顧客テナンシ2021に存在するデータベースを有することができる。この例において、制御プレーンVCN2016は、アプリサブネット2026を含むことができるデータプレーンマイナーアプリ層2040を含むことができる。データプレーンミラーアプリ層2040は、データプレーンVCN2018に存在してもよいが、データプレーンミラーアプリ層2040は、データプレーンVCN2018に存在しなくてもよい。すなわち、データプレーンミラーアプリ層2040は、顧客テナンシ2021にアクセスすることができるが、データプレーンミラーアプリ層2040は、データプレーンVCN2018に存在しなくてもよく、IaaSプロバイダの顧客によって所有または運営されなくてもよい。データプレーンミラーアプリ層2040は、データプレーンVCN2018への呼び出しを行うように構成されてもよいが、制御プレーンVCN2016に含まれる任意のエンティティへの呼び出しを行うように構成されなくてもよい。顧客は、制御プレーンVCN2016にプロビジョニングされたデータプレーンVCN2018内のリソースを展開することまたは使用することを望むことができ、データプレーンミラーアプリケーション階層2040は、顧客のリソースの所望の展開または他の使用を促進することができる。
【0266】
いくつかの実施形態において、IaaSプロバイダの顧客は、フィルタをデータプレーンVCN2018に適用することができる。この実施形態において、顧客は、データプレーンVCN2018がアクセスできるものを決定することができ、顧客は、データプレーンVCN2018からのパブリックインターネット2054へのアクセスを制限することができる。IaaSプロバイダは、データプレーンVCN2018から任意の外部ネットワークまたはデータベースへのアクセスにフィルタを適用するまたは制御することができない場合がある。顧客が顧客テナンシ2021に含まれるデータプレーンVCN2018にフィルタおよび制御を適用することは、データプレーンVCN2018を他の顧客およびパブリックインターネット2054から隔離することを支援することができる。
【0267】
いくつかの実施形態において、クラウドサービス2056は、サービスゲートウェイ2036によって呼び出されて、パブリックインターネット2054上に、制御プレーンVCN2016上に、またはデータプレーンVCN2018上に存在していない可能性があるサービスにアクセスすることができる。クラウドサービス2056と制御プレーンVCN2016またはデータプレーンVCN2018との間の接続は、ライブまたは連続的でなくてもよい。クラウドサービス2056は、IaaSプロバイダによって所有または運営されている別のネットワーク上に存在してもよい。クラウドサービス2056は、サービスゲートウェイ2036から呼び出しを受信するように構成されてもよく、パブリックインターネット2054から呼び出しを受信しないように構成されてもよい。いくつかのクラウドサービス2056は、他のクラウドサービス2056から隔離されてもよく、制御プレーンVCN2016は、制御プレーンVCN2016と同じ地域に配置していない可能性があるクラウドサービス2056から隔離されてもよい。例えば、制御プレーンVCN2016は、「地域1」に配置されてもよく、クラウドサービス「展開19」は、「地域1」および「地域2」に配置されてもよい。展開19への呼び出しが地域1に配置された制御プレーンVCN2016に含まれるサービスゲートウェイ2036によって行われる場合、この呼び出しは、地域1内の展開19に送信されてもよい。この例において、制御プレーンVCN2016または地域1の展開19は、地域2の展開19と通信可能に結合されなくてもよい。
【0268】
図21は、少なくとも1つの実施形態に従って、IaaSアーキテクチャの別の例示的なパターンを示すブロック図2100である。サービスオペレータ2102(例えば、図19のサービスオペレータ1902)は、仮想クラウドネットワーク(VCN)2106(例えば、図19のVCN1906)およびセキュアホストサブネット2108(例えば、図19のセキュアホストサブネット1908)を含み得るセキュアホストテナンシ2104(例えば、図19のセキュアホストテナンシ1904)に通信可能に結合されてもよい。VCN2106は、SSH VCN2112に含まれるLPG2110を介してSSH VCN2112(例えば、図19のSSH VCN1912)に通信可能に結合され得るLPG2110(例えば、図19のLPG1910)を含むことができる。SSH VCN2112は、SSHサブネット2114(例えば、図19のSSHサブネット1914)を含むことができ、SSH VCN2112は、制御プレーンVCN2116に含まれるLPG2110を介して制御プレーンVCN2116(例えば、図19の制御プレーンVCN1916)に通信可能に結合されてもよく、データプレーンVCN2118に含まれるLPG2110を介してデータプレーンVCN2118(例えば、図19のデータプレーン1918)に通信可能に結合されてもよい。制御プレーンVCN2116およびデータプレーンVCN2118は、サービステナンシ2119(例えば、図19のサービステナント1919)に含まれてもよい。
【0269】
制御プレーンVCN2116は、ロードバランサ(LB)サブネット2122(例えば、図19のLBサブネット1922)を含むことができる制御プレーンDMZ層2120(例えば、図19の制御プレーンDMZ層1920)と、アプリサブネット2126(例えば、図19のアプリサブネット1926と同様)を含むことができる制御プレーンアプリ層2124(例えば、図19の制御プレーンアプリ層1924)と、DBサブネット2130を含むことができる制御プレーンデータ層2128(例えば、図19の制御プレーンデータ層1928)とを含むことができる。制御プレーンDMZ層2120に含まれるLBサブネット2122は、制御プレーンアプリ層2124に含まれるアプリサブネット2126と、制御プレーンVCN2116に含まれ得るインターネットゲートウェイ2134(例えば、図19のインターネットゲートウェイ1934)とに通信可能に結合されてもよい。アプリサブネット2126は、制御プレーンデータ層2128に含まれるDBサブネット2130と、サービスゲートウェイ2136(例えば、図19のサービスゲートウェイ)およびネットワークアドレス変換(NAT)ゲートウェイ2138(例えば、図19のNATゲートウェイ1938)とに通信可能に結合されてもよい。制御プレーンVCN2116は、サービスゲートウェイ2136およびNATゲートウェイ2138を含むことができる。
【0270】
データプレーンVCN2118は、データプレーンアプリ層2146(例えば、図19のデータプレーンアプリ層1946)と、データプレーンDMZ層2148(例えば、図19のデータプレーンDMZ層1948)と、データプレーンデータ層2150(例えば、図19のデータプレーンデータ階層1950)とを含むことができる。データプレーンDMZ層2148は、データプレーンVCN2118に含まれるデータプレーンアプリ層2146およびインターネットゲートウェイ2134の信頼できるアプリサブネット2160および信頼できないアプリサブネット2162に通信可能に結合され得るLBサブネット2122を含むことができる。信頼できるアプリサブネット2160は、データプレーンVCN2118に含まれるサービスゲートウェイ2136、データプレーンVCN2118に含まれるNATゲートウェイ2138、およびデータプレーンデータ層2150に含まれるDBサブネット2130に通信可能に結合されてもよい。信頼できないアプリサブネット2162は、データプレーンVCN2118に含まれるサービスゲートウェイ2136、およびデータプレーンデータ層2150に含まれるDBサブネット2130に通信可能に結合されてもよい。データプレーンデータ層2150は、データプレーンVCN2118に含まれるサービスゲートウェイ2136に通信可能に結合され得るDBサブネット2130を含むことができる。
【0271】
信頼できないアプリサブネット2162は、テナント仮想マシン(VM)2166(1)~(N)に通信可能に結合され得る1つ以上のプライマリVNIC2164(1)~(N)を含むことができる。各テナントVM2166(1)~(N)は、それぞれの顧客テナンシ2170(1)~(N)に含まれ得るそれぞれのコンテナ送信VCN2168(1)~(N)に含まれ得るそれぞれのアプリサブネット2167(1)~(N)に通信可能に結合されてもよい。それぞれのセカンダリVNIC2172(1)~(N)は、データプレーンVCN2118に含まれる信頼できないアプリサブネット2162と、コンテナ送信VCN2168(1)~(N)に含まれるアプリサブネットとの間の通信を促進することができる。各コンテナ送信VCN2168(1)~(N)は、パブリックインターネット2154(例えば、図19のパブリックインターネット1954)に通信可能に結合され得るNATゲートウェイ2138を含むことができる。
【0272】
制御プレーンVCN2116に含まれるインターネットゲートウェイ2134およびデータプレーンVCN2118に含まれるインターネットゲートウェイ2134は、パブリックインターネット2154に通信可能に結合され得るメタデータ管理サービス2152(例えば、図19のメタデータ管理システム1952)に通信可能に結合されてもよい。パブリックインターネット2154は、制御プレーンVCN2116に含まれるNATゲートウェイ2138およびデータプレーンVCN2118に含まれるNATゲートウェイ2138に通信可能に結合されてもよい。制御プレーンVCN2116に含まれるサービスゲートウェイ2136およびデータプレーンVCN2118に含まれるサービスゲートウェイ2136は、クラウドサービス2156に通信可能に結合されてもよい。
【0273】
いくつかの実施形態において、データプレーンVCN2118は、顧客テナンシ2170に統合されてもよい。この統合は、コードを実行するときにサポートを望む場合がある場合などのいくつかの場合において、IaaSプロバイダの顧客にとって有用または望ましい場合がある。顧客は、実行すると、破壊的であり得る、他の顧客リソースと通信し得る、または望ましくない影響を引き起こし得るコードを提供することがある。従って、IaaSプロバイダは、顧客がIaaSプロバイダに提供したコードを実行するか否かを判断することができる。
【0274】
いくつかの例において、IaaSプロバイダの顧客は、一時的なネットワークアクセスをIaaSプロバイダに許可することができ、データプレーンアプリ層2146に追加する機能を要求することができる。機能を実行するためのコードは、VM2166(1)~(N)で実行されてもよいが、データプレーンVCN2118上の他の場所で実行されるように構成されることができない。各VM2166(1)~(N)は、1つの顧客テナンシ2170に接続されてもよい。VM2166(1)~(N)に含まれるそれぞれのコンテナ2171(1)~(N)は、コードを実行するように構成されてもよい。この場合、二重の隔離(例えば、コンテナ2171(1)~(N)は、コードを実行し、コンテナ2171(1)~(N)は、少なくとも、信頼できないアプリサブネット2162に含まれるVM2166(1)~(N)に含まれ得る)が存在してもよく、これは、誤ったコードまたは望ましくないコードがIaaSプロバイダのネットワークに損傷を与えること、または異なる顧客のネットワークに損傷を与えることを防止することを支援することができる。コンテナ2171(1)~(N)は、顧客テナンシ2170に通信可能に結合されてもよく、顧客テナンシ2170からデータを送信または受信するように構成されてもよい。コンテナ2171(1)~(N)は、データプレーンVCN2118内の任意の他のエンティティからデータを送信または受信するように構成されなくてもよい。コードの実行が完了すると、IaaS提供者は、コンテナ2171(I)~(N)をキルするまたは廃棄することができる。
【0275】
いくつかの実施形態において、信頼できるアプリサブネット2160は、IaaSプロバイダによって所有または運営され得るコードを実行することができる。この実施形態において、信頼できるアプリサブネット2160は、DBサブネット2130に通信可能に結合され、DBサブネット2130においてCRUD操作を実行するように構成されてもよい。信頼できないアプリサブネット2162は、DBサブネット2130に通信可能に結合され得るが、この実施形態において、信頼できないアプリサブネットは、DBサブネット2130内で読み取り操作を実行するように構成されてもよい。各顧客のVM2166(1)~(N)に含まれ、顧客からのコードを実行することができるコンテナ2171(1)~(N)は、DBサブネット2130と通信可能に結合されなくてもよい。
【0276】
他の実施形態において、制御プレーンVCN2116およびデータプレーンVCN2118は、通信可能に直接に結合されなくてもよい。この実施形態において、制御プレーンVCN2116とデータプレーンVCN2118との間に直接的な通信は、存在しないことがある。しかしながら、少なくとも1つの方法による間接的な通信は、存在してもよい。制御プレーンVCN2116とデータプレーンVCN2118との間の通信を容易にすることができるLPG2110が、IaaSプロバイダによって確立されてもよい。別の例において、制御プレーンVCN2116またはデータプレーンVCN2118は、サービスゲートウェイ2136を介してクラウドサービス2156への呼び出しを行うことができる。例えば、制御プレーンVCN2116からクラウドサービス2156への呼び出しは、データプレーンVCN2118と通信することができるサービスの要求を含むことができる。
【0277】
図22は、少なくとも1つの実施形態に従って、IaaSアーキテクチャの別の例示的なパラメータを示すブロック図2200である。サービスオペレータ2202(例えば、図19のサービスオペレータ1902)は、仮想クラウドネットワーク(VCN)2206(例えば、図19のVCN1906)およびセキュアホストサブネット-2208(例えば、図19のセキュアホストサブネット1908)を含み得るセキュアホストテナンシ2204(例えば、図19のセキュアホストテナンシ1904)に通信可能に結合されてもよい。VCN2206は、SSH VCN2212に含まれるLPG2210を介してSSH VCN2212(例えば、図19のSSH VCN1912)に通信可能に結合され得るLPG2210(例えば、図19のLPG1910)を含むことができる。SSH VCN2212は、SSHサブネット-2214(例えば、図19のSSHサブネット1914)を含むことができ、SSH VCN2212は、制御プレーンVCN2216に含まれるLPG2210を介して制御プレーンVCN2216(例えば、図19の制御プレーンVCN1916)に通信可能に結合されてもよく、データプレーンVCN2218に含まれるLPG2210を介してデータプレーンVCN2218(例えば、図19のデータプレーン1918)に通信可能に結合されてもよい。制御プレーンVCN2216およびデータプレーンVCN2218は、サービステナンシ2219(例えば、図19のサービステナンシ1919)に含まれてもよい。
【0278】
制御プレーンVCN2216は、LBサブネット2222(例えば、図19のLBサブネット1922)を含み得る制御プレーンDMZ層2220(例えば、図19の制御プレーンDMZ層1920)、アプリサブネット2226(例えば、図19のアプリサブネット1926)を含み得る制御プレーンアプリ層2224(例えば、図19の制御プレーンアプリ層1924)、DBサブネット2230(例えば、図21のDBサブネット2130)を含み得る制御プレーンデータティア2228(例えば、図19の制御プレーンデータティア1928)を含むことができる。制御プレーンDMZ層2220に含まれるLBサブネット2222は、制御プレーンアプリ層2224に含まれるアプリサブネット2226と、制御プレーンVCN2216に含まれ得るインターネットゲートウェイ2234(例えば、図19のインターネットゲートウェイ1934)とに通信可能に結合されてもよい。アプリサブネット2226は、制御プレーンデータ層2228に含まれるDBサブネット2230と、サービスゲートウェイ2236(例えば、図19のサービスゲートウェイ)およびネットワークアドレス変換(NAT)ゲートウェイ2238(例えば、図19のNATゲートウェイ1938)とに通信可能に結合されてもよい。制御プレーンVCN2216は、サービスゲートウェイ2236およびNATゲートウェイ2238を含むことができる。
【0279】
データプレーンVCN2218は、データプレーンアプリ層2246(例えば、図19のデータプレーンアプリ層1946)、データプレーンDMZ層2248(例えば、図19のデータプレーンDMZ層1948)、およびデータプレーンデータ層2250(例えば、図19のデータプレーンデータ層1950)を含むことができる。データプレーンDMZ層2248は、データプレーンアプリ層2246の信頼できるアプリサブネット2260(例えば、図21の信頼できるアプリサブネット2160)および信頼できないアプリサブネット2262(例えば、図21の信頼できないアプリサブネット2162)およびデータプレーンVCN2218に含まれるインターネットゲートウェイ2234に通信可能に結合され得るLBサブネット2222を含むことができる。信頼できるアプリサブネット2260は、データプレーンVCN2218に含まれるサービスゲートウェイ2236、データプレーンVCN2218に含まれるNATゲートウェイ2238、およびデータプレーンデータ層2250に含まれるDBサブネット2230に通信可能に結合されてもよい。信頼できないアプリサブネット2262は、データプレーンVCN2218に含まれるサービスゲートウェイ2236、およびデータプレーンデータ層2250に含まれるDBサブネット2230に通信可能に結合されてもよい。データプレーンデータ層2250は、データプレーンVCN2218に含まれるサービスゲートウェイ2236に通信可能に結合され得るDBサブケット2230を含むことができる。
【0280】
信頼できないアプリサブネット2262は、信頼できないアプリサブネット2262に常駐するテナント仮想マシン(VM)2266(1)~(N)に通信可能に結合され得るプライマリYNIC2264(1)~(N)を含むことができる。各テナントVM2266(1)~(N)は、それぞれのコンテナ2267(1)~(N)においてコードを実行することができ、コンテナ送信VCN2268に含まれ得るデータプレーンアプリ層2246に含まれ得るアプリサブネット2226に通信可能に結合されてもよい。各セカンダリVNIC2272(1)~(N)は、データプレーンVCN2218に含まれる信頼できないアプリサブネット2262とコンテナ送信VCN2268に含まれるアプリサブネットとの間の通信を促進することができる。コンテナ送信VCNは、パブリックインターネット2254(例えば、図19のパブリックインターネット1954)に通信可能に結合することができるNATゲートウェイ2238を含むことができる。
【0281】
制御プレーンVCN2216に含まれるインターネットゲートウェイ2234およびデータプレーンVCN2218に含まれるインターネットゲートウェイ2234は、パブリックインターネット2254に通信可能に結合され得るメタデータ管理サービス2252(例えば、図19のメタデータ管理システム1952)に通信可能に結合されてもよい。パブリックインターネット2254は、制御プレーンVCN2216に含まれるインターネットゲートウェイ2234およびデータプレーンVCN2218に含まれるNATゲートウェイ2238に通信可能に結合されてもよい。制御プレーンVCN2216に含まれるインターネットゲートウェイ2234およびデータプレーンVCN2218に含まれるサービスゲートウェイ2236は、クラウドサービス2256に通信可能に結合されてもよい。
【0282】
いくつかの例において、図22のブロック図2200のアーキテクチャによって示されたパターンは、図21のブロック図2100のアーキテクチャによって示されたパターンの例外と考えられ、IaaSプロバイダが顧客と直接に通信できない(例えば、非接続地域)場合、IaaSプロバイダの顧客にとって望ましいことがある。顧客は、各顧客のVM2266(1)~(N)に含まれるそれぞれのコンテナ2267(1)~(N)にリアルタイムでアクセスすることができる。コンテナ2267(1)~(N)は、コンテナ送信VCN2268に含まれ得るデータプレーンアプリ層2246のアプリサブネット2226に含まれるそれぞれのセカンダリVNIC2272(1)~(N)を呼び出すように構成されてもよい。セカンダリVNIC2272(1)~(N)は、パブリックインターネット2254に呼び出しを送信することができるNATゲートウェイ2238に呼び出しを送信することができる。この例において、顧客がリアルタイムでアクセスできるコンテナ2267(1)~(N)は、制御プレーンVCN2216から隔離されてもよく、データプレーンVCN2218に含まれる他のエンティティから隔離されてもよい。また、コンテナ2267(1)~(N)は、他の顧客のリソースから隔離されてもよい。
【0283】
他の例において、顧客は、コンテナ2267(1)~(N)を使用して、クラウドサービス2256を呼び出すことができる。この例では、顧客は、コンテナ2267(1)~(N)において、クラウドサービス2256からサービスを要求するコードを実行することができる。コンテナ2267(1)~(N)は、要求をパブリックインターネット2254に送信することができるNATゲートウェイに要求を送信することができるセカンダリVNIC2272(1)~(N)にこの要求を送信することができる。パブリックインターネット2254は、インターネットゲートウェイ2234を介して、制御プレーンVCN2216に含まれるLBサブネット2222にこの要求を送信することができる。要求が有効であるとの判断に応答して、LBサブネットは、この要求をアプリサブネット2226に送信することができ、アプリサブネット2226は、サービスゲートウェイ2236を介して、この要求をクラウドサービス2256に要求を送信することができる。
【0284】
なお、図示されたIaaSアーキテクチャ1900、2000、2100および2200は、図示されたもの以外の要素を含んでもよい。また、図示された実施形態は、本開示の実施形態を組み込むことができるクラウドインフラストラクチャシステムの一部の例に過ぎない。他のいくつかの実施形態において、IaaSシステムは、図示されたものよりも多いまたは少ない要素を有してよく、2つ以上の要素を組み合わせてよく、または要素の異なる構成または配置を有してよい。
【0285】
特定の実施形態において、本明細書に記載されたIaaSシステムは、セルフサービス、サブスクリプションベース、柔軟な拡張可能性、信頼性、高可用性、および安全な方法で顧客に提供されるアプリケーション、ミドルウェア、およびデータベースサービスのスイートを含むことができる。このようなIaaSシステムの一例は、本出願人によって提供されたオラクル(登録商標)クラウドインフラストラクチャ(OCI)である。
【0286】
図23は、様々な実施形態が実装され得る例示的なコンピュータシステム2300を示す。システム2300は、上述したコンピュータシステムのいずれかを実装するために使用されてもよい。図示のように、コンピュータシステム2300は、バスサブシステム2302を介して多数の周辺サブシステムと通信する処理ユニット2304を含む。これらの周辺サブシステムは、処理加速ユニット2306、I/Oサブシステム2308、記憶サブシステム2318、および通信サブシステム2324を含んでもよい。記憶サブシステム2318は、有形のコンピュータ可読記憶媒体2322およびシステムメモリ2310を含む。
【0287】
バスサブシステム2302は、コンピュータシステム2300の様々な構成要素およびサブシステムを意図したように相互に通信させるための機構を提供する。バスサブシステム2302は、単一のバスとして概略的に示されているが、バスサブシステムの代替的な実施形態は、複数のバスを利用してもよい。バスサブシステム2302は、メモリバスまたはメモリコントローラ、周辺バス、および様々なバスアーキテクチャのいずれかを使用するローカルバスを含む、いくつかの種類のバス構造のいずれかであってもよい。例えば、このようなアーキテクチャは、業界標準アーキテクチャ(ISA)バス、マイクロチャネルアーキテクチャ(MCA)、バス拡張ISA(EISA)バス、ビデオ電子標準協会(VESA)ローカルバス、およびIEEE P1386.1標準に準拠して製造されたメザニンバスとして実装できる周辺機器相互接続(PCI)バスなどを含むことができる。
【0288】
1つ以上の集積回路(例えば、従来のマイクロプロセッサまたはマイクロコントローラ)として実装され得る処理ユニット2304は、コンピュータシステム2300の動作を制御する。処理ユニット2304は、1つ以上のプロセッサを含んでもよい。これらのプロセッサは、シングルコアまたはマルチコアプロセッサを含んでもよい。いくつかの実施形態において、処理ユニット2304は、各処理ユニットに含まれるシングルコアまたはマルチコアプロセッサを有する1つ以上の独立した処理ユニット2332および/または2334として実装されてもよい。他の実施形態において、処理ユニット2304は、2つのデュアルコアプロセッサを単一のチップに統合することによって形成されたクワッドコア(quad-core)処理ユニットとして実装されてもよい。
【0289】
様々な実施形態において、処理ユニット2304は、プログラムコードに応答して様々なプログラムを実行することができ、同時に実行する複数のプログラムまたはプロセスを維持することができる。任意の時点で、実行されるプログラムコードの一部または全部は、プロセッサ2304および/または記憶サブシステム2318に常駐することができる。プロセッサ2304は、適切なプログラミングを通して、上述した様々な機能性を提供することができる。コンピュータシステム2300は、デジタル信号プロセッサ(DSP)、専用プロセッサおよび/または同種のものを含むことができる処理加速ユニット2306をさらに含んでもよい。
【0290】
I/Oサブシステム2308は、ユーザインターフェイス入力装置と、ユーザインターフェイス出力装置とを含むことができる。ユーザインターフェイス入力装置は、キーボード、マウスまたはトラックボールなどのポインティング装置、ディスプレイに組み込まれたタッチパッドまたはタッチスクリーン、スクロールホイール、クリックホイール、ダイヤル、ボタン、スイッチ、キーパッド、音声命令認識システムを備える音声入力装置、マイクロフォン、および他の種類の入力装置を含んでもよい。また、ユーザインターフェイス入力装置は、例えば、Microsoft Kinect(登録商標)モーションセンサのようなモーション検知および/またはジェスチャ認識装置を含んでもよい。Microsoft Kinect(登録商標)モーションセンサは、ジェスチャおよび音声命令を利用する自然ユーザインターフェース(NUI)を介して、Microsoft Xbox(登録商標)360ゲームコントローラなどの入力装置を制御することができ、それと対話することができる。また、ユーザインターフェイス入力装置は、Google Glass(登録商標)瞬き検出器のような眼球ジェスチャ認識装置を含むことができる。Google Glass(登録商標)瞬き検出器は、ユーザの眼球活動(例えば、写真を撮るときおよび/またはメニューを選択するときの「瞬き」)を検出し、眼球活動を入力装置(例えば、Google Glass(登録商標))に入力する入力に変換する。さらに、ユーザインターフェイス入力装置は、音声命令を介してユーザと音声認識システム(例えば、Siri(登録商標)ナビゲータ)との対話を可能にする音声認識検出装置を含んでもよい。
【0291】
また、ユーザインターフェイス入力装置は、三次元(3D)マウス、ジョイスティックまたはポインティングスティック、ゲームパッド、グラフィックタブレット、スピーカなどのオーディオ/ビジュアル装置、デジタルカメラ、デジタルビデオカメラ、ポータブルメディアプレーヤ、ウェブカメラ、イメージスキャナ、指紋スキャナ、バーコードリーダ、3Dスキャナ、3Dプリンタ、レーザ距離計、および視線追跡装置を含むがこれらに限定されない。さらに、ユーザインターフェイス入力装置は、例えば、コンピュータ断層撮影装置、磁気共鳴像装置、超音波放射断層撮影装置、または医療用超音波装置などのような医用画像入力装置を含んでもよい。また、ユーザインターフェイス入力装置は、例えば、MIDIキーボードおよび電子楽器などの音声入力装置を含んでもよい。
【0292】
ユーザインターフェイス出力装置は、ディスプレイサブシステム、インジケータライト、またはオーディオ出力装置などの非視覚ディスプレイを含んでもよい。ディスプレイサブシステムは、例えば、陰極線管(CRT)、液晶ディスプレイ(LCD)またはプラズマディスプレイを使用するフラットパネル装置、投射装置またはタッチスクリーンであってもよい。一般に、「出力装置」という用語を使用する場合、コンピュータシステム2300から情報をユーザまたは他のコンピュータに出力するためのすべての可能な種類の装置および機構を含むことを意図している。例えば、ユーザインターフェイス出力装置は、文字、画像およびオーディオ/ビデオ情報を視覚的に伝達するさまざまな表示装置、例えば、モニタ、プリンタ、スピーカ、ヘッドフォン、カーナビゲーションシステム、プロッタ、音声出力装置、およびモデムを含むがこれらに限定されない。
【0293】
コンピュータシステム2300は、記憶サブシステム2318を含むことができる。記憶サブシステム2318は、ソフトウェア要素を備え、図示では、これらのソフトウェア要素は、システムメモリ2310内に配置されている。システムメモリ2310は、処理ユニット2304にロード可能かつ実行可能なプログラム命令、およびこれらのプログラムの実行により生成されたデータを記憶することができる。
【0294】
コンピュータシステム2300の構成およびタイプに応じて、システムメモリ2310は、揮発性メモリ(例えば、ランダムアクセスメモリ(random access memory:RAM))であってもよく、および/または、不揮発性メモリ(例えば、読取り専用メモリ(read-only memory:ROM)、フラッシュメモリ)であってもよい。一般に、RAMは、処理ユニット2304がすぐにアクセス可能なデータおよび/またはプログラムモジュール、および/または、処理ユニット2304によって現在操作および実行されているデータおよび/またはプログラムモジュールを収容する。いくつかの実現例では、システムメモリ2310は、スタティックランダムアクセスメモリ(static random access memory:SRAM)またはダイナミックランダムアクセスメモリ(dynamic random access memory:DRAM)などの複数の異なるタイプのメモリを含み得る。いくつかの実現例では、始動中などにコンピュータシステム2300内の要素間で情報を転送することを助ける基本ルーチンを含む基本入力/出力システム(basic input/output system:BIOS)が、一般にROMに格納され得る。一例としておよび非限定的に、システムメモリ2310は、クライアントアプリケーション、ウェブブラウザ、中間層アプリケーション、リレーショナルデータベース管理システム(relational database management system:RDBMS)などを含み得るアプリケーションプログラム2312、プログラムデータ2314およびオペレーティングシステム2316も示す。一例として、オペレーティングシステム2316は、マイクロソフトウィンドウズ(登録商標)、Apple Macintosh(登録商標)および/もしくはLinux(登録商標)オペレーティングシステムのさまざまなバージョン、さまざまな市販のUNIX(登録商標)もしくはUNIXライクオペレーティングシステム(さまざまなGNU/Linuxオペレーティングシステム、Google Chrome(登録商標)OSなどを含むが、これらに限定されるものではない)、および/または、iOS、Windows(登録商標)フォン、アンドロイド(登録商標)OS、ブラックベリー(登録商標)23 OSおよびパーム(登録商標)OSオペレーティングシステムなどのモバイルオペレーティングシステムを含み得る。
【0295】
また、記憶サブシステム2318は、いくつかの実施例の機能を提供する基本的なプログラミングおよびデータ構造を格納するための有形のコンピュータ可読記憶媒体を提供することができる。プロセッサによって実行されたときに上記の機能を提供するソフトウェア(プログラム、コードモジュール、命令)は、記憶サブシステム2318に記憶されてもよい。これらのソフトウェアモジュールまたは命令は、処理ユニット2304によって実行されてもよい。また、記憶サブシステム2318は、本開示に従って使用されるデータを記憶するためのリポジトリを提供することができる。
【0296】
また、記憶サブシステム2300は、コンピュータ可読記憶媒体2322にさらに接続可能なコンピュータ可読記憶媒体リーダ2320を含むことができる。コンピュータ可読記憶媒体2322は、システムメモリ2310とともに、または必要に応じてシステムメモリ2310と組み合わせて、コンピュータ可読情報を一時的におよび/または永久に収容、格納、送信および検索するための記憶媒体に加えて、リモート記憶装置、ローカル記憶装置、固定的な記憶装置および/または取外し可能な記憶装置を包括的に表すことができる。
【0297】
また、コードまたはコードの一部を含むコンピュータ可読記憶媒体2322は、当該技術分野において公知のまたは使用される任意の適切な媒体を含んでもよい。当該媒体は、情報の格納および/または送信のための任意の方法または技術において実現される揮発性および不揮発性の、取外し可能および取外し不可能な媒体などであるが、これらに限定されるものではない記憶媒体および通信媒体を含む。これは、RAM、ROM、電子的消去・プログラム可能ROM(electronically erasable programmable ROM:EEPROM)、フラッシュメモリもしくは他のメモリ技術、CD-ROM、デジタル多用途ディスク(digital versatile disk:DVD)、または他の光学式記憶装置、磁気カセット、磁気テープ、磁気ディスク記憶装置もしくは他の磁気記憶装置、または他の有形のコンピュータ可読媒体などの有形のコンピュータ可読記憶媒体を含むことができる。また、これは、データ信号、データ送信などの無形のコンピュータ可読媒体、または、所望の情報を送信するために使用可能であり且つコンピュータシステム2300によってアクセス可能なその他の媒体を含むことができる。
【0298】
一例として、コンピュータ可読記憶媒体2322は、取外し不可能な不揮発性磁気媒体から読取るまたは当該媒体に書込むハードディスクドライブ、取外し可能な不揮発性磁気ディスクから読取るまたは当該ディスクに書込む磁気ディスクドライブ、ならびに、CD ROM、DVDおよびブルーレイ(登録商標)ディスクまたは他の光学式媒体などの取外し可能な不揮発性光学ディスクから読取るまたは当該ディスクに書込む光学式ディスクドライブを含んでもよい。コンピュータ可読記憶媒体2322は、ジップ(登録商標)ドライブ、フラッシュメモリカード、ユニバーサルシリアルバス(universal serial bus:USB)フラッシュドライブ、セキュアデジタル(secure digital:SD)カード、DVDディスク、デジタルビデオテープなどを含み得るが、これらに限定されるものではない。また、コンピュータ可読記憶媒体2322は、フラッシュメモリベースのSSD、企業向けフラッシュドライブ、ソリッドステートROMなどの不揮発性メモリに基づくソリッドステートドライブ(solid-state drive:SSD)、ソリッドステートRAM、ダイナミックRAM、スタティックRAMなどの揮発性メモリに基づくSSD、DRAMベースのSSD、磁気抵抗RAM(magnetoresistive RAM:MRAM)SSD、およびDRAMとフラッシュメモリベースのSSDとの組み合わせを使用するハイブリッドSSDを含んでもよい。ディスクドライブおよびそれらの関連のコンピュータ可読媒体は、コンピュータ可読命令、データ構造、プログラムモジュールおよび他のデータの不揮発性記憶装置をコンピュータシステム2300に提供することができる。
【0299】
通信サブシステム2324は、他のコンピュータシステムおよびネットワークとのインターフェースを提供する。通信サブシステム2324は、他のシステムからデータを受信したり、コンピュータシステム2300から他のシステムにデータを送信するためのインターフェイスの役割を果たす。例えば、通信サブシステム2324は、コンピュータシステム2300がインターネットを介して1つ以上の装置に接続することを可能にし得る。いくつかの実施例では、通信サブシステム2324は、(例えば3G、4GまたはEDGE(enhanced data rates for global evolution)などの携帯電話技術、高度データネットワーク技術を用いて)無線音声および/またはデータネットワークにアクセスするための無線周波数(radio frequency:RF)トランシーバ構成要素、WiFi(IEEE802.11ファミリ標準または他のモバイル通信技術またはそれらの任意の組み合わせ)、全地球測位システム(global positioning system:GPS)レシーバ構成要素、および/または、他の構成要素を含んでもよい。いくつかの実施例では、通信サブシステム2324は、無線インターフェースに加えて、または無線インターフェースの代わりに、有線ネットワーク接続(例えばイーサネット)を提供することができる。
【0300】
また、いくつかの実施例において、通信サブシステム2324は、コンピュータシステム2300を使用し得る1人以上のユーザを代表して、構造化されたおよび/または構造化されていないデータフィード2326、イベントストリーム2328、イベント更新2330などの形態で入力通信を受信することができる。
【0301】
一例として、通信サブシステム2324は、ツイッター(登録商標)フィード、フェースブック(登録商標)更新、リッチ・サイト・サマリ(Rich Site Summary:RSS)フィードなどのウェブフィードなどのデータフィード2326をリアルタイムでソーシャルネットワークおよび/または他の通信サービスのユーザから受信し、および/または、1つ以上の第三者情報源からリアルタイム更新を受信するように構成されてもよい。
【0302】
また、通信サブシステム2324は、連続的なデータストリームの形態でデータを受信するように構成され得て、当該データは、連続的である場合もあれば本質的に明確な端部を持たない状態で境界がない場合もあるリアルタイムイベントのイベントストリーム2328および/またはイベント更新2330を含んでもよい。連続的なデータを生成するアプリケーションの例としては、例えばセンサデータアプリケーション、金融ティッカ、ネットワーク性能測定ツール(例えばネットワークモニタリングおよびトラフィック管理アプリケーション)、クリックストリーム分析ツール、自動車交通モニタリングなどを含んでもよい。
【0303】
また、通信サブシステム2324は、構造化されたおよび/または構造化されていないデータフィード2326、イベントストリーム2328、イベント更新2330などを、コンピュータシステム2300に結合された1つ以上のストリーミングデータソースコンピュータと通信し得る1つ以上のデータベースに出力するように構成されてもよい。
【0304】
コンピュータシステム2300は、手持ち式携帯機器(例えば、iPhone(登録商標)携帯電話、Ipad(登録商標)計算タブレット、PDA)、ウェアラブル装置(例えば、Google Glass(登録商標)ヘッドマウントディスプレイ)、PC、ワークステーション、メインフレーム、キオスク、サーバラックまたはその他のデータ処理システムを含む様々な種類のうちの1つであってもよい。
【0305】
前述の説明において、説明の目的で、本開示の実施例を完全に理解できるようにするために、具体的な詳細を記載する。しかしながら、これらの具体的な詳細がなくても、様々な実施例を実施できることは明らかであろう。以下の説明は、例のみを提供し、本開示の範囲、適用性、または構成を制限することを意図していない。むしろ、実施例の以下の説明は、実施例を実施するための可能な説明を当業者に提供するものである。添付の特許請求の範囲に規定される本開示の精神及び範囲から逸脱することなく、要素の機能および配置に様々な変更を加えることができることを理解されたい。図面および説明は、制限的であることを意図していない。回路、システム、ネットワーク、プロセス、および他の構成要素は、不必要な詳細で実施例を不明瞭にしないために、ブロック図の形態で構成要素として示されてもよい。他の実施例では、周知の回路、プロセス、アルゴリズム、構造、および技術は、実施例を不明瞭にしないために、不必要な詳細なしに示されてもよい。本開示の教示は、モバイルアプリケーション、非モバイルアプリケーション、デスクトップアプリケーション、ウェブアプリケーション、エンタープライズアプリケーションなどの様々な種類のアプリケーションに適用することもできる。また、本開示の教示は、特定の動作環境(例えば、オペレーティングシステム、デバイス、プラットフォームなど)に限定されるものではなく、複数の異なる動作環境に適用することができる。
【0306】
また、留意すべきことは、各々の実施例は、フローチャート、フロー図、データフロー図、構造図、またはブロック図として示された処理として説明されていることである。フローチャートは、操作を順次処理として説明しているが、多くの操作は、並行でまたは同時に実行することができる。さらに、操作の順序を再配置してもよい。処理は、その操作が完了した時点で終了するが、図に示されていない追加のステップを含んでもよい。処理は、メソッド、関数、プロシージャ、サブルーチン、サブプログラムなどに対応することができる。処理が関数に対応する場合、その終了は、呼び出し関数またはメイン関数の戻りに対応することができる。
【0307】
「例」および「例示的」という用語は、本明細書において、「例、事例、または例示として役立つ」という意味で使用される。本明細書において「例示的」または「例」として説明された任意の実施形態または設計は、必ずしも他の実施形態または設計よりも好ましいまたは有利であると解釈されるべきではない。
【0308】
「機械可読記憶媒体」または「コンピュータ可読記憶媒体」という用語は、携帯型または非携帯型の記憶装置、光記憶装置、ならびに命令および/またはデータを記憶、格納、または搬送することができる様々な他の媒体を含むが、これらに限定されない。機械可読記憶媒体またはコンピュータ可読記憶媒体は、データを記憶することができ、無線または有線接続を介して伝搬する搬送波および/または一時的な電子信号を含まない非一時的な媒体を含んでもよい。非一時的な媒体の例は、磁気ディスクまたはテープ、コンパクトディスク(CD)またはデジタル多用途ディスク(DVD)などの光記憶媒体、フラッシュメモリ、メモリまたはメモリ装置を含み得るが、これらに限定されない。コンピュータプログラム製品は、プロシージャ、関数、サブプログラム、プログラム、ルーチン、サブルーチン、モジュール、ソフトウエアパッケージ、クラス、命令、データ構造、またはプログラム文の任意の組み合わせを表し得るコードおよび/または機械実行可能命令を含んでもよい。コードセグメントは、情報、データ、引数、パラメータ、またはメモリ内容を転送および/または受取ることによって、別のコードセグメントまたはハードウェア回路に結合されてもよい。情報、引数、パラメータおよびデータなどは、メモリ共有、メッセージ転送、トークン転送、ネットワーク送信などの任意の適切な手段を介して、伝達され、転送され、または送信されてもよい。
【0309】
さらに、実施形態は、ハードウェア、ソフトウェア、ファームウェア、ミドルウェア、マイクロコード、ハードウェア記述言語、またはそれらの任意の組み合わせによって実施されてもよい。ソフトウェア、ファームウェア、ミドルウェアまたはマイクロコードに実施される場合、必要な作業を実行するプログラムコードまたはコードセグメントは、機械可読媒体に記憶されてもよい。プロセッサは、必要な作業を実行することができる。一部の図面に示されたシステムは、様々な構成で提供されてもよい。いくつかの例において、システムは、システムの1つ以上の要素がクラウドコンピューティングシステム内の1つ以上のネットワークにわたって分散される分散システムとして構成されてもよい。要素が特定の動作を実行するように「構成されている」として説明される場合、このような構成は、例えば、動作を実行するように電子回路または他のハードウェアを設計することによって、動作を実行するように電子回路(例えば、マイクロプロセッサまたは他の適切な電子回路)をプログラミングまたは制御することによって、またはそれらの任意の組み合わせによって達成されてもよい。
【0310】
本開示の特定の実施形態を説明してきたが、さまざまな変更、改変、代替構成、および同等物も本開示の範囲内に包含される。本開示の実施形態は、特定のデータ処理環境内で動作するのに限定されず、複数のデータ処理環境内で自由に動作することができる。さらに、一連の特定の処置およびステップを用いて本開示の実施形態を説明してきたが、本開示の範囲が説明された一連の処置およびステップに限定されないことは、当業者にとって明らかであろう。上述した実施形態のさまざまな特徴および態様は、個別にまたは共同で使用することができる。
【0311】
さらに、ハードウェアおよびソフトウェアの特定の組み合わせを用いて本開示の実施形態を説明してきたが、ハードウェアおよびソフトウェアの他の組み合わせも本開示の範囲内に含まれることを認識すべきである。ハードウェアのみ、ソフトウェアのみ、またはそれらの組み合わせを用いて、本開示の実施形態を実現することができる。本開示に記載されたさまざまなプロセスは、同一のプロセッサまたは任意の組み合わせの異なるプロセッサ上で実行することができる。したがって、特定の処理を実行するように構成要素またはモジュールを構成すると説明する場合、その構成は、例えば、その処理を実行するように電子回路を設計することによって、その処理を実行するようにプログラム可能な電子回路(マイクロプロセッサなど)をプログラムすることによって、またはそれらの組み合わせによって実現することができる。プロセスは、プロセス間の通信を行う従来技術を含むがこれに限定されないさまざまな技術を用いて通信を行うことができる。異なる対のプロセスは、異なる技術を使用することができ、または同一対のプロセスは、異なる時間で異なる技術を使用することができる。
【0312】
したがって、明細書および図面は、限定的な意味ではなく例示的な意味であるとみなすべきである。しかしながら、特許請求の範囲により定められた幅広い主旨および範囲から逸脱することなく、追加、削減、削除および他の修飾および変更を行ってもよいことは、明らかであろう。したがって、本開示の特定の実施形態を説明したが、これらの実施形態は、限定することを意図していない。さまざまな変更およびその等価物は、添付の特許請求の範囲に含まれる。
【0313】
本開示の実施形態の例は、以下の項に照らして説明することができる。
項1.コンピュータシステムによって実現される方法であって、第1のネットワーク仮想化デバイス(NVD)から、第1の計算インスタンスのインターネットグループ管理プロトコル(IGMP)応答に関する第1の情報を受信することを含み、上記第1の情報は、上記第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示し、上記第1の計算インスタンスは、ホストマシン上でホストされ、レイヤ2仮想ネットワークに属し、上記レイヤ2仮想ネットワークは、物理ネットワーク上でホストされ、複数の計算インスタンスと、複数のレイヤ2仮想ネットワークインターフェースと、複数のレイヤ2仮想スイッチとを含み、上記物理ネットワークは、第1のNVDと上記ホストマシンとを含み、上記第1のNVDは、上記複数のレイヤ2仮想ネットワークインターフェースのうちの第1のレイヤ2仮想ネットワークインターフェースと、上記複数のレイヤ2仮想スイッチのうちの第1のレイヤ2仮想スイッチとをホストし、上記第1のレイヤ2仮想ネットワークインターフェースおよび上記第1のレイヤ2仮想スイッチは、上記第1の計算インスタンスに関連付けられ、上記方法はさらに、上記第1の情報に基づいて、上記第1の計算インスタンスが上記マルチキャストグループに追加されることを示すIGMPテーブルを生成することと、上記IGMPテーブルの少なくとも第1の部分を第2のNVDに送信することとを含み、上記第2のNVDは、上記複数のレイヤ2仮想ネットワークインターフェースのうちの第2のレイヤ2仮想ネットワークインターフェースと、上記複数のレイヤ2仮想スイッチのうちの第2のレイヤ2仮想スイッチとをホストし、上記第2のレイヤ2仮想ネットワークインターフェースおよび上記第2のレイヤ2仮想スイッチは、上記複数の計算インスタンスのうちの第2の計算インスタンスに関連付けられる、コンピュータシステムによって実現される方法。
【0314】
項2.上記方法はさらに、上記第2のNVDから、上記第2の計算インスタンスのIGMP応答に関する第2の情報を受信することを含み、上記第2の情報は、上記第2の計算インスタンスが上記マルチキャストグループに追加されるべきであることを示し、上記IGMPテーブルは、さらに上記第2の情報に基づいて生成され、上記第2の計算インスタンスが上記マルチキャストグループに追加されることを示す、項1に記載の方法。
【0315】
項3.上記方法はさらに、上記第1のNVDに、上記IGMPテーブルの少なくとも第2の部分を送信することを含む、項2に記載の方法。
【0316】
項4.上記第2のNVDに送信される上記第1の部分は、上記第2の計算インスタンスが上記マルチキャストグループに追加されるという第1の指示を含まず、上記第1の計算インスタンスが上記マルチキャストグループに追加されるという第2の指示を含み、上記第1のNVDに送信される上記第2の部分は、上記第2の指示を含み、上記第1の指示を含まない、項3に記載の方法。
【0317】
項5.上記IGMPテーブルは、上記第1のNVDおよび上記第2のNVDに送信される、項3に記載の方法。
【0318】
項6.上記方法はさらに、上記第1のNVDにIGMPクエリについて要求を送信することを含み、上記第1のIGMP応答は、上記第1のNVDによって上記IGMPクエリに基づいて受信される、項1~5のいずれか1項に記載の方法。
【0319】
項7.上記方法はさらに、上記レイヤ2仮想ネットワークの構成情報に基づいて、上記第1のレイヤ2仮想スイッチは上記第1の計算インスタンスに関連付けられ上記第1のNVDによってホストされると判断することを含み、上記第1のレイヤ2仮想スイッチは上記第1の計算インスタンスに関連付けられ上記第1のNVDによってホストされると判断することに基づいて、上記要求は上記第1のNVDに送信される、項6に記載の方法。
【0320】
項8.上記方法はさらに、上記第1のNVDから、上記第1の計算インスタンスが上記マルチキャストグループから除去されるべきであることを示す第2の情報を受信することと、上記第2の情報に基づいて、上記IGMPテーブルに対する更新を生成することとを含み、上記更新は、上記第1の計算インスタンスが上記マルチキャストグループから除去されることを示し、上記方法はさらに、上記第2のNVDに、少なくとも上記更新を送信することを含む、項1~7のいずれか1項に記載の方法。
【0321】
項9.上記更新は、上記第1のNVDではなく別のNVDにさらに送信される、項8に記載の方法。
【0322】
項10.ネットワーク仮想化デバイスであって、1つ以上のプロセッサと、命令を記憶する1つ以上のコンピュータ可読記憶媒体とを備え、上記命令は、上記1つ以上のプロセッサによって実行されると、上記ネットワーク仮想化デバイスを、レイヤ2仮想ネットワークに属する第1のレイヤ2仮想ネットワークインターフェースおよび第1のレイヤ2仮想スイッチをホストするよう構成し、上記第1のレイヤ2仮想ネットワークインターフェースおよび上記第1のレイヤ2仮想スイッチは、上記レイヤ2仮想ネットワークに属する第1の計算インスタンスに関連付けられ、上記第1の計算インスタンスは、上記ネットワーク仮想化デバイスを備える物理ネットワークのホストマシン上でホストされ、上記ホストマシンおよび上記ネットワーク仮想化デバイスは、通信可能に結合され、上記レイヤ2仮想ネットワークは、上記物理ネットワーク上でホストされ、複数の計算インスタンスと、複数のレイヤ2仮想ネットワークインターフェースと、複数のレイヤ2仮想スイッチとを備え、上記命令は、さらに、上記1つ以上のプロセッサによって実行されると、上記ネットワーク仮想化デバイスを、上記第1の計算インスタンスに、インターネットグループ管理プロトコル(IGMP)クエリを送信するよう構成し、上記第1の計算インスタンスのIGMP応答を受信するよう構成し、上記IGMP応答は、上記第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示す、ネットワーク仮想化デバイス。
【0323】
項11.上記命令の上記実行はさらに、上記ネットワーク仮想化デバイスを、コンピュータシステムに、上記IGMP応答に関する第1の情報を送信するよう構成し、上記第1の情報は、上記第1の計算インスタンスが上記マルチキャストグループに追加されるべきであることを示し、上記命令の上記実行はさらに、上記ネットワーク仮想化デバイスを、上記コンピュータシステムから、IGMPテーブルの少なくとも一部を受信するよう構成し、上記IGMPテーブルは、上記第1の情報に基づいて生成される、項10に記載のネットワーク仮想化デバイス。
【0324】
項12.上記一部は、上記複数の計算インスタンスのうちの第2の計算インスタンスが上記マルチキャストグループに追加されるという第1の指示を含み、上記第2の計算インスタンスは、第2のネットワーク仮想化デバイスによってホストされる第2のレイヤ2仮想ネットワークインターフェースおよび第2のレイヤ2仮想スイッチに関連付けられる、項11に記載のネットワーク仮想化デバイス。
【0325】
項13.上記命令の上記実行はさらに、上記ネットワーク仮想化デバイスを、上記第1の計算インスタンスの上記IGMP応答と上記コンピュータシステムから受信された上記IGMPテーブルの上記一部とに基づいてローカルIGMPテーブルを記憶するよう構成し、上記一部は、上記第1の計算インスタンスが上記マルチキャストグループに追加されるという第2の指示を含まず、上記ローカルIGMPテーブルは上記第2の指示を含む、項12に記載のネットワーク仮想化デバイス。
【0326】
項14.上記命令の上記実行はさらに、上記ネットワーク仮想化デバイスを、上記コンピュータシステムから、上記IGMPクエリについて要求を受信するよう構成し、上記IGMPクエリは、上記要求に基づいて送信される、項11に記載のネットワーク仮想化デバイス。
【0327】
項15.上記命令の上記実行はさらに、上記ネットワーク仮想化デバイスを、上記コンピュータシステムから受信した上記IGMPテーブルの上記一部に基づいてローカルIGMPテーブルを記憶するよう構成し、上記ローカルIGMPテーブルは、上記複数の計算インスタンスのうちの第2の計算インスタンスが上記マルチキャストグループに追加されることを示し、上記命令の上記実行はさらに、上記ネットワーク仮想化デバイスを、上記第1の計算インスタンスのフレームを受信するよう構成し、上記ローカルIGMPテーブルに基づいて、上記フレームが複製され、上記第2の計算インスタンスに送信されるべきであると判断するよう構成し、上記第2の計算インスタンス宛ての複製されたフレームを送信するよう構成する、項11に記載のネットワーク仮想化デバイス。
【0328】
項16.命令を記憶する1つ以上のコンピュータ可読記憶媒体であって、上記命令は、ネットワーク仮想化デバイス上で実行されると、上記ネットワーク仮想化デバイスに、動作を実行させ、上記動作は、レイヤ2仮想ネットワークに属する第1のレイヤ2仮想ネットワークインターフェースおよび第1のレイヤ2仮想スイッチをホストすることを含み、上記第1のレイヤ2仮想ネットワークインターフェースおよび上記第1のレイヤ2仮想スイッチは、上記レイヤ2仮想ネットワークに属する第1の計算インスタンスに関連付けられ、上記第1の計算インスタンスは、上記ネットワーク仮想化デバイスを備える物理ネットワークのホストマシン上でホストされ、上記ホストマシンおよび上記ネットワーク仮想化デバイスは、通信可能に結合され、上記レイヤ2仮想ネットワークは、上記物理ネットワーク上でホストされ、複数の計算インスタンスと、複数のレイヤ2仮想ネットワークインターフェースと、複数のレイヤ2仮想スイッチとを備え、上記動作はさらに、上記第1の計算インスタンスに、第1のインターネットグループ管理プロトコル(IGMP)クエリを送信することと、上記第1の計算インスタンスの第1のIGMP応答を受信することとを含み、上記第1のIGMP応答は、上記第1の計算インスタンスがマルチキャストグループに追加されるべきであることを示す、1つ以上のコンピュータ可読記憶媒体。
【0329】
項17.上記動作はさらに、コンピュータシステムに、上記第1のIGMP応答に関する第1の情報を送信することを含み、上記第1の情報は、上記第1の計算インスタンスが上記マルチキャストグループに追加されるべきであることを示し、上記動作はさらに、上記コンピュータシステムから、IGMPテーブルの少なくとも一部を受信することを含み、上記IGMPテーブルは、上記第1の情報に基づいて生成される、項16に記載の1つ以上のコンピュータ可読記憶媒体。
【0330】
項18.上記動作はさらに、上記第1の計算インスタンスに、第2のIGMPクエリを送信することと、上記第1の計算インスタンスの第2のIGMP応答を受信することとを含み、上記第2のIGMP応答は、上記第1の計算インスタンスが上記マルチキャストグループから除去されるべきであることを示す、項17に記載の1つ以上のコンピュータ可読記憶媒体。
【0331】
項19.上記動作はさらに、上記コンピュータシステムから受信した上記IGMPテーブルの上記一部に基づいてローカルIGMPテーブルを記憶することと、上記第1の計算インスタンスが上記マルチキャストグループから除去されることを示すよう、上記ローカルIGMPテーブルを更新することとを含む、項18に記載の1つ以上のコンピュータ可読記憶媒体。
【0332】
項20.上記動作はさらに、上記コンピュータシステムから受信した上記IGMPテーブルの上記一部に基づいてローカルIGMPテーブルを記憶することと、上記第1の計算インスタンスが上記マルチキャストグループから除去されるべきであることを示す更新を上記コンピュータシステムに送信することとを含む、項18に記載の1つ以上のコンピュータ可読記憶媒体。
【0333】
本開示を説明する文脈に(特に特許請求の範囲の文脈に)使用された不定冠詞「a」/「an」、定冠詞「the」および同様の参照は、本明細書に特に明記しない限りまたは内容上明らかに他の意味を示す場合を除き、単数および複数の両方を含むように解釈すべきである。用語「含む(comprising)」、「有する(having)」、「含む(including)」、および「含有する(containing)」は、特に明記しない限り、非限定的な用語(すなわち、「含むがこれに限定されない」という意味)として解釈されるべきである。「接続されている」という用語は、たとえ何かが介在していても、その一部または全部が内部に含まれている、取り付けられている、または一緒に結合されていると解釈されるべきである。本明細書において、値の範囲の列挙は、単にその範囲内に含まれる各個別の値を各々言及する速記方法として意図され、本明細書に特に明記しない限り、各個別の値は、本明細書に個別に記載されるように、本明細書に組み込まれる。本明細書に特に明記しない限りまたは内容上明らかに他の意味を示す場合を除き、本明細書に記載の全ての方法は、任意の適切な順序で行うことができる。本明細書において、任意の例および全ての例または例示的な言語(例えば、「~のような」)の使用は、本開示の実施形態をより明瞭にするよう意図されており、特に明記しない限り、本開示の範囲を限定するものではない。明細書内の用語は、本開示の実施に不可欠な任意の非請求要素を示すものと解釈すべきではない。
【0334】
句「X、Y、またはZの少なくとも1つ」というフレーズのような選言的言語は、特に断らない限り、項目、用語などがX、YもしくはZ、またはそれらの任意の組み合わせ(例えば、X、Y、および/またはZ)のいずれかであってもよいことを示すために一般的に用いられるものとして文脈内で理解されることを意図している。したがって、このような選言的言語は、特定の実施形態が、Xの少なくとも1つ、Yの少なくとも1つ、またはZの少なくとも1つが存在することを必要とすることを一般に意図しておらず、また、それを暗示していない。
【0335】
本開示を実施するために知られている最良の形態を含み、本開示の好ましい実施形態が本明細書に記載されている。これらの好ましい実施形態の変形形態は、前述の説明を読めば当業者には明らかになるであろう。当業者は、適宜、このような変形例を採用することができ、本開示は、本明細書に具体的に記載されている以外の方法で実施されてもよい。したがって、本開示は、適用される法律によって許可され、本明細書に添付された請求項に記載された主題の全ての変形および等価物を含む。さらに、その全ての可能な変形における上記の要素の任意の組み合わせは、本明細書において別段の指示がない限り、本開示に包含される。
【0336】
本明細書に引用された刊行物、特許出願、および特許を含む全ての参考文献は、各文献が参照により組み込まれることが個別にかつ明確に示され、その全体が本明細書に記載された場合と同じ程度に、参照により組み込まれるものとする。
【0337】
前述の明細書において、本開示の態様は、その特定の実施形態を参照して説明されているが、当業者は、本開示がそれに限定されないことを認識するであろう。上述の開示の様々な特徴および態様は、個々にまたは共同で使用されてもよい。さらに、実施形態は、本明細書のより広い精神および範囲から逸脱することなく、本明細書に説明されるものを超える任意の数の環境および用途において利用されることができる。したがって、明細書および図面は、限定的ではなく例示的であると見なされるべきである。
図1
図2
図3
図4
図5
図6
図7
図8
図9
図10
図11
図12
図13
図14
図15
図16
図17
図18
図19
図20
図21
図22
図23
【国際調査報告】