-
Notifications
You must be signed in to change notification settings - Fork 76
Go exporter should detect GKE resource labels automatically #261
Comments
@DukeNg can you please share more details about your use case? Note that this exporter is being used by OpenTelemetry Collector to export to Google Cloud Monitoring/Trace: https://github.com/open-telemetry/opentelemetry-collector-contrib/tree/master/exporter/stackdriverexporter But OpenTelemetry SDK has an independent exporter implementation: https://github.com/GoogleCloudPlatform/opentelemetry-operations-go Ideally, auto-detection mechanism should not be specific to vendor exporters, i.e. there should be a generic mechanism in SDK / Collector that would work for any exporter. |
So far I've tested with Opencensus. I followed the example in the OC doc to instrument both traces and stats and to make OC automatically append Resource labels (particularly GKE labels) to Trace's spans. I encountered two issues: 1. OC doesn't send resource labels to Cloud Trace: 2. The GKE resource labels detected were not complete
Either way, I think that we should come up with a way to detect all GKE variables.
What do you think? |
@nilebox friendly ping. |
@rghetia Do you think that it would be an easy fix to have Kubernetes provide all its fields through metadata attributes or inject all the variables in the exporter? or are we blocked on this? |
It can be injected using downward API, see
Is this environment variable missing? |
So what you're saying is that the users have to specify their MY_POD_NAMESPACE in their yaml files before deploying in order to get the NAMESPACE env variable? This is an option worth trying out for sure. On the other hand, if they don't set NAMESPACE we cam assume that value is "default" right? By cluster name I was referring to k8s_container. I think this is different from GCE CLUSTER_NAME? I've never seen GCE CLUSTER_NAME BEING listed on the resource labels page for OC. Ultimately, cluster name is only missing on Kubernetes Operator but it's working on gke.Detect() so if we can identify NAME_SPACE in gke.Detect() then we can just go with that approach. |
They should be setting
I don't think so. If they don't set |
@DukeNg - just wanted to clarify what your plan is for this issue - did you want us to assign it to you? This is a bit confusing at the moment as there's two different places in Open Census where resource detection can occur:
If I understand correctly, in both cases these methods read from environment variables (with the former taking precedence if used). No. 1 also reads the cluster name from instance metadata (which should be the same?). The environment variables can either be manually set or set via the OC operator. I'm not sure why cluster name is coming through as empty for you though; looks like this needs to be manually passed in to the operator - are you doing that correctly? Note for OpenTelemetry, I currently have an OTEP open to add resource detection to the spec. Once that's finalised it would be good to get this included in the SDK directly rather than as part of the OpenTelemetry Cloud Ops exporter (to avoid confusion like there is with OpenCensus). See open-telemetry/oteps#111 - is this something that will be a blocker for you if not implemented immediately? Also note there are some minor differences with resources in OpenTelemetry compared to OpenCensus - notably "type" is now just another attribute. Having said that, the issues you bring up here around GKE detection will also need to be solved in Otel regardless. We will also presumably need to port the OpenCensus operator to OpenTelemetry at some point - is that something you're interested in taking on as part of this work? |
Right now the Go Stackdriver exporter does not send GKE resource labels to Cloud Trace.
There are a few ways we can get resource labels:
Solution:
Automatically detect GKE resource labels and attach them to the span attributes.
Related issue: census-ecosystem/kubernetes-operator#14
The text was updated successfully, but these errors were encountered: