Skip to content

Commit

Permalink
Added Mimir / Loki Rules Sync Support
Browse files Browse the repository at this point in the history
Resolves #564
  • Loading branch information
bentonam authored and petewall committed Aug 16, 2024
1 parent 65bef9a commit e169562
Show file tree
Hide file tree
Showing 45 changed files with 55,868 additions and 4 deletions.
7 changes: 5 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ METRICS_CONFIG_FILES = $(subst values.yaml,metrics.alloy,$(INPUT_FILES))
EVENTS_CONFIG_FILES = $(subst values.yaml,events.alloy,$(INPUT_FILES))
LOGS_CONFIG_FILES = $(subst values.yaml,logs.alloy,$(INPUT_FILES))
PROFILES_CONFIG_FILES = $(subst values.yaml,profiles.alloy,$(INPUT_FILES))
RULES_CONFIG_FILES = $(subst values.yaml,rules.alloy,$(INPUT_FILES))

CT_CONFIGFILE ?= .github/configs/ct.yaml
LINT_CONFIGFILE ?= .github/configs/lintconf.yaml
Expand Down Expand Up @@ -39,7 +40,7 @@ lint-chart:
ct lint --debug --config "$(CT_CONFIGFILE)" --lint-conf "$(LINT_CONFIGFILE)" --check-version-increment=false

lint-config lint-configs lint-alloy:
@./scripts/lint-alloy.sh $(METRICS_CONFIG_FILES) $(EVENTS_CONFIG_FILES) $(LOGS_CONFIG_FILES) --public-preview $(PROFILES_CONFIG_FILES)
@./scripts/lint-alloy.sh $(METRICS_CONFIG_FILES) $(EVENTS_CONFIG_FILES) $(LOGS_CONFIG_FILES) $(RULES_CONFIG_FILES) --public-preview $(PROFILES_CONFIG_FILES)

# Shell Linting
lint-sh lint-shell:
Expand Down Expand Up @@ -98,7 +99,9 @@ test: scripts/test-runner.sh lint-chart lint-config
%/profiles.alloy: %/output.yaml
yq -r "select(.metadata.name==\"k8smon-alloy-profiles\") | .data[\"config.alloy\"] | select( . != null )" $< > $@

%/rules.alloy: %/output.yaml
yq -r "select(.metadata.name==\"k8smon-alloy-rules\") | .data[\"config.alloy\"] | select( . != null )" $< > $@

generate-example-outputs: $(OUTPUT_FILES) $(METRICS_CONFIG_FILES) $(EVENTS_CONFIG_FILES) $(LOGS_CONFIG_FILES) $(PROFILES_CONFIG_FILES)
generate-example-outputs: $(OUTPUT_FILES) $(METRICS_CONFIG_FILES) $(EVENTS_CONFIG_FILES) $(LOGS_CONFIG_FILES) $(PROFILES_CONFIG_FILES) $(RULES_CONFIG_FILES)

