Table of Contents
Grafana Agent Charmed Operator can be integrated with other charms through the following relations.
provides:
logging-provider:
interface: loki_push_api
requires:
logging:
interface: loki_push_api
Using this relation, Grafana Agent Charmed Operator can receive logs from any charm that supports the loki_push_api
relation interface (Those logs will later be forwarded to Loki using the logging-consumer
relation).
The information exchanged through the loki_push_api
interface can be broken down into two parts:
- Grafana Agent charm provides an endpoint URL to receive logs from charms running Loki clients.
- Grafana Agent charm may also receive alert rules which tell it when to raise alerts. These rules are read from a directory named
loki_alert_rules
, if present at the top level, within the client charm's source (src
) directory.
For instance let's say that we need Zinc Charmed Operator to send logs to Grafana Agent.
To do that we can use one of the "consumer" objects offered by the loki_push_api
lib and follow these steps.
- Specify the relation in the charm's metadata.yaml:
requires:
logging:
interface: loki_push_api
- Obtain the library from charmhub:
charmcraft fetch-lib charms.loki_k8s.v0.loki_push_api
- Import the library and use it in your
src/charm.py
:
from charms.loki_k8s.v0.loki_push_api import LogProxyConsumer
...
class MyOperatorCharm(CharmBase):
def __init__(self, *args):
....
self._logging = LogProxyConsumer(self, relation_name="logging", log_files=logs_files)
- After deploying Zinc charm relate it with
Grafana Agent
:
juju relate grafana-agent-k8s:logging-provider zinc-k8s:logging
Once the relation is established, Zinc charm can start sending logs to Grafana Agent charm.
provides
grafana-dashboard:
interface: grafana_dashboard
requires:
grafana-dashboard:
interface: grafana_dashboard
Over the grafana-dashboard
relation using the grafana-dashboard
interface, this Grafana Agent charm also provides meaningful dashboards (placed in src/grafana_dashboards
) about its metrics to be shown in a Grafana Charm .
In order to add these dashboards to Grafana all that is required is to relate the two charms in the following way:
juju relate \
grafana-agent-k8s:grafana-dashboard \
grafana-k8s:grafana-dashboard
provides:
self-metrics-endpoint:
interface: prometheus_scrape
requires:
metrics-endpoint:
interface: prometheus_scrape
This Grafana Agent charm may forward information about its metrics endpoint and associated alert rules to a Prometheus charm over the self-metrics-endpoint
relation using the prometheus_scrape
interface. In order for these metrics to be aggregated by the remote Prometheus charm all that is required is to relate the two charms as in:
juju relate \
grafana-agent-k8s:self-metrics-endpoint \
prometheus-k8s:metrics-endpoint
requires:
logging-consumer:
interface: loki_push_api
provides:
logging:
interface: loki_push_api
Loki receives logs forwarded by this Grafana Agent charm, aggregates and deduplicates them.
Grafana Agent Charmed Operator relates to Loki over the loki_push_api
interface using the logging-consumer
relation.
juju relate grafana-agent-k8s:logging-consumer loki-k8s
requires:
metrics-endpoint:
interface: prometheus_scrape
provides:
metrics-endpoint:
interface: prometheus_scrape
Charms may forward information about their metrics endpoints and associated alert rules to the Grafana Agent charm over the metrics-endpoint
relation using the prometheus_scrape
interface.
juju relate grafana-agent-k8s:metrics-endpoint zinc-k8s
Charms that seek to provide metrics endpoints and alert rules must do so by using the provided prometheus_scrape
charm library. This library, by implementing the metrics-endpoint
relation, not only ensures that scrape jobs and alert rules are forwarded to Grafana Agent but also that these are updated any time the metrics provider charm is upgraded. For example new alert rules may be added or old ones removed by updating and releasing a new version of the metrics provider charm. While it is safe to update alert rules as desired, care must be taken when updating scrape job specifications as this has the potential to break the continuity of the scraped metrics time series. In particular changing the following keys in the scrape job can break time series continuity
job_name
relabel_configs
metrics_relabel_configs
- Any label set by
static_configs
Evaluation of alert rules forwarded through the prometheus_scrape
interface are automatically limited to the charmed application that provided these rules. This ensures that alert rule evaluation is scoped down to the charm providing the rules.
requires:
send-remote-write:
interface: prometheus_remote_write
provides:
receive-remote-write:
interface: prometheus_remote_write
Grafana Agent may forward client charms metrics and associated alert rules (that are received using the metrics-endpoint
relation) to Prometheus using the prometheus_remote_write
interface.
To do that you have to relate Grafana Agent with Prometheus:
juju relate grafana-agent-k8s:send-remote-write prometheus-k8s
Once these relations are established, you can check it by running:
juju status --relations
Model Controller Cloud/Region Version SLA Timestamp
docs charm-dev microk8s/localhost 2.9.32 unsupported 17:55:18-03:00
App Version Status Scale Charm Channel Rev Address Exposed Message
grafana active 1 grafana-k8s edge 40 10.152.183.168 no
grafana-agent-k8s active 1 grafana-agent-k8s edge 11 10.152.183.123 no
loki-k8s waiting 1 loki-k8s edge 41 10.152.183.43 no
prometheus-k8s 2.33.5 active 1 prometheus-k8s candidate 55 10.152.183.128 no
zinc-k8s 0.2.8 active 1 zinc-k8s stable 26 10.152.183.247 no
Unit Workload Agent Address Ports Message
grafana-agent-k8s/0* active idle 10.1.157.120
grafana/0* active idle 10.1.157.88
loki-k8s/0 active idle 10.1.157.86
prometheus-k8s/0* active idle 10.1.157.89
zinc-k8s/0* active idle 10.1.157.79
Relation provider Requirer Interface Type Message
grafana-agent-k8s:grafana-dashboard grafana:grafana-dashboard grafana_dashboard regular
grafana-agent-k8s:logging-provider zinc-k8s:logging loki_push_api regular
grafana-agent-k8s:self-metrics-endpoint prometheus-k8s:metrics-endpoint prometheus_scrape regular
grafana:grafana grafana:grafana grafana_peers peer
loki-k8s:logging grafana-agent-k8s:logging-consumer loki_push_api regular
prometheus-k8s:prometheus-peers prometheus-k8s:prometheus-peers prometheus_peers peer
prometheus-k8s:receive-remote-write grafana-agent-k8s:send-remote-write prometheus_remote_write regular
zinc-k8s:metrics-endpoint grafana-agent-k8s:metrics-endpoint prometheus_scrape regular
flowchart LR
subgraph COS Lite
prometheus
loki
grafana
end
subgraph K8s cluster
prometheus --- |remote_write| grafana-agent
loki --- |loki_push_api| grafana-agent
grafana --- |grafana_dashboard| grafana-agent
grafana-agent --- |prometheus_scrape| prometheus-scrape-config
grafana-agent --- |prometheus_scrape| C1[Sidecar Charm 1]
C1 --- |loki_push_api| grafana-agent
prometheus-scrape-config --- |prometheus_scrape| C2[Sidecar Charm 2]
C2 --- |loki_push_api| grafana-agent
end
click prometheus https://github.com/canonical/prometheus-k8s-operator/
click loki https://github.com/canonical/loki-k8s-operator/
click prometheus-scrape-config https://github.com/canonical/prometheus-scrape-config-k8s-operator/