This page guides you through the following steps:
- Install the OpenTelemetry packages.
- Configure your application to export spans to Cloud Trace.
- Configure your platform.
For release information, see the following:
For OpenTelemetry reference content, see the following:
For the latest details about OpenTelemetry for C++, along with additional documentation and examples, see OpenTelemetry.
Before you begin
Enable the Cloud Trace API.
Roles required to enable APIs
          To enable APIs, you need the Service Usage Admin IAM
          role (roles/serviceusage.serviceUsageAdmin), which
          contains the serviceusage.services.enable permission. Learn how to grant
          roles.
        
Install the OpenTelemetry packages
- Set up a C++ development environment.
- Install the Google Cloud C++ OpenTelemetry exporter library. For installation information, see the OpenTelemetry quickstart.
Configure the export of spans to Cloud Trace
To configure the export of trace data, call the
google::cloud::otel::ConfigureBasicTracing(...) method in your main()
method:
The field project_id is the Google Cloud project where you want to store the
traces.
The method ConfigureBasicTracing(...) instantiates a
TracerProvider object that implements
a Cloud Trace exporter. If the object returned by the call to
ConfigureBasicTracing(...) goes out of scope, then the previous
TracerProvider object is reinstated, when one exists.
Configure sample rate
Applications might generate a large volume of trace data. The following sample illustrates how to configure the sampling rate:
Export to Cloud Trace with a custom TracerProvider
You might have use cases that require a custom TracerProvider object. For
example, if you want to use multiple exporters at the same time, you need
to make a custom TracerProvider object. In these cases, you can use the
Cloud Trace exporter directly:
Instrument your own application
For information about how to configure your application to capture trace spans, see OpenTelemetry Tracing. This page describes how to do all of the following:
- Create a span
- Create nested spans
- Set span attributes
- Create spans with events
- Create spans with links
Sample application
For a sample application, see the quickstart.
Configure your platform
You can use Cloud Trace on Google Cloud and other platforms.
Running on Google Cloud
When your application is running on Google Cloud, you don't need to provide authentication credentials in the form of a service account to the client library. However, you do need to ensure that your Google Cloud platform has the Cloud Trace API access scope enabled.
For a list of supported Google Cloud environments, see Environment support.
For the following configurations, the default access-scope settings enable the Cloud Trace API:
- App Engine flexible environment
- App Engine standard environment 
- Google Kubernetes Engine (GKE) 
- Compute Engine 
- Cloud Run 
If you use custom access scopes, then you must ensure that Cloud Trace API access scope is enabled:
- For information about how to configure the access scopes for your environment by using the Google Cloud console, see Configuring your Google Cloud project. 
- For - gcloudusers, specify access scopes using the- --scopesflag and include the- trace.appendCloud Trace API access scope. For example, to create a GKE cluster with only the Cloud Trace API enabled, do the following:- gcloud container clusters create example-cluster-name --scopes=https://www.googleapis.com/auth/trace.append 
Running locally and elsewhere
If your application is running outside of Google Cloud, then you must provide authentication credentials in the form of a service account to the client library. The service account must contain the Cloud Trace agent role. For instructions, see Creating a service account.
Google Cloud client libraries use Application Default Credentials (ADC) to find your application's credentials.
You can provide these credentials in one of three ways:
- Run - gcloud auth application-default login
- Place the service account in a default path for your operating system. The following lists the default paths for Windows and Linux: - Windows: - %APPDATA%/gcloud/application_default_credentials.json
- Linux: - $HOME/.config/gcloud/application_default_credentials.json
 
- Set the - GOOGLE_APPLICATION_CREDENTIALSenvironment variable to the path to your service account:
Linux/macOS
export GOOGLE_APPLICATION_CREDENTIALS=path-to-your-service-accounts-private-key
Windows
set GOOGLE_APPLICATION_CREDENTIALS=path-to-your-service-accounts-private-key
PowerShell:
$env:GOOGLE_APPLICATION_CREDENTIALS="path-to-your-service-accounts-private-key"
View traces
In the Google Cloud console, go to the Trace explorer page:
You can also find this page by using the search bar.
Troubleshooting
For information on troubleshooting issues with Cloud Trace, go to the Troubleshooting page.
To debug the C++ Cloud Trace exporter, see the Troubleshooting section of the reference documentation.
Resources
- https://opentelemetry.io/
- open-telemetry/opentelemetry-cpp GitHub repository
- google-cloud-cpp OpenTelemetry Exporters Library GitHub repository.