regenerate-example-outputs: clean generate-example-outputs
7 changes: 5 additions & 2 deletions charts/k8s-monitoring/Chart.lock
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@ dependencies:
- name: alloy
repository: https://grafana.github.io/helm-charts
version: 0.6.0
- name: alloy
repository: https://grafana.github.io/helm-charts
version: 0.3.2
- name: kube-state-metrics
repository: https://prometheus-community.github.io/helm-charts
version: 5.25.1
Expand All @@ -29,5 +32,5 @@ dependencies:
- name: kepler
repository: https://sustainable-computing-io.github.io/kepler-helm-chart
version: 0.5.9
digest: sha256:78cc014e2a726be60e168fa7d09facff16ff7ed399948403ff2e692ae8d24d91
generated: "2024-08-14T17:25:14.684591-05:00"
digest: sha256:02e225df81ff2034d306bd6950a033fdcba0285c8ac4f7be31bbd13a03389e6b
generated: "2024-08-16T11:13:53.900883-05:00"
5 changes: 5 additions & 0 deletions charts/k8s-monitoring/Chart.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,11 @@ dependencies:
version: 0.6.0
repository: https://grafana.github.io/helm-charts
condition: profiles.enabled
- alias: alloy-rules
name: alloy
version: 0.3.2
repository: https://grafana.github.io/helm-charts
condition: rules.enabled
- name: kube-state-metrics
version: 5.25.1
repository: https://prometheus-community.github.io/helm-charts
Expand Down
32 changes: 32 additions & 0 deletions charts/k8s-monitoring/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,7 @@ The Prometheus and Loki services may be hosted on the same cluster, or remotely
| https://grafana.github.io/helm-charts | alloy-events(alloy) | 0.6.0 |
| https://grafana.github.io/helm-charts | alloy-logs(alloy) | 0.6.0 |
| https://grafana.github.io/helm-charts | alloy-profiles(alloy) | 0.6.0 |
| https://grafana.github.io/helm-charts | alloy-rules(alloy) | 0.3.2 |
| https://opencost.github.io/opencost-helm-chart | opencost | 1.41.0 |
| https://prometheus-community.github.io/helm-charts | kube-state-metrics | 5.25.1 |
| https://prometheus-community.github.io/helm-charts | prometheus-node-exporter | 4.38.0 |
Expand Down Expand Up @@ -841,6 +842,24 @@ The Prometheus and Loki services may be hosted on the same cluster, or remotely
| receivers.zipkin.port | int | `9411` | Which port to use for the Zipkin receiver. This port needs to be opened in the alloy section below. |
| receivers.zipkin.tls | object | `{}` | [TLS settings](https://grafana.com/docs/alloy/latest/reference/components/otelcol.receiver.zipkin/#tls-block) to configure for the Zipkin receiver. |

### Rules

| Key | Type | Default | Description |
|-----|------|---------|-------------|
| rules.enabled | bool | `false` | Whether or not to enable the rules synchronization |

### Rules (Loki)

| Key | Type | Default | Description |
|-----|------|---------|-------------|
| rules.loki.enabled | bool | `true` | Whether or not to enable the Mimir rules synchronization |

### Rules (Mimir)

| Key | Type | Default | Description |
|-----|------|---------|-------------|
| rules.mimir.enabled | bool | `true` | Whether or not to enable the Mimir rules synchronization |

### Test Job

| Key | Type | Default | Description |
Expand Down Expand Up @@ -872,6 +891,19 @@ The Prometheus and Loki services may be hosted on the same cluster, or remotely
| Key | Type | Default | Description |
|-----|------|---------|-------------|
| extraObjects | list | `[]` | Deploy additional manifest objects |
| rules.loki.namespace.label_expressions | list | `[]` | Label expressions for Namespace resources. |
| rules.loki.namespace.label_selectors | object | `{}` | Label selector for Namespace resources. |
| rules.loki.prefix | string | alloy | Prefix to be added to the rule namespace, used to differentiate multiple Alloy deployments added. |
| rules.loki.rule.label_expressions | list | `[]` | Label expressions for PrometheusRule resources. Example: ```alloy - key: team operator: In values: ["ops"] ``` |
| rules.loki.rule.label_selectors | object | `{"rule_type":"loki"}` | Label selectors for PrometheusRule resources as key/pair values. Example: ```alloy label_selectors: rule_type: loki sync: "true" loki: "true" ``` |
| rules.loki.sync_interval | string | 5m | Amount of time between reconciliations with Mimir. |
| rules.mimir.namespace.label_expressions | list | `[]` | Label expressions for Namespace resources. |
| rules.mimir.namespace.label_selectors | object | `{}` | Label selector for Namespace resources. |
| rules.mimir.prefix | string | alloy | Prefix to be added to the rule namespace, used to differentiate multiple Alloy deployments added. |
| rules.mimir.prometheus_http_prefix | string | /api/prom | Path prefix for Mimir’s Prometheus endpoint (gem-path-prefix). |
| rules.mimir.rule.label_expressions | list | `[]` | Label expressions for PrometheusRule resources. Example: ```alloy - key: team operator: In values: ["ops"] ``` |
| rules.mimir.rule.label_selectors | object | `{"rule_type":"mimir"}` | Label selectors for PrometheusRule resources as key/pair values. Example: ```alloy label_selectors: rule_type: mimir sync: "true" mimir: "true" ``` |
| rules.mimir.sync_interval | string | 5m | Amount of time between reconciliations with Mimir. |

## Customizing the configuration

Expand Down
Binary file added charts/k8s-monitoring/charts/alloy-0.3.2.tgz
Binary file not shown.
8 changes: 8 additions & 0 deletions charts/k8s-monitoring/templates/_configs.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -153,3 +153,11 @@
{{- include "alloy.config.logging" (index .Values "alloy-profiles").logging }}
{{- include "alloy.config.liveDebugging" (index .Values "alloy-profiles").liveDebugging}}
{{- end -}}

{{/* Grafana Alloy for Rules config */}}
{{- define "alloyRulesConfig" -}}
{{- include "alloy.config.rulesMimir" . }}
{{- include "alloy.config.rulesLoki" . }}

{{- include "alloy.config.logging" (index .Values "alloy-rules").logging }}
{{- end -}}
10 changes: 10 additions & 0 deletions charts/k8s-monitoring/templates/alloy-rules-config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{{- if .Values.rules.enabled }}
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "alloy.fullname" (index .Subcharts "alloy-rules") }}
namespace: {{ .Release.Namespace }}
data:
config.alloy: |-
{{- include "alloyRulesConfig" . | trim | nindent 4 }}
{{- end }}
74 changes: 74 additions & 0 deletions charts/k8s-monitoring/templates/alloy_config/_rules_loki.alloy.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
{{ define "alloy.config.rulesLoki" }}
{{- if .Values.rules.loki.enabled }}
// Logs Service
remote.kubernetes.secret "logs_service" {
name = {{ include "kubernetes_monitoring.logs_service.secret.name" . | quote}}
namespace = {{ .Values.externalServices.loki.secret.namespace | default .Release.Namespace | quote }}
}
// Rules
loki.rules.kubernetes "rules_service" {
address = nonsensitive(remote.kubernetes.secret.logs_service.data[{{ .Values.externalServices.loki.hostKey | quote }}])
{{- if or (and (eq .Values.externalServices.loki.secret.create true) (.Values.externalServices.loki.tenantId) (eq .Values.externalServices.loki.secret.create false) ) }}
headers = nonsensitive(coalesce(remote.kubernetes.secret.logs_service.data[{{ .Values.externalServices.loki.tenantIdKey | quote }}], ""))
{{- end }}
sync_interval = {{ .Values.rules.loki.sync_interval | quote }}
loki_namespace_prefix = {{ .Values.rules.loki.prefix | quote }}
{{- if .Values.externalServices.loki.proxyURL }}
proxy_url = {{ .Values.externalServices.loki.proxyURL | quote }}
{{- end }}
{{ if eq .Values.externalServices.loki.authMode "basic" }}
basic_auth {
username = nonsensitive(remote.kubernetes.secret.logs_service.data[{{ .Values.externalServices.loki.basicAuth.usernameKey | quote }}])
password = remote.kubernetes.secret.logs_service.data[{{ .Values.externalServices.loki.basicAuth.passwordKey | quote }}]
}
{{- end }}
rule_namespace_selector {
{{- if .Values.rules.loki.namespace.label_selectors }}
match_labels = {
{{- range $key, $value := .Values.rules.loki.namespace.label_selectors }}
{{ $key }} = "{{ $value }}",
{{- end }}
}
{{- end }}

{{- if .Values.rules.loki.namespace.label_expressions }}
{{- range $expr := .Values.rules.loki.namespace.label_expressions }}
match_expression {
key = "{{ $expr.key }}"
operator = "{{ $expr.operator }}"
values = [
{{- range $index, $value := $expr.values }}
{{- if $index }}, {{ end }}"{{ $value }}"
{{- end }}
]
}
{{- end }}
{{- end }}
}

rule_selector {
{{- if .Values.rules.loki.rule.label_selectors }}
match_labels = {
{{- range $key, $value := .Values.rules.loki.rule.label_selectors }}
{{ $key }} = "{{ $value }}",
{{- end }}
}
{{- end }}

{{- if .Values.rules.loki.rule.label_expressions }}
{{- range $expr := .Values.rules.loki.rule.label_expressions }}
match_expression {
key = "{{ $expr.key }}"
operator = "{{ $expr.operator }}"
values = [
{{- range $index, $value := $expr.values }}
{{- if $index }}, {{ end }}"{{ $value }}"
{{- end }}
]
}
{{- end }}
{{- end }}
}
}
{{- end }}
{{- end }}
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
{{ define "alloy.config.rulesMimir" }}
{{- if .Values.rules.mimir.enabled }}
// Metrics Service
remote.kubernetes.secret "metrics_service" {
name = {{ include "kubernetes_monitoring.metrics_service.secret.name" . | quote }}
namespace = {{ .Values.externalServices.prometheus.secret.namespace | default .Release.Namespace | quote }}
}
// Rules
mimir.rules.kubernetes "rules_service" {
address = nonsensitive(remote.kubernetes.secret.metrics_service.data[{{ .Values.externalServices.prometheus.hostKey | quote }}])
{{- if or (and (eq .Values.externalServices.prometheus.secret.create true) (.Values.externalServices.prometheus.tenantId) (eq .Values.externalServices.prometheus.secret.create false) ) }}
headers = nonsensitive(coalesce(remote.kubernetes.secret.metrics_service.data[{{ .Values.externalServices.prometheus.tenantIdKey | quote }}], ""))
{{- end }}
sync_interval = {{ .Values.rules.mimir.sync_interval | quote }}
prometheus_http_prefix = {{ .Values.rules.mimir.prometheus_http_prefix | quote }}
mimir_namespace_prefix = {{ .Values.rules.mimir.prefix | quote }}
{{- if .Values.externalServices.prometheus.proxyURL }}
proxy_url = {{ .Values.externalServices.prometheus.proxyURL | quote }}
{{- end }}
{{ if eq .Values.externalServices.prometheus.authMode "basic" }}
basic_auth {
username = nonsensitive(remote.kubernetes.secret.metrics_service.data[{{ .Values.externalServices.prometheus.basicAuth.usernameKey | quote }}])
password = remote.kubernetes.secret.metrics_service.data[{{ .Values.externalServices.prometheus.basicAuth.passwordKey | quote }}]
}
{{- end }}
rule_namespace_selector {
{{- if .Values.rules.mimir.namespace.label_selectors }}
match_labels = {
{{- range $key, $value := .Values.rules.mimir.namespace.label_selectors }}
{{ $key }} = "{{ $value }}",
{{- end }}
}
{{- end }}

{{- if .Values.rules.mimir.namespace.label_expressions }}
{{- range $expr := .Values.rules.mimir.namespace.label_expressions }}
match_expression {
key = "{{ $expr.key }}"
operator = "{{ $expr.operator }}"
values = [
{{- range $index, $value := $expr.values }}
{{- if $index }}, {{ end }}"{{ $value }}"
{{- end }}
]
}
{{- end }}
{{- end }}
}

rule_selector {
{{- if .Values.rules.mimir.rule.label_selectors }}
match_labels = {
{{- range $key, $value := .Values.rules.mimir.rule.label_selectors }}
{{ $key }} = "{{ $value }}",
{{- end }}
}
{{- end }}

{{- if .Values.rules.mimir.rule.label_expressions }}
{{- range $expr := .Values.rules.mimir.rule.label_expressions }}
match_expression {
key = "{{ $expr.key }}"
operator = "{{ $expr.operator }}"
values = [
{{- range $index, $value := $expr.values }}
{{- if $index }}, {{ end }}"{{ $value }}"
{{- end }}
]
}
{{- end }}
{{- end }}
}
}
{{- end }}
{{- end }}
Loading

0 comments on commit e169562

Please sign in to comment.