podlabelmetrics.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package metrics
  2. import (
  3. "github.com/opencost/opencost/core/pkg/clustercache"
  4. "github.com/opencost/opencost/core/pkg/util/promutil"
  5. "github.com/prometheus/client_golang/prometheus"
  6. )
  7. //--------------------------------------------------------------------------
  8. // KubePodLabelsCollector
  9. //--------------------------------------------------------------------------
  10. // KubePodLabelsCollector is a prometheus collector that emits pod labels only
  11. type KubePodLabelsCollector struct {
  12. KubeClusterCache clustercache.ClusterCache
  13. metricsConfig MetricsConfig
  14. labelsWhitelist map[string]bool
  15. }
  16. func (kpmc *KubePodLabelsCollector) SetLabelsWhiteList() {
  17. kpmc.labelsWhitelist = make(map[string]bool)
  18. for k, v := range kpmc.metricsConfig.LabelsWhitelist {
  19. kpmc.labelsWhitelist[k] = v
  20. }
  21. }
  22. // Describe sends the super-set of all possible descriptors of pod labels only
  23. // collected by this Collector.
  24. func (kpmc KubePodLabelsCollector) Describe(ch chan<- *prometheus.Desc) {
  25. disabledMetrics := kpmc.metricsConfig.GetDisabledMetricsMap()
  26. if _, disabled := disabledMetrics["kube_pod_labels"]; !disabled {
  27. ch <- prometheus.NewDesc("kube_pod_labels", "All labels for each pod prefixed with label_", []string{}, nil)
  28. }
  29. if _, disabled := disabledMetrics["kube_pod_owner"]; !disabled {
  30. ch <- prometheus.NewDesc("kube_pod_owner", "Information about the Pod's owner", []string{}, nil)
  31. }
  32. }
  33. func (kpmc *KubePodLabelsCollector) UpdateControllerSelectorsCache() {
  34. for _, r := range kpmc.KubeClusterCache.GetAllReplicaSets() {
  35. for k := range r.SpecSelector.MatchLabels {
  36. kpmc.labelsWhitelist[k] = true
  37. }
  38. for _, v := range r.SpecSelector.MatchExpressions {
  39. kpmc.labelsWhitelist[v.Key] = true
  40. }
  41. }
  42. for _, ss := range kpmc.KubeClusterCache.GetAllStatefulSets() {
  43. for k := range ss.SpecSelector.MatchLabels {
  44. kpmc.labelsWhitelist[k] = true
  45. }
  46. for _, v := range ss.SpecSelector.MatchExpressions {
  47. kpmc.labelsWhitelist[v.Key] = true
  48. }
  49. }
  50. }
  51. func (kpmc *KubePodLabelsCollector) UpdateServiceLabels() {
  52. for _, service := range kpmc.KubeClusterCache.GetAllServices() {
  53. // Just unroll the selector and keep all labels whose keys could match a service selector
  54. for k := range service.SpecSelector {
  55. kpmc.labelsWhitelist[k] = true
  56. }
  57. }
  58. }
  59. func (kpmc *KubePodLabelsCollector) UpdateWhitelist() {
  60. kpmc.SetLabelsWhiteList()
  61. kpmc.UpdateControllerSelectorsCache()
  62. kpmc.UpdateServiceLabels()
  63. }
  64. // Collect is called by the Prometheus registry when collecting metrics.
  65. func (kpmc KubePodLabelsCollector) Collect(ch chan<- prometheus.Metric) {
  66. pods := kpmc.KubeClusterCache.GetAllPods()
  67. disabledMetrics := kpmc.metricsConfig.GetDisabledMetricsMap()
  68. for _, pod := range pods {
  69. podName := pod.Name
  70. podNS := pod.Namespace
  71. podUID := string(pod.UID)
  72. // Pod Labels
  73. if _, disabled := disabledMetrics["kube_pod_labels"]; !disabled {
  74. podLabels := pod.Labels
  75. if kpmc.metricsConfig.UseLabelsWhitelist {
  76. kpmc.UpdateWhitelist()
  77. for lname := range pod.Labels {
  78. if _, ok := kpmc.labelsWhitelist[lname]; !ok {
  79. delete(podLabels, lname)
  80. }
  81. }
  82. }
  83. labelNames, labelValues := promutil.KubePrependQualifierToLabels(promutil.SanitizeLabels(podLabels), "label_")
  84. ch <- newKubePodLabelsMetric("kube_pod_labels", podNS, podName, podUID, labelNames, labelValues)
  85. }
  86. // Owner References
  87. if _, disabled := disabledMetrics["kube_pod_owner"]; !disabled {
  88. for _, owner := range pod.OwnerReferences {
  89. ch <- newKubePodOwnerMetric("kube_pod_owner", podNS, podName, podUID, owner.Name, owner.Kind, owner.Controller != nil)
  90. }
  91. }
  92. }
  93. }