Go アプリケーションから Error Reporting にエラーレポートを送信するには、Go 用 Error Reporting パッケージを使用します。次の場合は、Go 用 Error Reporting パッケージを使用してエラーグループを作成します。
- ログバケットには顧客管理の暗号鍵(CMEK)が含まれています。
- ログバケットが
global
リージョンにない - カスタム エラーイベントを報告する。
Error Reporting は、App Engine、Compute Engine、Google Kubernetes Engine などの一部の Google Cloud サービスに統合されています。Error Reporting は、こうしたサービスで実行されるアプリケーションによって Cloud Logging に記録されたエラーを表示します。詳細については、このページの Google Cloud での実行をご覧ください。
Logging を使用して、エラーデータを Error Reporting に送信することもできます。データ形式の要件については、Logging のエラー メッセージの形式設定をご覧ください。
準備
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
Google Cloud Console の [プロジェクト セレクタ] ページで、Google Cloud プロジェクトを選択または作成します。
-
Enable the Error Reporting API .
-
Google Cloud Console の [プロジェクト セレクタ] ページで、Google Cloud プロジェクトを選択または作成します。
-
Enable the Error Reporting API .
クライアント ライブラリをインストールする
Go 用 Error Reporting パッケージを使用すると、ほぼすべての場所で動作している Go アプリケーションから報告されるエラーをモニタリングして表示できます。
-
go get
を使用してパッケージをインストールします。go get cloud.google.com/go/errorreporting
インストールの詳細については、Go 用 Error Reporting パッケージのドキュメントをご覧ください。Issue Tracker を使用して問題を報告することもできます。
クライアント ライブラリを設定する
Go 用 Error Reporting パッケージの動作をカスタマイズできます。godoc をご覧ください。
Google Cloud でアプリを実行する
projects.events.report
を使用してエラーグループを作成するには、サービス アカウントに Error Reporting 書き込みロール(roles/errorreporting.writer
)が必要です。
一部の Google Cloud サービスでは、Error Reporting 書き込みロール(roles/errorreporting.writer
)が適切なサービス アカウントに自動的に付与されます。ただし、一部のサービスに適したサービス アカウントにこのロールを付与する必要があります。
App Engine フレキシブル環境
App Engine では、デフォルトのサービス アカウントに Error Reporting 書き込みロール(roles/errorreporting.writer
)が自動的に付与されます。
Go 用 Error Reporting パッケージは、明示的に認証情報を提示しなくても使用できます。
App Engine のフレキシブル環境のアプリケーションでは、Error Reporting が自動的に有効になります。特別な設定は必要ありません。Google Kubernetes Engine
Google Kubernetes Engine で Error Reporting を使用するには、次の操作を行います。
コンテナが使用するサービス アカウントに、Error Reporting 書き込みロール(
roles/errorreporting.writer
)が付与されていることを確認します。Compute Engine のデフォルトのサービス アカウントまたはカスタム サービス アカウントを使用できます。
ロールの付与については、プロジェクト、フォルダ、組織へのアクセスを管理するをご覧ください。
クラスタを作成し、そのクラスタに
cloud-platform
アクセス スコープを付与します。たとえば、次の create コマンドでは、
cloud-platform
アクセス スコープとサービス アカウントを指定します。gcloud container clusters create CLUSTER_NAME --service-account SERVICE_ACCT_NAME --scopes=cloud-platform
Compute Engine
Compute Engine の VM インスタンスで Error Reporting を使用するには、次のようにします。
VM インスタンスが使用するサービス アカウントに、Error Reporting 書き込みロール(
roles/errorreporting.writer
)が付与されていることを確認します。Compute Engine のデフォルトのサービス アカウントまたはカスタム サービス アカウントを使用できます。
ロールの付与については、プロジェクト、フォルダ、組織へのアクセスを管理するをご覧ください。
-
Google Cloud コンソールで、[VM インスタンス] ページに移動します。
検索バーを使用してこのページを検索する場合は、小見出しが [Compute Engine] である結果を選択します。
cloud-platform
アクセス スコープを適用する VM インスタンスを選択します。[停止]、[編集] の順にクリックします。
[ID と API へのアクセス] セクションで、Error Reporting 書き込みロール(
roles/errorreporting.writer
)を持つサービス アカウントを選択します。[アクセス スコープ] セクションで、[すべての Cloud API に完全アクセス権を許可] を選択して、変更内容を保存します。
[開始 / 再開] をクリックします。
例
次のサンプルは、Go クライアント ライブラリを使用して、カスタム エラーイベントを報告する方法を示しています。
パニックやエラーの報告方法のその他の例については、godoc をご覧ください。
ローカル開発環境でアプリを実行する
自分のワークステーションでライブラリを実行するなど、ローカル開発環境で Go 用 Error Reporting パッケージを使用するには、ローカル アプリケーションのデフォルト認証情報を使用して Go 用 Error Reporting パッケージを指定する必要があります。 詳細については、Error Reporting に対する認証をご覧ください。
このページの Go サンプルをローカル開発環境から使用するには、gcloud CLI をインストールして初期化し、自身のユーザー認証情報を使用してアプリケーションのデフォルト認証情報を設定してください。
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create local authentication credentials for your user account:
gcloud auth application-default login
詳細については、 ローカル開発環境の認証の設定 をご覧ください。
projects.events.report
メソッドは API キーもサポートしています。
認証に API キーを使用する場合、ローカルのアプリケーションのデフォルト認証情報ファイルを設定する必要はありません。詳細については、Google Cloud の認証に関するドキュメントの API キーを作成するをご覧ください。
エラーレポートの表示
Google Cloud コンソールで、[Error Reporting] ページに移動します。
このページは、検索バーを使用しても確認できます。
詳細については、エラーの表示をご覧ください。