体験して理解しよう!マイクロサービスの開発、ビルド、デプロイ、運用
data:image/s3,"s3://crabby-images/a4fc6/a4fc6b7d0a5e6598cfbf1e941c506c35e06e01ad" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/0108_blog_header_W.max-2200x2200.jpg"
Kimihiko Kitase
Head of Enterprise Marketing, Google Cloud Japan
デモ用のマイクロサービスアプリケーションを使って実際に、マイクロサービスアプリケーションの開発、ビルド、デプロイ、運用を体験してみましょう。
このアプリケーションは、10 のサービスで構成されている「Hipster Shop」と呼ばれるデモ用の EC サイトです。ユーザーは、製品を選択し、カートに追加し購入することができます。各サービスは、Go, C#, Node.js, Python, Java といった言語で独自に書かれおり、下記のように、gRPC でコミュニケーションします。また、開発者は skaffold を使用し、1 コマンドでアプリケーションのビルド、デプロイが可能です。実行環境は、Google Kubernetes Engine (GKE) や、Local の Kubernetes 環境を選択することができます。今回は、GKE 環境を使って体験してみたいと思います。data:image/s3,"s3://crabby-images/48278/48278304e00f950a95cf307dab0dce7cb52e8d43" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure1.max-1700x1700.png"
data:image/s3,"s3://crabby-images/48278/48278304e00f950a95cf307dab0dce7cb52e8d43" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure1.max-1700x1700.png"
準備
プロジェクトを作成し、Cloud Shell を起動し、デモ用のマイクロサービスアプリケーションをクローンします。
- GCP アカウントと、GitHub アカウントを作成(既にアカウントを持っている方は必要ありません)
- GCP Console にログオンし、プロジェクトを作成
data:image/s3,"s3://crabby-images/310ee/310eeb26f52b7d82a104f2d88d1fcd6df45cc981" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure2_jJgdb6Z.max-1900x1900.png"
data:image/s3,"s3://crabby-images/310ee/310eeb26f52b7d82a104f2d88d1fcd6df45cc981" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure2_jJgdb6Z.max-1900x1900.png"
- [Cloud Shell をアクティブにする] をクリック
data:image/s3,"s3://crabby-images/a5e27/a5e27c54dca8505e41100e703f87945aa2834080" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure3.max-2200x2200.png"
data:image/s3,"s3://crabby-images/a5e27/a5e27c54dca8505e41100e703f87945aa2834080" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure3.max-2200x2200.png"
- [Cloud Shell 環境] から、Cloud Shell を起動
data:image/s3,"s3://crabby-images/6153a/6153a227e1bfd3b146ff56211857e5d8c0bbb79b" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure4.max-2200x2200.png"
data:image/s3,"s3://crabby-images/6153a/6153a227e1bfd3b146ff56211857e5d8c0bbb79b" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure4.max-2200x2200.png"
- gcloud コマンドの初期設定
data:image/s3,"s3://crabby-images/3ff98/3ff9866a5e5fbc429a846cc0171c691df1707c81" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure5.max-2200x2200.png"
data:image/s3,"s3://crabby-images/3ff98/3ff9866a5e5fbc429a846cc0171c691df1707c81" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure5.max-2200x2200.png"
- Cloud Shell にて、Fork した マイクロサービスアプリケーションを Clone
- 必要な GCP のサービスを有効に
- Container Registry を Docker registry として利用するために、gcloud を Docker 認証ヘルパーとして登録
アプリケーションのデプロイ
GKE クラスタを作成し、アプリケーションをデプロイします。
GKE クラスタを作成
- アプリケーションのビルドとデプロイ : skaffold を使用し、1 コマンドで、ビルドからデプロイメントまで行います。(全てのサービスをビルドするので、30 分程度かかります。)
- ブラウザを起動し、fronted-external の EXTERNAL-IP にアクセスし、アプリケーションが正常に動作していることを確認
data:image/s3,"s3://crabby-images/f5304/f53046b407160b8fd7a29881c42d5d5725522be2" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure6.max-2200x2200.png"
data:image/s3,"s3://crabby-images/f5304/f53046b407160b8fd7a29881c42d5d5725522be2" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure6.max-2200x2200.png"
- Cloud Build のログを確認
data:image/s3,"s3://crabby-images/f378e/f378ed3c58ad55e4f51718224c5f8a97f742d80e" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure7.max-2200x2200.png"
data:image/s3,"s3://crabby-images/f378e/f378ed3c58ad55e4f51718224c5f8a97f742d80e" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure7.max-2200x2200.png"
data:image/s3,"s3://crabby-images/09243/092438816abb7199ee0677e86a80653b84c4736c" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure8.max-2200x2200.png"
data:image/s3,"s3://crabby-images/09243/092438816abb7199ee0677e86a80653b84c4736c" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure8.max-2200x2200.png"
- Container Registry にあるビルドされたコンテナを確認
data:image/s3,"s3://crabby-images/19273/19273da780b3914dda46d2cf69e0dac06f2bbc8a" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure9.max-2200x2200.png"
data:image/s3,"s3://crabby-images/19273/19273da780b3914dda46d2cf69e0dac06f2bbc8a" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure9.max-2200x2200.png"
data:image/s3,"s3://crabby-images/bdf8f/bdf8fd689e103b03c186001cf394f416adfbcf77" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure10.max-2200x2200.png"
data:image/s3,"s3://crabby-images/bdf8f/bdf8fd689e103b03c186001cf394f416adfbcf77" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure10.max-2200x2200.png"
data:image/s3,"s3://crabby-images/0354c/0354c426ca525352c1cab336d71fe7aa56d56b75" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure11.max-2200x2200.png"
data:image/s3,"s3://crabby-images/0354c/0354c426ca525352c1cab336d71fe7aa56d56b75" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure11.max-2200x2200.png"
ソースコードの修正
ソースコードを修正し、GKE クラスタにアプリケーションを再度デプロイします。
microservices-demo/src/frontend/templates/header.html の <header> を修正し、再ビルド
- ブラウザを起動し、frontend-external の EXTERNAL-IP にアクセスし、Header 部分が変わっていることを確認
data:image/s3,"s3://crabby-images/29159/29159416f170acab3dafeab2adbdad588d1cdfb7" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure12.max-2200x2200.png"
data:image/s3,"s3://crabby-images/29159/29159416f170acab3dafeab2adbdad588d1cdfb7" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure12.max-2200x2200.png"
- Build ログの確認
data:image/s3,"s3://crabby-images/8641c/8641c96b3a9bd2b39cff46d75cad570dbfad79cb" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure13.max-2200x2200.png"
data:image/s3,"s3://crabby-images/8641c/8641c96b3a9bd2b39cff46d75cad570dbfad79cb" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure13.max-2200x2200.png"
data:image/s3,"s3://crabby-images/e64b1/e64b133ac772eabd695f12cfb916612a6bcae9b0" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure14.max-2200x2200.png"
data:image/s3,"s3://crabby-images/e64b1/e64b133ac772eabd695f12cfb916612a6bcae9b0" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure14.max-2200x2200.png"
- コンテナの確認
data:image/s3,"s3://crabby-images/47bec/47bec0a2fdb8a90a544cc4213ac840229ec9a6bf" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure15.max-2200x2200.png"
data:image/s3,"s3://crabby-images/47bec/47bec0a2fdb8a90a544cc4213ac840229ec9a6bf" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure15.max-2200x2200.png"
data:image/s3,"s3://crabby-images/6f98a/6f98ab8a0a11be98164c8f41bb8092b4de979b76" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure16.max-2200x2200.png"
data:image/s3,"s3://crabby-images/6f98a/6f98ab8a0a11be98164c8f41bb8092b4de979b76" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure16.max-2200x2200.png"
data:image/s3,"s3://crabby-images/2e7bf/2e7bf8cf4beb9f3ea0ea3fa5dec192ccea104daa" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure17.max-2200x2200.png"
data:image/s3,"s3://crabby-images/2e7bf/2e7bf8cf4beb9f3ea0ea3fa5dec192ccea104daa" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure17.max-2200x2200.png"
レプリケーションとオートヒーリング
Kubernetes の特徴は「アプリケーションのあるべき姿」を設定ファイル(yaml ファイル)で宣言できるという事です。障害があった場合でも、設定ファイルに書いたとおりのインフラを維持(オートヒーリング)するように設計されています。ここでは、adservice サービスに障害が起きたとき、正しくオートヒーリングするか確認します。また、Node がダウンした場合でも影響を与えたくない frontend サービスにはレプリケーションの設定を行います。
クラスタ環境の確認
- Replica の設定: kubectl scale を使用するには、--replicas フラグを設定して新しいレプリカ数を指定します。たとえば frontend を 3 つのレプリカにスケーリングするには、次のコマンドを実行します。
- コンソールからも設定可能: [Kubernetes Engine] - [ワークロード] で Replica の設定を行いたいサービスを選択し、 [操作] - [スケール] を選択し Replica 数を設定します。
data:image/s3,"s3://crabby-images/d58ad/d58ad2b438676e3d8abc41b0e4e0b22c0178e07d" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure18.max-2200x2200.png"
data:image/s3,"s3://crabby-images/d58ad/d58ad2b438676e3d8abc41b0e4e0b22c0178e07d" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure18.max-2200x2200.png"
- クラスタの状態を監視: Cloud Shell で、Ctrl + b → % キーを押し、セッションウィンドウを分割し分割したウインドウで下記コマンドを実行します。(移動は Ctrl + b → o 、解除は Ctrl + b → x です。)
- オートヒーリングのテスト: 元のウインドウに戻り(Ctrl + b → o)、Pod が落ちたときでも、自動的に新しくコンテナを作成されることを確認します。(分割ウインドウの状態を確認)
- オートヒーリングのテスト: Node が落ちたときでも、自動的に Node が再起動されることを確認します。(分割ウインドウを確認)
- adservice とサイト全体の状態をブラウザで確認: adservice は ページ下部に広告を表示するサービスです。adservice の Pod や Node が落ちると、一時的に広告が表示されなくなりますが、サイト全体は落ちません。また、オートヒーリングにより、すぐに adservice が再作成され、広告も正常に表示されます。
data:image/s3,"s3://crabby-images/e4523/e452317bd8515fff47b41871ecdb8819921ad9a2" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure19.max-2200x2200.png"
data:image/s3,"s3://crabby-images/e4523/e452317bd8515fff47b41871ecdb8819921ad9a2" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure19.max-2200x2200.png"
data:image/s3,"s3://crabby-images/403b4/403b4481ac6cb98bfd6e2f55db843e7d4eb3db30" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure20.max-2200x2200.png"
data:image/s3,"s3://crabby-images/403b4/403b4481ac6cb98bfd6e2f55db843e7d4eb3db30" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure20.max-2200x2200.png"
オートスケーリング
Horizontal Pod Autoscaler (HPA) により、各サービスの CPU 使用率に応じて、Pod を自動的にスケールすることができます。ここでは、負荷がかかりやすい frontend サービスを自動的にスケールするように設定したいと思います。
オートスケーリングの設定: kubectl autoscale を使用するときは、アプリケーションの最大レプリカ数と最小レプリカ数、CPU 使用率の目標を指定します。たとえば、レプリカの最大数を 6、最小数を 3 にして、CPU 使用率の目標を 50% に設定するには、下記コマンドを実行します。(オートスケーリングの設定を解除する場合は、kubectl delete hpa frontend)
- コンソールからも設定可能: [Kubernetes Engine] - [ワークロード] で autoscale の設定を行いたいサービスを選択し、 [操作] - [自動スケーリング] を選択し設定します。
data:image/s3,"s3://crabby-images/b2308/b23084f5c6f186b43cca02298741e091bc56b26a" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure21.max-2200x2200.png"
data:image/s3,"s3://crabby-images/b2308/b23084f5c6f186b43cca02298741e091bc56b26a" alt="https://storage.googleapis.com/gweb-cloudblog-publish/images/Figure21.max-2200x2200.png"
- オートスケーリングのテスト: Apache Bench によるストレステストを行い、正しくオートスケールされるか確かめてみます。frontend サービスの CPU 使用率が 50% を超えたあたりから、pod 数が自動的に増加することを確認します。
クリーンアップ
利用したリソースを今後利用しない場合は、課金を避けるためにも削除しましょう。
アプリケーションを削除する場合: skaffold run コマンドを使ってデプロイした場合は、skaffold delete コマンドで、デプロイしたアプリケーションをクリーンアップすることができます。kubectl apply -f [...] コマンドを使ってデプロイした場合は、kubectl delete -f [...] コマンドで、デプロイしたアプリケーションをクリーンアップしてください。
- クラスタごと削除する場合
- プロジェクトごと削除する場合
いかがでしょうか。マイクロサービスの開発、ビルド、デプロイ、運用を体験できたでしょうか。本来のマイクロサービスアプリケーションは、もっと大規模なものになるとは思いますが、少しでも実感が湧いてもらえればと思います。