

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# Elastic ロードバランシングレイヤー
<a name="layers-elb"></a>

**重要**  
この AWS OpsWorks Stacks サービスは 2024 年 5 月 26 日にサポート終了となり、新規および既存のお客様の両方で無効になっています。できるだけ早くワークロードを他のソリューションに移行することを強くお勧めします。移行についてご質問がある場合は、[AWS re:Post](https://repost.aws/) または[AWS プレミアムサポート](https://aws.amazon.com/support)を通じて AWS サポート チームにお問い合わせください。

Elastic Load Balancing OpsWorks の動作は、 スタックレイヤーとは多少異なります。レイヤーを作成してインスタンスを追加する代わりに、Elastic Load Balancing コンソールまたは API を使用してロードバランサーを作成し、既存のレイヤーにアタッチすることもできます。レイヤーのインスタンスにトラフィックを分散することに加えて、Elastic Load Balancing は以下を行います。
+ 異常な Amazon EC2 インスタンスを検出し、異常なインスタンスが復旧するまで、トラフィックを残りの正常なインスタンスに再ルーティングします。
+ 受信トラフィックに応じて、自動的にそのリクエスト処理能力を拡張します。
+ [Connection Draining](https://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/config-conn-drain.html) を有効にすると、異常があるまたは登録解除されるインスタンスへの新しいリクエストの送信がロードバランサーで停止されるものの、指定された最大タイムアウト値まで接続が維持されるため、インスタンスはすべての処理中のリクエストを完了できます。

ロードバランサーをレイヤーにアタッチすると、 OpsWorks Stacks は以下を実行します。
+ 現在登録されているインスタンスの登録を解除します。
+ レイヤーのインスタンスがオンラインになるとこれを自動的に登録し、オフラインになるとインスタンスの登録を解除します。これには、負荷ベースのインスタンスも、時間ベースのインスタンスも含まれます。
+ アベイラビリティーゾーンの登録されたインスタンスへのリクエストのルーティングを自動的に開始します。

ロードバランサー[の接続ドレイニング](https://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/config-conn-drain.html)機能を有効にしている場合は、 OpsWorks スタックがサポートするかどうかを指定できます。Connection Draining サポートを有効にすると (デフォルト設定）、インスタンスがシャットダウンされた後、 OpsWorks Stacks は以下を実行します。
+ ロードバランサーからインスタンスを登録解除します。

  ロードバランサーは新しいリクエストの送信を停止し、Connection Drainingを開始します。
+ ロードバランサーが Connection Draining を完了するまで、[Shutdown ライフサイクルイベント](workingcookbook-events.md)のトリガーを遅らせます。

Connection Draining サポートを有効にしない場合、インスタンスがまだロードバランサーに接続されている場合でも、 OpsWorks スタックはインスタンスがシャットダウンされるとすぐに Shutdown イベントをトリガーします。

Elastic Load Balancing をスタックとともに使用する場合は、まず Elastic Load Balancing コンソール、CLI、または API を使用して、同じリージョン内に 1 つ以上のロードバランサーを作成する必要があります。以下に注意する必要があります。
+ レイヤーにアタッチできるロードバランサーの数は 1 つのみです。
+ 各ロードバランサーで処理できるレイヤーは 1 つのみです。
+ OpsWorks スタックは Application Load Balancer をサポートしていません。 OpsWorks スタックは Classic Load Balancer でのみ使用できます。

つまり、負荷分散する各スタックのレイヤーごとに個別の Elastic Load Balancing ロードバランサーを作成し、その目的のためだけに使用する必要があります。 OpsWorks スタックで使用する予定の各 Elastic Load Balancing ロードバランサーにわかりやすい名前 (MyStack1-RailsLayer-ELB など) を割り当てて、1 つのロードバランサーを複数の目的で使用しないようにすることをお勧めします。

**重要**  
スタックレイヤー用に新しい Elastic Load Balancing OpsWorks ロードバランサーを作成することをお勧めします。既存の Elastic Load Balancing ロードバランサーを使用する場合は、まず、他の目的で使用されておらず、インスタンスがアタッチされていないことを確認する必要があります。ロードバランサーがレイヤーにアタッチされた後、OpsWorks は既存のインスタンスをすべて削除して、レイヤーのインスタンスのみを処理するようにロードバランサーを設定します。レイヤーにアタッチした後でロードバランサーの設定を Elastic Load Balancing コンソールまたは API を使用して変更することは技術的には可能ですが、そうしないでください。この変更は永続的ではないためです。

**Elastic Load Balancing ロードバランサーをレイヤーにアタッチするには**

1. まだ作成していない場合は、[Elastic Load Balancing コンソール](https://console.aws.amazon.com/ec2/#s=LoadBalancers)、API、または CLI を使用して、スタックのリージョンでロードバランサーを作成します。ロードバランサーを作成する場合、以下の作業を行います。
   + アプリケーションに適したヘルスチェック ping パスを指定してください。

     デフォルトの ping パスは `/index.html` であるため、アプリケーションのルートに `index.html` が含まれていない場合、適切な ping パスを指定する必要があります。そうしないと、ヘルスチェックは失敗します。
   + [Connection Draining](https://docs.aws.amazon.com/elasticloadbalancing/latest/userguide/config-conn-drain.html) を使用する場合は、この機能が有効になっていて、適切なタイムアウト値が設定されていることを確認します。

   詳細については、「[Elastic Load Balancing](https://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/Welcome.html)」を参照してください。

1. バランスを取りたい[レイヤーを作成](workinglayers-basics-create.md)するか、[既存のレイヤーのネットワーク設定を編集](workinglayers-basics-edit.md)します。
**注記**  
カスタムレイヤーの作成時にロードバランサーをアタッチすることはできません。レイヤーの設定を編集する必要があります。

1. **Elastic Load Balancing** で、レイヤーにアタッチするロードバランサーを選択し、 OpsWorks スタックで接続ドレイニングをサポートするかどうかを指定します。

ロードバランサーをレイヤーにアタッチすると、 OpsWorks スタックはスタックのインスタンスで [Configure ライフサイクルイベント](workingcookbook-events.md)をトリガーして変更を通知します。また、ロードバランサーをデタッチすると OpsWorks 、スタックは Configure イベントもトリガーします。

**注記**  
インスタンスが起動すると、 OpsWorks スタックは [Setup レシピと Deploy レシピを実行し](workingcookbook-executing.md)、パッケージをインストールしてアプリケーションをデプロイします。これらのレシピが完了すると、インスタンスはオンライン状態になり、 OpsWorks スタックはインスタンスを Elastic Load Balancing に登録します。 OpsWorks スタックは、インスタンスがオンラインになった後に Configure イベントもトリガーします。これは、Elastic Load Balancing 登録と Configure レシピが同時に実行される可能性があり、Configure レシピの終了前にインスタンスが登録される可能性があることを意味します。インスタンスが Elastic Load Balancing に登録される前にレシピを終了させるには、レイヤーの Setup または Deploy ライフサイクルイベントにレシピを追加する必要があります。詳細については、「[レシピの実行](workingcookbook-executing.md)」を参照してください。

ロードバランサーからインスタンスを削除した方がよい場合があります。たとえば、アプリケーションを更新するときは、アプリケーションを 1 つのインスタンスにデプロイし、各インスタンスにデプロイする前にアプリケーションが正しく動作していることを確認することをお勧めします。通常、ロードバランサーからそのインスタンスを削除するため、更新を確認するまでユーザーリクエストを受信しません。

ロードバランサーからオンラインインスタンスを一時的に削除するには、Elastic Load Balancing コンソールまたは API を使用する必要があります。コンソールを使用する方法を次に説明します。

**ロードバランサーから一時的にインスタンスを削除するには**

1. [[Amazon EC2 console](https://console.aws.amazon.com/ec2/)] (Amazon EC2 コンソール) を開き、[**Load Balancers**] (ロードバランサー) を選択します。

1. 適切なロードバランサーを選択し、[**Instances**] タブを開きます。

1. インスタンスの [**Actions**] (アクション) 列で [**Remove from Load Balancer**] (ロードバランサーから移動) を選択します。

1. 完了したら、[**Edit Instances**] を選択し、インスタンスをロードバランサーに戻します。

**重要**  
Elastic Load Balancing コンソールまたは API を使用してロードバランサーからインスタンスを削除する場合は、Elastic Load Balancing を使用してインスタンスを戻す必要もあります。 OpsWorks スタックは、他のサービスコンソールまたは APIs で実行するオペレーションを認識しないため、インスタンスがロードバランサーに返されることはありません。場合によっては、 OpsWorks スタックはインスタンスを ELB に戻すことができますが、これは保証された動作ではなく、すべてのケースで発生するわけではありません。

次のように、インスタンスの特定のセットに複数のロードバランサーをアタッチできます。

**複数のロードバランサーをアタッチするには**

1. [Elastic Load Balancing console](https://console.aws.amazon.com/ec2/#s=LoadBalancers) (Elastic Load Balancing コンソール)、API、または CLI を使用して、ロードバランサーのセットを作成します。

1. ロードバランサーごとに[カスタムレイヤーを作成](workinglayers-custom.md)し、該当するロードバランサーをアタッチします。これらのレイヤーにカスタムレシピを実装する必要はありません。デフォルトのカスタムレイヤーで十分です。

1. 各カスタムレイヤーに[インスタンスのセットを追加](workinginstances-add.md)します。

[Instances] ページに移動して、適切なロードバランサーの名前をクリックすると、ロードバランサーのプロパティを確認できます。

![\[PHP App Server table showing two online instances with their details and status.\]](http://docs.aws.amazon.com/ja_jp/opsworks/latest/userguide/images/elb_view.png)


[**ELB**] ページには、関連するインスタンスの DNS 名やヘルスステータスなど、ロードバランサーの基本プロパティが表示されます。スタックが VPC 内で実行されている場合、ページにはアベイラビリティーゾーンではなくサブネットが表示されます。緑のチェックマークは、正常なインスタンスを示します。名前をクリックすると、ロードバランサーを通じてサーバーに接続できます。

![\[ELB My-Stack-PHP settings showing DNS name, layer, region, and instance status.\]](http://docs.aws.amazon.com/ja_jp/opsworks/latest/userguide/images/elb_properties.png)
