4
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

はじめに

本記事では、Amazon VPC Latticeを使ってBlue/Green Deployを行う方法についてまとめたものになります。アプリケーションのBlue/Green Deployにはいくつか方法がございますが、手札の一つとして持っておければと思います。

実現したいこと

  • アプリケーションやサービスの更新時に、できるだけダウンタイムを少なくBlue/Green Deployを行いたい

実施手順

事前の状態

  • クライアントVPC-サービスVPC間がVPC Latticeで接続されている状態
     →Latticeのそもそものサービスネットワークやターゲットグループの作成はこちら
  • 新バージョンのアプリケーションが新しいVPCでデプロイされている状態
    before2.drawio.png

切り替え準備

新バージョンのVPCをVPC Latticeターゲットグループに追加

1. VPC Latticeのターゲットグループを作成
2. ターゲットタイプ(インスタンス or IPアドレス or Lambda or ALB)やプロトコル・ポートはアプリケーションに合わせて設定(HTTP or HTTPS or TCP)
3. ターゲットを指定して作成

Latticeサービスに追加

1. 既存のサービスを選択しリスナールールを選択
2. リスナーのアクションを選択し、ターゲットグループを追加。重みはOld Verを1、New Verを0にしておく
image.png

切り替え前の状態

blue.drawio.png

切り替えの実施

1. 既存のサービスを選択しリスナールールを選択
2. リスナーのアクションを選択し、重みの値をold verを0、new verを1に入れ替える
image.png

切り替え後の状態

green.drawio.png

New Verのアプリケーションが問題ないことを確認できたら、Old VerのターゲットグループをLatticeサービスのリスナーから削除し、Latticeターゲットグループを削除した後、Old VerのVPCやアプリケーションを削除する

ユースケース

  • アプリケーションの更新に伴いVPC内部の構成の更新(EC2ベースからECSベースへの更新など)やALBの入れ替えが必要で、VPCごと入れ替えをおこなう場合
  • アプリケーションごとにVPCの管理者が分かれており、なおかつIPアドレス設計の考慮をあまりしたくない場合
  • DNSのスワップによる一時的なダウンタイムを短くしたい場合

本方式のメリット・デメリット

メリット

  • ネットワークやVPCの切り替え中の考慮を少なくでき、VPC内の設計を簡素化できる
  • アプリケーションやデータベースごとにVPCを作るため、全体的なワークロードの疎結合化が可能になる
  • DNSのスワップによるダウンタイムを回避できるため、切り替え時間が早い

デメリット

  • クライアントーサービス間の通信が双方向になる場合は利用できない
  • 不特定多数がアクセスするVPCには適用できない(インターネットから直接接続されてくるVPC)
  • VPC Latticeを使ってサービス間の接続を行っていない場合は、サービス間接続の構成変更が必要になる

まとめ

VPC Latticeの機能から一つユースケースを考えてみました。VPC Latticeを利用することでサービス間の疎結合化ができるため、普段からVPC Latticeを使っていくことをお勧めします。

4
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?