OCI技術資料 : ロード・バランサ 概要
https://speakerdeck.com/ocise/ociji-shu-zi-liao-rodobaransa-gai-yao
P.9 のバックアップ制御が気になったので動作テストをしてみました。
ロード・バランサのバックエンドサーバー毎に次の制御ができるようですが、今回はバックアップを試します。
- バックアップ
- ドレイン
- オフライン
用途例としてはSorryサーバと記載されていますが、通常時/異常時のコンピュートインスタンスの自動切替などにも応用ができそうです。
テスト環境
-
OCI 大阪リージョンに複数のコンピュートインスタンス(osaka01, osaka02, osaka03)を作成。
-
各インスタンスには簡単なWebアプリがデプロイされており、ロード・バランサからのリクエストを受けるとインスタンス名(osaka01, osaka02, osaka03)をブラウザに表示。
-
ロード・バランサの[負荷分散ポリシー]は 重みづけラウンドロビン(重み default値 1 ) とする。
通常時/異常時の自動切換え
1. 初期動作
ロード・バランサとバックエンド(osaka01, osaka02)の状況を確認します。
ナビゲーションメニューから、[ネットワーキング] - [ロード・バランサ]を選択し、テスト前の状態を確認します。
[バックエンド・セットのヘルス] ヘルスチェックはOK
続いて、[ロード・バランサ] 画面左下の [バクエンド・セット] をクリックし、実際のバックエンドの構成を表示します。
バックエンド・セットに含まれる2台のインスタンスが表示されています。
osaka01 : 192.168.0.8
osaka02 : 192.168.0.9
共にヘルスチェックは OK 正常動作しています。また各インスタンスで設定可能な ドレイン、オフライン、バックアップはすべて False の初期状態となっています。
この状態で、ブラウザからロード・バランサに何度かリクエストをすると、ラウンドロビンのポリシーにそってバックエンドのインスタンス(osaka01, osaka02)に交互にリクエストが振り分けられていることが確認できます。
2. バックアップ制御 有効化
バックエンドのインスタンス osaka02 のバックアップ設定を True とし有効化します。
インスタンス osaka02 を選択し、[アクション] から ”バックアップ状態の編集" を選択し、下記画面で True 有効化に変更します。
osaka02 バックアップがTrueに変更されました。
変更後、ブラウザからロード・バランサに何度かリクエストすると、osaka01 のみが表示されます。ロード・バランサのバックアップ有効化制御により、osaka02 へはトラフィックが転送されなくなりました。
osaka01 が通常時のバックエンドとして稼働し、osaka02 はバックアップとして機能していることが確認できました。
3. 通常時から異常時への切り替え
通常時のバックエンドのインスタンス osaka01 を停止します。ナビゲーションメニューから[コンピュート] - [インスタンス] を選択後、osaka01 インスタンスを選択し右ボタンから"停止"をクリックします。停止直後 ヘルスチェックは**"不明"と表示されますが、
しばらくするとヘルスチェックでインスタンスの停止が検知され、通常時のバックエンド osaka01 のヘルスは”クリティカル”**へ変更されました。
この状態で、ブラウザからロード・バランサにリクエストすると、ロード・バランサがバックアップ有効化されている osaka02 へリクエストを転送していることが確認できます。
その後のリクエストはすべて osaka02 で処理され、異常時のバックアップとして機能していることが確認できました。
osaka01 サーバを再起動して、ヘルスチェック "OK" になれば、osaka01 サーバが通常時として復活します。
3台構成での動作確認
ロード・バランサのバックアップ制御の動作について理解できたので、3台構成で想定どおりの動きになるかを試します。
想定動作
-
バックエンドに osaka03 を追加し3台構成とする
-
osaka02 のバックアップを有効化(True)
通常時:osaka01, osaka03 サーバでラウンドロビンされる
osaka01 サーバーを停止後は、osaka03でのみリクエスト処理される -
osaka03も停止(すべてのバックエンドがヘルスOKじゃなくなる)
異常時:osaka02 がバックアップとして機能し、以後はosaka02 でリクエスト処理される
1. バックエンドに osaka03 を追加
2. osaka02 のバックアップを有効化(True)
osaka02 (192.168.0.9) のバックエンドを有効化
この状態で、ブラウザからロード・バランサに何度かリクエストすると、osaka01とosaka03 で交互に処理されることが確認できました。
この状態で、ブラウザからロード・バランサにリクエストすると、osaka03 のみで処理されることが確認できました。
3. osaka03も停止(すべてのバックエンドがヘルスでなくなる)
バックアップ有効化の osaka02 を除き、osaka01, osaka03 の停止により、バックエンド全体のヘルスがクリティカルな状態となる。
この状態で、ブラウザからロード・バランサにリクエストすると、ロード・バランサがバックアップ有効化されている osaka02 へリクエストを転送していることが確認できます。
その後のリクエストはすべて osaka02 で処理され、バックアップ有効化の想定された動きになっていることが確認できました。