概要
Azure Web AppsでWEBサービスを立ち上げ、そのログ監視をApplication Insightsで設定するチュートリアル的な記事です。
リソースグループ作成
リソースグループで各Azureリソースをまとめると、チュートリアル実施後のクリーンアップが楽になります。
data:image/s3,"s3://crabby-images/73c91/73c91312f1671a8a9b47363041139130c99a44f9" alt=""
グループ名は任意です。今回は「test-8839-rg」としました。
data:image/s3,"s3://crabby-images/45043/45043cdd76c15db378fbcbf162905df60c04e709" alt=""
最後に[作成]します。
data:image/s3,"s3://crabby-images/29358/2935802a7bbc29a4dddd3b7e5d739b7bc384fedd" alt=""
App Service作成
Web AppsでWEBサービスを立ち上げます。
data:image/s3,"s3://crabby-images/a7a97/a7a974a7423deb8edc14811d1533ae12637010e7" alt=""
ランタイムは Node.js を選択します。
また、[SKU とサイズ]で[サイズを変更します]を選択することで
App Serviceプラン(コンピューティングリソース)のサイズ(スペック)を変更できます。
data:image/s3,"s3://crabby-images/06c38/06c380aa024ffb3a47db37c1c29e27eb9d78a301" alt=""
Application Insightsを有効にします。
ランタイムによっては有効化できるもの/できないものがあります。
data:image/s3,"s3://crabby-images/223d8/223d82413c45ce0d7952a1890cd3a5e40fdcd5eb" alt=""
App Serviceを作成します。
data:image/s3,"s3://crabby-images/56362/563624b53bdbc727f273c8db9c1dc9640b483fa7" alt=""
リソースのデプロイが完了したら、作成されたリソースに移動します。
data:image/s3,"s3://crabby-images/1742f/1742f7913abf8ba14115974e7f2fd057e4f2edb9" alt=""
以下の通りWEBサービスのURLが確認できます。
data:image/s3,"s3://crabby-images/30732/307328635abea0e5b0d40e582dfdea512031560e" alt=""
URLにアクセスすると、以下のようなページが表示されます。
data:image/s3,"s3://crabby-images/fcaa7/fcaa7ceb781f9a9cc797b207f8f3decb4caf1612" alt=""
Application Insights監視設定
ログ確認
App Serviceから、Application Insightsの画面に遷移できます。
data:image/s3,"s3://crabby-images/fe845/fe84502ba69c61b4a51844dca5b07ce8ab6fa7ce" alt=""
data:image/s3,"s3://crabby-images/243d7/243d7343a15d02342614e61c233fbe1244e2d3b7" alt=""
監視設定
Application Insightsの画面から、アラートルールを作成します。
data:image/s3,"s3://crabby-images/c7c02/c7c022f99f7d29a0fca093cd21f0c6f44f8b0810" alt=""
アラートの発生条件を追加します。
data:image/s3,"s3://crabby-images/c7080/c7080938080261b78f447011b290963197603050" alt=""
それぞれ[ログ検索]、[Custom log search]を選択します。
data:image/s3,"s3://crabby-images/fc045/fc045a515e304f13dcb5df08a2f451b2be06c80e" alt=""
図の通り設定します。
data:image/s3,"s3://crabby-images/5cdf3/5cdf30e3c54f81d85fde1376c14400f2a0c7435f" alt=""
「"test-8839-access" を含むURLでアクセスされた場合」という条件になっています。
1 2 |
requests | where url contains "test-8839-access" |
※検索クエリについては後述します。
次にアクショングループを作成します。
アラートが発生した場合のアクション(今回の場合はメール通知)を定義します。
data:image/s3,"s3://crabby-images/5f66c/5f66cb24ecbf7bc559e71e24508c51168b36d246" alt=""
アクショングループ名などは任意です。
data:image/s3,"s3://crabby-images/a93f7/a93f7f92cd4cca9b1fec51bcc7448de51efe79bf" alt=""
アラートメールの送付先を指定します。
data:image/s3,"s3://crabby-images/e507a/e507a3a44a638d2798b958ab3fca3ab6eacfc71a" alt=""
アクショングループのアクション名を入力し[OK]を選択します。
data:image/s3,"s3://crabby-images/464df/464df958143995306b4ae739a52cc8400affe372" alt=""
アラートメールの件名などを入力し、アラートルールを作成します。
data:image/s3,"s3://crabby-images/d4158/d41580fa0ffd9fb34eb67ee97b689d93b13106de" alt=""
アラートテスト
監視対象の文字列(test-8839-access)が含まれるURLでWEBサービスにアクセスしてみます。
data:image/s3,"s3://crabby-images/baac4/baac4b8fb7d3ed76f75932fec09491befb2332c4" alt=""
しばらくすると、以下のようなアラートメールが送信されていました。
data:image/s3,"s3://crabby-images/50696/50696530549ba61380be29b7904be8850ce0bcfd" alt=""
Application Insightsの検索クエリ
Application Insightsの[検索]画面から[ログ(Analytics)]を選択すると、
data:image/s3,"s3://crabby-images/316d4/316d42ba2ab9947d34c92b0cca532df3a0015b75" alt=""
検索クエリを実行できる画面に遷移します。
data:image/s3,"s3://crabby-images/79f61/79f61d02085ef880ffc055e07fbddf04d10fa1c1" alt=""
以下クエリサンプルが参考になります。
投稿者プロフィール
- 2015年8月入社。弊社はインフラ屋ですが、アプリも作ってみたいです。