Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create Flow components to consume Kubernetes monitoring CRDs #2466

Closed
5 tasks done
rfratto opened this issue Nov 2, 2022 · 1 comment
Closed
5 tasks done

Create Flow components to consume Kubernetes monitoring CRDs #2466

rfratto opened this issue Nov 2, 2022 · 1 comment
Assignees
Labels
flow Related to Grafana Agent Flow frozen-due-to-age Locked due to a period of inactivity. Please open new issues or PRs if more discussion is needed. proposal Proposal or RFC proposal-accepted Proposal has been accepted.
Milestone

Comments

@rfratto
Copy link
Member

rfratto commented Nov 2, 2022

Today, Grafana Agent Operator must be used if you want to consume ServiceMonitors, PodMonitors, Probes, and PodLogs for collecting telemetry data. I would like to see support for consuming those CRDs added to Grafana Agent itself in the form of Flow components.

Each Flow component will discover a specific CRD, and use the definition of that CRD to collect telemetry data. For example, a prometheus.kubernetes.pod_monitors component collect metrics from pods specified by the set of discovered PodMonitors. Collected metrics are then forwarded to a Prometheus-compatible component, usually prometheus.remote_write.

NOTE: A component to consume PodLogs depends on Promtail components being added to Grafana Agent Flow first.

Adding these components allows Grafana Agent Flow to be a suitable alternative to Grafana Agent Operator, where users would have more power to configure everything Grafana Agent Flow supports instead of being limited to what Grafana Agent Operator happens to expose.

Example pipeline

An example Flow pipeline which uses these components may look like the following:

prometheus.kubernetes.pod_monitors "default" {
  // Look for PodMonitors with a label "application: my-application" in the 
  // default namespace.
  selector {
    labels = {
      application = "my-application"
    } 

    namespace {
      names = ["default"]
    }
  }

  // Send metrics collect from PodMonitor applications to the 
  // specified prometheus.remote_write component. 
  forward_to = [prometheus.remote_write.default.receiver]
}

prometheus.remote_write "default" {
  client {
    url = env("PROMETHEUS_REMOTE_WRITE_URL") 
  }
}

This just serves as an example; the arguments that each of the new components will support is to be determined, though they will likely need to be similar to how you configure a MetricsInstance or LogsInstance with Grafana Agent Operator.

Component names

I haven't been able to come up with a great name for these components which best describe what they do. For now, my preliminary suggestion is to use PROJECT.kubernetes.PLURAL_CRD_NAME for each component, meaning the following components are added:

  • prometheus.kubernetes.service_monitors for collecting metrics based on discovered ServiceMonitors
  • prometheus.kubernetes.pod_monitors for collecting metrics based on discovered PodMonitors
  • prometheus.kubernetes.probes for collecting metrics based on discovered Probes
  • loki.kubernetes.pod_logs for collecting logs based on discovered PodLogs.

Benefits

Being able to send metrics from SerivceMonitors, PodMonitors, Probes to any Prometheus-compatible Flow component may be particularly interesting to users, such as being able to convert metrics to OTLP and write them to Kafka:

prometheus.kubernetes.pod_monitors "default" {
  ...

  forward_to = [otelcol.receiver.prometheus.default] 
}

otelcol.receiver.prometheus "default" {
  output {
    metrics = [otelcol.exporter.kafka.default.input] 
  }
} 

// NOTE: this component isn't implemented yet, and just serves 
// as an example for what this approach is capable of doing. 
otelcol.exporter.kafka "default" {
  ... 
}

Tasks

Preview Give feedback
  1. flow frozen-due-to-age
    captncraig
  2. flow frozen-due-to-age
  3. flow frozen-due-to-age
    captncraig
  4. flow frozen-due-to-age
    captncraig
@gloriasc
Copy link

@captncraig Any updates on the above mentioned tasklist?

@marctc marctc added this to the v0.33.0 milestone Mar 7, 2023
@marctc marctc removed this from the v0.33.0 milestone Apr 4, 2023
@captncraig captncraig added this to the v0.34.0 milestone Apr 20, 2023
@mattdurham mattdurham added the proposal-accepted Proposal has been accepted. label May 17, 2023
@jcreixell jcreixell moved this from Todo to In Progress in Grafana Agent (Public) May 30, 2023
@marctc marctc modified the milestones: v0.34.0, v0.35.0 Jun 2, 2023
@gloriasc gloriasc moved this from In Progress to Blocked in Grafana Agent (Public) Jun 13, 2023
@captncraig captncraig moved this from Blocked to Done in Grafana Agent (Public) Jul 11, 2023
@github-actions github-actions bot added the frozen-due-to-age Locked due to a period of inactivity. Please open new issues or PRs if more discussion is needed. label Feb 21, 2024
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Feb 21, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
flow Related to Grafana Agent Flow frozen-due-to-age Locked due to a period of inactivity. Please open new issues or PRs if more discussion is needed. proposal Proposal or RFC proposal-accepted Proposal has been accepted.
Projects
No open projects
Development

No branches or pull requests

5 participants