🐈

Elastic Beanstalkの超詳細解説

2023/11/16に公開

はじめに

この記事はDevOps on AWS大全の一部です。
DevOps on AWS大全の一覧はこちら

この記事ではElastic Beanstalkに関連する内容を超詳細にまとめています。

具体的には以下流れで説明します。

  • Elastic Beanstalkとは
  • Elastic Beanstalkの仕組み
  • Elastic Beanstalk for Advance

AWSの区分でいう「Level 200:トピックの入門知識を持っていることを前提に、ベストプラクティス、サービス機能を解説するレベル」の内容です。

この記事を読んでほしい人

  • Elastic Beanstalkがどういうサービスか説明できるようになりたい人
  • Elastic Beanstalkを採用するときのベストプラクティスを説明できるようになりたい人
  • AWS Certified DevOps Engineer Professionalを目指している人

Elastic Beanstalkとは

Elastic Beanstalkとは開発者がアプリケーションの開発に集中するためのAWSのサービスです。
具体的には、典型的なWeb環境またはキューイングを用いた非同期型のワーカー環境の構築からリリース、運用までの手間を大幅に省いてくれるサービスです。

Amplify同様、作りこみにくいというデメリットがあるのでエンタープライズな実プロジェクトで使うことはほとんどありませんが、試験向けにはデプロイ手法がよく聞かれるので知っておいて損はありません。

Elastic Beanstalkの仕組み

Elastic Beanstalkはインフラストラクチャ部分の管理だけではなくアプリケーションの管理もまとめて行うことが可能です。
構成要素は3つ、アプリケーション、アプリケーションバージョン、環境です。

構成要素

アプリケーションはアプリケーションバージョンと環境の情報を束ねる論理単位です。
1つのアプリケーションにつき複数の環境やアプリケーションバージョンを持つことができ、例えば開発環境と本番環境の2つの環境を1つのアプリケーションで管理することが可能です。

アプリケーションバージョンはデプロイ可能なコードを指し、S3上でバージョン管理されます。
環境ごとに異なるアプリケーションバージョンをデプロイすることが可能です。

環境はインフラストラクチャ部分の設定でウェブサーバ環境とワーカー環境の2種類があります。

ウェブ環境はスケーラブルなウェブアプリケーションを実行するための環境です。
ELBとAuto Scalingでスケーラビリティを確保しています。

一方、ワーカー環境はバッチアプリケーションを実行するための環境です。
こちらはSQSとAuto Scalingでスケーラビリティを確保しています。

環境の種類とは別に環境のタイプと呼ばれる概念があります。

これは、ウェブサーバ環境とワーカー環境どちらであれコスト最適にするかパフォーマンス最適にするかをえらぶためのものでシングルインスタンス環境かAuto Scaling環境かを選んで構築可能です。
シングルインスタンス環境は低コストで運用したい際によく利用します。

デプロイメントオプション

Elastic Beanstalkでサポートされているデプロイメントオプションは5つです。

各デプロイメントオプションは以下に表形式でまとめました。

デプロイメントポリシー 詳細 負荷分散された環境のサポート 単一インスタンス環境のサポート
All at once AutoScalingGroup内のEC2インスタンスをすべて一度に更新
ローリング AutoScalingGroup内のEC2インスタンスを指定した台数ずつ更新(一時的な台数減あり) ×
追加バッチによるローリング AutoScalingGroup内のEC2インスタンスを指定した台数ずつ更新(一時的な台数減なし) ×
イミュータブル 新しくAutoScalingGroupを作りEC2インスタンス起動後、既存のAutoScalingGroupにインスタンスを移動して更新
トラフィック分割 新しくAutoScalingGroupを作りトラフィック切り替えを行い更新 ○ ※ALB必須 ×

具体的なイメージがわくように、EC2インスタンス上のアプリケーションがどのように更新されるかを可視化したのが以下の図です。

All at once は文字通り1度に全台のインスタンスを更新し、ローリングは指定した台数ずつ更新しているのがわかると思います。

ローリングと追加バッチによるローリングの違いは更新中にEC2インスタンスの台数が減少するか維持されるかです。
これはコストとパフォーマンスのどちらを取るかで選ぶことになり、試験でもよく聞かれます。

また、イミュータブルとトラフィック分割の違いは新旧のバージョンに流れるトラフィックを厳密に管理できるかできないかです。

イミュータブルの場合、一時的にですがランダムで新旧どちらかのインスタンスにトラフィックが流れます。
一方、トラフィック分割の場合、新旧それぞれに流すトラフィックの割合を制御することができます。
そのため、Canaryリリースではトラフィック分割を利用します。

また、Elastic BeanstalkのデプロイメントオプションにはないBlue/Greenを実現したい場合にはRoute53を用いたURLのスワップが必要です。

この点も試験でよく聞かれるので、Blue/GreenはElastic BeanstalkのデプロイメントオプションではなくRoute53を用いたURLスワップだと覚えておきましょう。

Elastic Beanstalk for Advance

ここまで、Web環境とワーカー環境はどちらか1つを使う前提で書いていましたが、実は2つの環境をつなぐことも可能です。

具体的には上図の通りリクエストをフロント側のWeb環境で受け、SQSを使って負荷のかかる処理をワーカー環境で非同期に処理するという構成です。
例えば巨大ファイルの圧縮などが想定できます。

なお、繰り返し実施する処理はElastic Beanstalkの中のcron.ymlに処理を記載することで実現できます。

まとめ

この記事ではElastic Beanstalkに関連する内容を超詳細にまとめました。

  • Elastic Beanstalkとは
  • Elastic Beanstalkの仕組み
  • Elastic Beanstalk for Advance

次回はAWS SAMについて超詳細解説します。

Discussion