テンプレートから学ぶ Azure ~ Web API 編 ~
簡単な TODO アプリのテンプレートから Azure を学ぶシリーズ。 今回は Azure-Samples/todo-nodejs-mongo-terraformを触って勉強します。
目的
簡単な TODO アプリのテンプレートをデプロイして、実動作とソースコードを確かめつつ、Azure の基本的な機能を学びます。 アーキテクチャ図は以下の通りです。
デプロイ
まずは README.md を読み、デプロイ手順を確認します。
このリポジトリは azd
対応なので、コマンド一発でデプロイできます。
azd については、Azure Developer CLI による開発プロセスの高速化を参照してください。
# リポジトリを clone
git clone git@github.com:Azure-Samples/todo-nodejs-mongo-terraform.git
cd todo-nodejs-mongo-terraform
# APIM を使いたいので環境変数を設定
azd env set USE_APIM true
# デプロイ
azd up
以上で Azure 上にリソースが作成され、デプロイが完了します。 デプロイされた API サーバーや Web アプリにアクセスして動作確認します。
- API サーバーにアクセス(Swagger UI が開く):
https://app-api-{RESOURCE_TOKEN}.azurewebsites.net/
- Web サーバーにアクセス(Web アプリが開く):
https://app-web-{RESOURCE_TOKEN}.azurewebsites.net/
また、コマンドラインから動作メトリクスを確認できます。
# Azure Dashboard を開く
azd monitor --overview
# Application Insights の Live metrics stream を開く
azd monitor --live
# Application Insights の Logs を開く
azd monitor --logs
コードを読む
azd
対応なプロジェクトは、ディレクトリ構造に規則性があるのでソースコードが読みやすいです。
一例として自分のコードの読み方を紹介します。
IaC コードの概要をつかむ
インフラ側のリソース定義は、infra/
以下にあります。
infra/main.tf がプログラムのエントリポイントになっていて、ここで定義される各種 module の実装詳細は modules/
以下に配置されています。
細部を読み込む前に、まずはこの main.tf を読んで全体像を把握しておきましょう。
ここでは一例として applicationinsights
を見てみます。
module "applicationinsights" {
source = "./modules/applicationinsights"
location = var.location
rg_name = azurerm_resource_group.rg.name
environment_name = var.environment_name
workspace_id = module.loganalytics.LOGANALYTICS_WORKSPACE_ID
tags = azurerm_resource_group.rg.tags
resource_token = local.resource_token
}
ここで引数として指定されている module.loganalytics.LOGANALYTICS_WORKSPACE_ID
に注目します。
これは applicationinsights が loganalytics に依存していることを意味します。
すべてを頭に入れるのは大変なので、どのモジュールがどのような方向で依存を張っているのかの概要をざっくり把握しておくと、後々の細部の理解が楽になります。
(図に書いてモジュール間の依存を矢印で書くと良いです)
Web アプリケーションと API サーバーの実装は、modules/appservicenode/
以下にあります。
それぞれ環境変数として参照しているパラメータから依存関係が判ります。
以下は API サーバーの設定値です。
app_settings = {
"AZURE_COSMOS_CONNECTION_STRING_KEY" = local.cosmos_connection_string_key
"AZURE_COSMOS_DATABASE_NAME" = module.cosmos.AZURE_COSMOS_DATABASE_NAME
"SCM_DO_BUILD_DURING_DEPLOYMENT" = "true"
"AZURE_KEY_VAULT_ENDPOINT" = module.keyvault.AZURE_KEY_VAULT_ENDPOINT
"APPLICATIONINSIGHTS_CONNECTION_STRING" = module.applicationinsights.APPLICATIONINSIGHTS_CONNECTION_STRING
}
ざっくり以下のことが分ります。
module.cosmos
,AZURE_COSMOS_CONNECTION_STRING_KEY
から Cosmos DB に依存AZURE_KEY_VAULT_ENDPOINT
から Key Vault に依存module.applicationinsights.APPLICATIONINSIGHTS_CONNECTION_STRING
から Application Insights に依存
azd up
で作成された各種リソースは .azure/ENVIRONMENT_NAME/terraform.tfstate
に記録されていますので、実際に設定された個々のパラメータを確認できます。
WIP: azure.yaml の services のビルドプロセスについて
azd
は、azure.yaml
に定義された services
のビルドプロセスを自動化しています。
挙動の詳細は把握し次第追記します。