Control plane logging and monitoring
This document demonstrates how to use Cloud Logging and Cloud Monitoring to view logs and metrics for the Cloud Service Mesh control plane.
Using a service mesh gives you the ability to observe traffic to and from services, which allows for richer monitoring and debugging without code changes in the service itself. Log entries can provide important information for troubleshooting your service mesh, including records of successful connections and disconnections, error reports for misconfigured clients, and alerts about API resource conflicts.
Use cases
The following are three use cases for control plane logging and monitoring:
- Cloud Logging for Cloud Service Mesh control plane: You can securely store, search, analyze, and set alerts on all of your Cloud Service Mesh logging data and events using all the built-in features of Logging. Cloud Service Mesh exports logs to Logging when an Envoy or gRPC client connects or disconnects, as well as when it detects configuration issues.
- Cloud Monitoring for Cloud Service Mesh control plane: Cloud Service Mesh exports a key metric indicating the number of clients connected to the Cloud Service Mesh control plane to Monitoring. You can set up a dashboard in Monitoring and visualize this metric in real time to monitor the health of the mesh as clients connect and disconnect. This also lets you set up an SLO for your mesh.
- Troubleshoot issues immediately: Cloud Service Mesh exports telemetry to Logging and Monitoring by default. No additional setup is necessary to configure logging and monitoring, enabling you to troubleshoot issues at any time, including when you are setting up the mesh for the first time.
View logs
To view Cloud Service Mesh logs, use the Logs Explorer. The following section presents an example query to view Cloud Service Mesh logs, but you can use the previous link to create your own query.
- In the Google Cloud console, go to the Logs Explorer page. 
- In the Resource list,
- If you use the service routing APIs, select Gateway ScopeorMesh.
- If you use the older APIs, select GCE Network.
 
- If you use the service routing APIs, select 
- In the Log name list, select trafficdirector.googleapis.com/events.
- Click Run query.
Cloud Service Mesh log entry fields
| Field | Description | 
|---|---|
| node_id | ID of the xDS-client node, as provided by the xDS-client. | 
| client_type | Type of xDS-client connected to Cloud Service Mesh. Possible values: 
 | 
| node_ip | IP address of the node as provided by the client. | 
| api_version | The xDS API version used by xDS clients to connect to Cloud Service Mesh.
         Possible values are V2andV3. | 
| description | Text description of the event with additional details. | 
Example log entries
| Example of the log entry | Description | 
|---|---|
| "Cloud Service Mesh could not find any configuration for xDS client." | This log is generated when the xDS client is rejected by Cloud Service Mesh because no configuration exists. This might be due to the incomplete setup of Cloud Service Mesh-relevant API resources. | 
| "Client has successfully connected." | This type of log message is generated every time a client connects successfully to Cloud Service Mesh. | 
| "Client has successfully disconnected." | This type of log message is generated every time an established client is disconnected from Cloud Service Mesh. | 
| "TRAFFICDIRECTOR_INTERCEPTION_PORT metadata variable is not set. Routing configuration for the interception listener exists, but will be ignored." | This type of log message is generated when Cloud Service Mesh resources
         are configured correctly, but the TRAFFICDIRECTOR_INTERCEPTION_PORTvariable is not set in the xDS-client node metadata, so this
         configuration can not be added to the client. | 
| "Interception listener is built on the given port 15001, but routing configuration does not exist for it." | This type of log message is generated when the TRAFFICDIRECTOR_INTERCEPTION_PORTvariable is set in the xDS-client
         node metadata, but no resources were configured for Cloud Service Mesh to
         generate a complete xDS response. | 
| "Sending ADS response from Cloud Service Mesh failed. Last discovery request from the node had an incorrect version and/or nonce." | This type of log message is generated when Cloud Service Mesh could not process xDS response correctly due to corrupted communication from the xDS client. This message indicates an implementation error in the client. We recommend checking the client's logs. | 
| "Client sending cross-region traffic to backend service backend_service_id. Source region:source_regionDestination region(s):destination_region1, destination_region2" | This type of log message is generated when a client reports to Cloud Service Mesh that it sent cross-region traffic from a source region to one or more destination regions. | 
View metrics
Cloud Service Mesh exports three metrics to Cloud Monitoring: xDS API Connected Streams, Request count, and Request count by zone. xDS API Connected Streams indicates the number of clients that are connected to your control plane; Request count indicates the number of requests sent to a backend service, grouped by source region, destination region, and request status. Request count by zone indicates the number of requests sent to a backend service, grouped by source zone, destination zone, and request status. To view these metrics, use the Metrics Explorer.
To view Cloud Service Mesh metrics, do the following:
- In the Google Cloud console, go to the Metrics Explorer page. 
- In the Resource type list, select a resource.
- If you use the service routing APIs, select Gateway ScopeorMesh.
- If you use the older APIs, select Network.
 
- If you use the service routing APIs, select 
- In the Metric list, select connected_clients.
- Return to the Resource type list, and then select Compute Engine Backend Service.
- In the Metric list, select either Request countorRequest count by zone.
Alternatively, you can use a query to view the cross-region request count:
- Select MQL.
- In the field, enter the following example query:
fetch gce_backend_service | metric 'trafficdirector.googleapis.com/xds/server/request_count' | filter ( ne(metric.source_region, metric.destination_region)) | align rate(1m) | every 1m | group_by [metric.source_region, metric.destination_region, resource.backend_service_id], [value_request_count_aggregate: aggregate(value.request_count)] 
- Click Run query.
Set up logs-based metrics and alerts
The following steps require that you set up logs-based metrics. For more information about setting up logs-based metrics, see the overview.
You can configure alerts to notify you when user-specified messages appear in your included logs. These alerts can notify the operator when something unexpected occurs. For example, if a change in Cloud Service Mesh configuration results in API resource conflicts, you can receive an alert on the error message. To set up alerts on your log-based metrics, see Configure charts and alerts.