data:image/s3,"s3://crabby-images/3444d/3444d6f4e4668356360a0bc3d31895ca7b5b0eee" alt="Google App Engine(GAE)で作成したサービスのアクセスエラー率を可視化・アラート通知する方法"
Google App Engine(GAE)で作成したサービスのアクセスエラー率を可視化・アラート通知する方法
2023.04.11
本記事のポイント
PaaS系のサービスであるGoogle App Engine(以下、GAE)を運用している方の中には、どのような形でアプリケーションの異常に気が付けるか、それを設定する方法でお悩みではないでしょうか。
この記事では、Cloud Monitoringで可視化やアラート通知を行う方法について解説します。
はじめに
サーバーレスでアプリケーション開発に集中できる仕組みが整っているGoogle App Engine(以下、GAE)ですが、実際にサービスインしたいけど「適切な監視方法が応答監視ぐらいしか思いつかない」「もう少し詳細な監視をしたい」とお悩みの方も多くいらっしゃるのではないでしょうか。 そこで今回は、Cloud Monitoring(以下、Monitoring)を利用した可視化や監視方法について解説します。 記事前半ではダッシュボードで可視化する方法を、後半ではアラート通知する方法をお伝えするので、是非じっくりとご覧ください。Google App Engine(GAE)とは
GAEとはGoogleが提供するGoogle Cloudのサーバーレスサービスのひとつです。 JavaやPython、Node.jsなど好きな言語で作成したWebアプリケーションをGoogleが管理するサーバーに簡単にデプロイできるPaaS系のプラットフォームです。 GAEにはスタンダード環境とフレキシブル環境の2つの環境が次のような特徴があります。1. スタンダード環境
- GAEが用意するサンドボックス内で実行される
- 無料または低コストでアプリケーション開発ができる
- インスタンスの稼働時間で課金が発生
2. フレキシブル環境
- Google Compute Engine上のDockerコンテナ内で実行される
- スケーリング処理を細かく制御できるアプリケーション開発ができる
- 使用したvCPU、メモリー、ディスク量に応じて課金が発生
Google Cloud ダッシュボードで可視化する方法
続いて、Monitoringのダッシュボードで可視化する方法をお伝えします。 実際に監視対象となる環境を用意したいので公式で用意されている環境でアプリケーションを用意しましょう。 環境 ・GAEの環境の種類:フレキシブル ・Python:3 アプリケーションの用意が終わりましたらダッシュボードの作成に移ります。 Monitoring > ダッシュボード ダッシュボードを作成します。data:image/s3,"s3://crabby-images/f31f9/f31f98b43f92378320bbca7b5415f7bd650c9659" alt="Google App Engineダッシュボード"
data:image/s3,"s3://crabby-images/1759a/1759a24109db028b3d021d4388a09da22d228e48" alt="Google App Engineダッシュボードグラフ追加"
data:image/s3,"s3://crabby-images/96718/967182373913072230bbb8709a01edc8d558afa0" alt="Google App Engineダッシュボード ADVANCED"
data:image/s3,"s3://crabby-images/72a9b/72a9bd34f0fd27f07bb459d146a913c4cf10c352" alt="Google App Engineダッシュボード設定内容"
data:image/s3,"s3://crabby-images/76920/76920d5cc84d25458022d462e95e0d796c34c6ff" alt="Google App Engineダッシュボード ADVANCED2"
data:image/s3,"s3://crabby-images/800c4/800c4735fe053757b50b71373d481739f2d173e3" alt="Google App Engineダッシュボード モニタリング"
アラート通知する方法
Monitoringで通知チャンネルの設定とポリシーの作成を行い、アラート通知する方法をお伝えします。 まずは通知先となるチャンネル(Eメール) の作成を行います。 GCPコンソールにログインし、Cloud Shellを起動します。 通知先を設定するためのファイルを作成します。$ vim email-channel.json
{
"type": "email",
"displayName": "email alert notifications",
"description": "for app engine 400s error rate notification",
"labels": {
"email_address": "通知先のメールアドレス"
}
}
作成したファイルを使ってEメールの通知チャンネルを追加します。
$ gcloud beta monitoring channels create --channel-content-from-file="email-channel.json"
設定がうまく行われた場合、次のようなメッセージが表示されます。
Created notification channel [projects/<プロジェクトID>/notificationChannels/<識別子>] .
data:image/s3,"s3://crabby-images/93829/9382988bcc38b6e18cb268243d21546a5488081f" alt="Google App Engineダッシュボード アラート通知設定"
$ vim monitoring-policy_4xxErrorRate.json
{
"displayName": "HTTP 400s error rate",
"combiner": "OR",
"conditions": [
{
"displayName": "App Engine HTTP 400s error rate exceeds 30 percent",
"conditionThreshold": {
"filter": "metric.label.response_code>=\"400\" AND
metric.label.response_code<\"500\" AND
metric.type=\"appengine.googleapis.com/http/server/response_count\" AND
project=\"[プロジェクト名]\" AND
resource.type=\"gae_app\"",
"aggregations": [
{
"alignmentPeriod": "300s",
"crossSeriesReducer": "REDUCE_SUM",
"groupByFields": [
"project",
"resource.label.module_id",
"resource.label.version_id"
],
"perSeriesAligner": "ALIGN_DELTA"
}
],
"denominatorFilter": "metric.type=\"appengine.googleapis.com/http/server/response_count\" AND
project=\"[プロジェクト名]\" AND
resource.labels.version_id = \"[バージョン名]\" AND
resource.labels.module_id = \"[サービス名]\" AND
resource.type=\"gae_app\"",
"denominatorAggregations": [
{
"alignmentPeriod": "300s",
"crossSeriesReducer": "REDUCE_SUM",
"groupByFields": [
"project",
"resource.label.module_id",
"resource.label.version_id"
],
"perSeriesAligner": "ALIGN_DELTA"
}
],
"comparison": "COMPARISON_GT",
"thresholdValue": 0.3,
"duration": "0s",
"trigger": {
"count": 1
}
}
}
],
"notificationChannels": "projects/[プロジェクトID]/notificationChannels/[作成した通知チャンネルID]"
}
作成したファイルを使ってアラートポリシーを追加します。
$ gcloud alpha monitoring policies create --policy-from-file="monitoring-policy_4xxErrorRate.json"
設定がうまく行われた場合次のようなメッセージが表示されます。
Created alert policy [projects/<プロジェクトID>/alertPolicies/<識別子>] .
data:image/s3,"s3://crabby-images/96a7a/96a7a4aad2785f31fbb1cc815527cf8188c11931" alt="GAE プロジェクトID"
data:image/s3,"s3://crabby-images/e94a9/e94a9d3735b28d00eeba02974dbdc5e2a053996e" alt="GAE Monitoringコンソールポリシー"
data:image/s3,"s3://crabby-images/cf7c8/cf7c857b738cdd5eaa10dd0d2b827a55c9b802f7" alt="GAE MonitoringコンソールプロジェクトID"
data:image/s3,"s3://crabby-images/b3b4d/b3b4d6ff7536eaf3ac9dc9acb284e095abfbd96d" alt="GAE Monitoringコンソールエラー"
data:image/s3,"s3://crabby-images/99400/99400cad05ebc870ea415f8c9dba87696fb4afa9" alt="GAE Monitoringコンソール画面"
data:image/s3,"s3://crabby-images/c304f/c304feaa0f103feb38140211379b2302f4e1555b" alt="GAE Monitoring アラートメール"
終わりに
今回は、GAEで作成したアプリケーションのクライアントエラーの比率を一例にMonitoringダッシュボードで可視化する方法やMonitoringポリシーでアラート通知する方法をご紹介いたしました。フィルター条件を変更することでサーバーエラー比率の可視化や監視が行うことができます。 また、通知チャンネルはEメールに限らずPub/SubやSMS、Slackなどへの通知も可能です。 実際に検証してみた結果、比率のグラフ化は行えてもアラート通知させるためには設定ファイルを用意しgcloudで設定する必要があるため、設定ファイルで定義した内容を理解し、Aggregationの概念的な理解が求められると、取り掛かりにくいと感じてしまいました。 そのため、公式ドキュメントや噛み砕いて表現してくれる情報をもとに理解を深めながら設定を進めていきました。 参考サイト: App Engine 環境を選択する(Google Cloud公式) App Engine フレキシブル環境で Python アプリを作成する(Google Cloud公式) HTTP エラーの比率(Google Cloud公式) Google Cloud Monitoring の Aggregation を理解する
関連記事
TAG
タグ一覧へ