Observability and debugging with Service Directory
Cloud Service Mesh's integration with Service Directory introduces new complexities in debugging. Within your business, service consumers and service producers might belong to different teams or organizations. To help you debug such issues, Cloud Service Mesh integrates with Cloud Logging and Cloud Monitoring.
For example:
- You have a checkoutservice that uses Cloud Service Mesh for application networking.
- There's a paymentservice in Service Directory that a different team (the service producer) owns and maintains.
- You want to call on the paymentservice from thecheckoutservice so you create a new backend service in Cloud Service Mesh. This backend service attaches to thepaymentservice using Service Directory for service discovery.
In this model, the service producer might want to delete or modify the paymentservice that is hosted in Service Directory. Because they own
the payment service, they are permitted to make such changes. But if the
payment service is deleted, service discovery is broken.
Logging
When Cloud Service Mesh resolves a backend service that is attached to a Service Directory service, it gets a list of endpoints from Service Directory. If the service has been deleted from Service Directory, Cloud Service Mesh doesn't get any endpoints. In such a case, a log entry is added to Logging. The log entry includes the following information:
- The backend service name
- The Service Directory name
- A message: Service Directory returned 0 endpoints for this service.
This information helps you debug issues. You can also set up alerts to be proactively notified.
Monitoring
Similar to the logging case, Cloud Service Mesh integrates with Monitoring to generate metrics. Cloud Service Mesh adds the following metrics to Monitoring for each backend service:
- The backend service name
- The number of endpoints associated with this backend service that are shared with Cloud Service Mesh's clients
Cloud Service Mesh clients are not able to send traffic to backend services that don't have endpoints.
Google Cloud console
If a Service Directory service is deleted and an attachment to
that service exists in the Cloud Service Mesh backend service, the
Google Cloud console displays a warning: The attached
Service Directory service could not be found.
What's next
- Learn about integrating Cloud Service Mesh with Service Directory.
- Learn how to set up the integration.
- Learn about Service Directory observability.