OpenTelemetry Google Cloud Monitoring Exporter
OpenTelemetry Google Cloud Monitoring Exporter allows the user to send collected metrics to Google Cloud.
To get started with instrumentation in Google Cloud, see Generate traces and metrics with
Go.
To learn more about instrumentation and observability, including opinionated recommendations
for Google Cloud Observability, visit Instrumentation and
observability.
Google Cloud Monitoring provides visibility into the performance, uptime, and overall health of cloud-powered applications. It collects metrics, events, and metadata from Google Cloud, Amazon Web Services, hosted uptime probes, application instrumentation, and a variety of common application components including Cassandra, Nginx, Apache Web Server, Elasticsearch, and many others. Operations ingests that data and generates insights via dashboards, charts, and alerts. Cloud Monitoring alerting helps you collaborate by integrating with Slack, PagerDuty, and more.
Setup
Google Cloud Monitoring is a managed service provided by Google Cloud Platform. Google Cloud Monitoring requires to set up "Workspace" in advance. The guide to create a new Workspace is available on the official document.
Authentication
The Google Cloud Monitoring exporter depends upon google.FindDefaultCredentials
, so the service account is automatically detected by default, but also the custom credential file (so called service_account_key.json
) can be detected with specific conditions. Quoting from the document of google.FindDefaultCredentials
:
- A JSON file whose path is specified by the
GOOGLE_APPLICATION_CREDENTIALS
environment variable. - A JSON file in a location known to the gcloud command-line tool. On Windows, this is
%APPDATA%/gcloud/application_default_credentials.json
. On other systems, $HOME/.config/gcloud/application_default_credentials.json
.
When running code locally, you may need to specify a Google Project ID in addition to GOOGLE_APPLICATION_CREDENTIALS
. This is best done using an environment variable (e.g. GOOGLE_CLOUD_PROJECT
) and the metric.WithProjectID
method, e.g.:
projectID := os.Getenv("GOOGLE_CLOUD_PROJECT")
opts := []mexporter.Option{
mexporter.WithProjectID(projectID),
}
Useful links