LoginSignup
6
2

More than 1 year has passed since last update.

【Azure】Container Registryにプッシュしたら自動でApp Serviceのコンテナを最新化する

Posted at

AzureでApp Serviceでコンテナを使用したWebアプリを作成しています。リポジトリは同じくAzureのContainer Registryです。
コンテナイメージを最新化するたびにApp Serviceを手動で更新するのは面倒です。そんな問題を解決する方法として、Webhookを使用してApp Serviceのコンテナを最新化するお手軽CD(Continuous Delivery/継続的デリバリー)を紹介します。

前提条件

  • Azure(クラウドサービス)の基本を理解している
  • Azure CLIの基本を理解している
  • コンテナの基本を理解している

ターゲット

  • コンテナイメージを更新するたびに、App Serviceも更新するのが手間に感じている
  • 簡単でいいのでCDを構築してみたい
  • Container Registry/App ServiceのWebhookを使ってみたい

概要

summaryx1.5_margin30.drawio.png

  1. Container RegistryにコンテナイメージをPushする
  2. Container RegistryがイメージのPushを検知して、設定されているApp ServiceのWebhook URLを叩く
  3. Webhook URLが叩かれたことでApp Serviceが再起動して、最新のコンテナイメージをPullすることで最新化される

App Serviceにコンテナイメージの最新化を知らせる仕組み

Container Registryのコンテナイメージに更新があった場合、そのことをApp Serviceに知らせたいです。言い換えると、App Serviceに「コンテナイメージの更新」という イベント を通知する仕組みが必要です。

そんなときのために、App Serviceには「コンテナイメージの更新」という イベント を通知する仕組みとしてWebhook URLが用意されています。Webhookは、イベントが発生したらその内容を通知する仕組みのことです。Webhook URLにリクエストを送ることで、「コンテナイメージの更新」を知らせることが出来ます。

AzureのContainer RgistoryはWebhook機能があるので、そこにApp ServiceのWebhook URLを登録すれば、コンテナイメージのPushをトリガーに自動でWebhook URLを叩いてくれます。

構築手順

これからApp Serviceを作成する場合は、Container Registryがパブリックの場合とプライベートの場合で若干異なりますので、環境に合わせてどちらかを行ってください。
すでにApp Serviceまで作成が完了している場合は、Webhookの設定から行ってください。

Container Registryの作成

Container Registryを作成していない場合は、作成しましょう。
SKUによるWebhookの違いは登録できる数ですので、お試しならば Basic で十分です。
セキュリティ等の観点で、プライベートレジストリが良い場合は Premium です。
create_container_registry.png
SKUの価格表
image.png
引用元 | Container Registry の価格 (2022/8/8現在)

コンテナイメージのPush

コンテナイメージをPushしていない場合は、Pushしましょう。
適切な権限のユーザーまたはサービスプリンシパルで行いましょう。プライベートレジストリの場合はネットワーク設定が必要な場合もあります。
お試しで何を使おうか迷う場合は、nginx:alpineがおすすめです。
container_images.png

Container Registryの管理者ユーザー有効化

App ServiceにContainer Registryを紐づける場合は、管理者ユーザーを有効化する必要があります。
アクセスキーの設定画面で、管理者ユーザーのトグルを有効にしてください。
container_registry_admin.png

App Serviceの作成

App Serviceを作成していない場合は、作成しましょう。
基本 では各項目を入力して、公開Dockerコンテナー を選択します。
app_service_create_basic.png
Docker では、Container Registoryの情報とそこから取得するイメージとタグを指定します。
プライベートレジストリの場合とパブリックレジストリの場合で入力項目が違いますので注意してください。

必要な値の確認方法はこちら

{レジストリ名}, {ログイン サーバー}, {ユーザー名}, {password}
Container Registryのアクセスキーから確認できます。
container_registry_loginserver.png

{リポジトリ}, {タグ}
Container Registryのリポジトリからリポジトリを選択して確認できます。
container_registry_imagetag.png

プライベートレジストリの場合
オプション | 単一コンテナー
イメージ ソース | プライベートレジストリ
サーバーURL | https://{ログイン サーバー}
ユーザー名 | {ユーザー名}
パスワード | {password}
イメージとタグ | {ログイン サーバー}/{リポジトリ}:{タグ}
app_service_create_docker_private.png
パブリックレジストリの場合
オプション | 単一コンテナー
イメージ ソース | Azure Container Registry
レジストリ | {レジストリ名}
イメージ | {リポジトリ}
タグ | {タグ}
app_service_create_docker_public.png

Webhookの設定

App Serviceのデプロイセンターから 継続的デプロイオン に設定して保存します。

app_service_update_webhook.png

Container Registry側にも自動でWebhookが追加されるはずなので、確認しましょう。
container_registry_webhook.png

確認

Container Registryのリポジトリに、新しいコンテナイメージをPushして、App Serviceが自動で更新されることを確認しましょう。

ちゃんとコンテナが更新されれば成功です!

更新されない場合に確認すること

  • リポジトリとコンテナイメージのタグがApp Serviceの設定と同じであること
  • Container Registryの管理者ユーザーが有効化されていること→(Container Registryの管理者ユーザー有効化)
  • Container RegistryのWebhooksにWebhook URLが追加されていて、状態が有効であること→(Webhookの設定)
    • 追加されていない場合は、App Serviceのデプロイセンターの設定が正しいことを確認して、手動でContainer RegistryのWebhooksを追加する
  • App Serviceの デプロイセンター > ログ から原因を調査
    • Container Registryがプライベートレジストリの場合でコンテナイメージのPullが失敗しているときは、App ServiceがイメージをPullするときのIPアドレスがブロックされている可能性があるので、Container Registryの ネットワーク > ファイアウォール でIPアドレスを許可する

おわりに

紹介した内容は、Azureでコンテナを使うCDではもっとも簡単な方法の一つだと思います。
コンテナイメージ更新時にApp Serviceが再起動するので、ダウンタイムがあってはいけない本番環境向きではないですが、ダウンタイムが許容できるサービスや開発環境などでは十分ですね。

6
2
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
6
2