mirror of
https://github.com/carlosedp/cluster-monitoring.git
synced 2025-01-11 00:10:18 +01:00
43 lines
2.3 KiB
Plaintext
43 lines
2.3 KiB
Plaintext
local k = import 'ksonnet/ksonnet.beta.3/k.libsonnet';
|
|
local vars = import 'vars.jsonnet';
|
|
|
|
local join_objects(objs) =
|
|
local aux(arr, i, running) =
|
|
if i >= std.length(arr) then
|
|
running
|
|
else
|
|
aux(arr, i + 1, running + arr[i]) tailstrict;
|
|
aux(objs, 0, {});
|
|
|
|
local kp = (import 'kube-prometheus/kube-prometheus.libsonnet')
|
|
+ (import 'kube-prometheus/kube-prometheus-anti-affinity.libsonnet')
|
|
+ (import 'kube-prometheus/kube-prometheus-kops-coredns.libsonnet')
|
|
+ (import 'kube-prometheus/kube-prometheus-kubeadm.libsonnet')
|
|
// Use http Kubelet targets. Comment to revert to https
|
|
+ (import 'kube-prometheus/kube-prometheus-insecure-kubelet.libsonnet')
|
|
+ (import 'base_operator_stack.jsonnet')
|
|
+ (import 'smtp_server.jsonnet')
|
|
// Additional modules are loaded dynamically from vars.jsonnet
|
|
+ join_objects([module.file for module in vars.modules if module.enabled])
|
|
// Load image versions last to override default from modules
|
|
+ (import 'image_sources_versions.jsonnet');
|
|
|
|
// Generate core modules
|
|
{ ['00namespace-' + name]: kp.kubePrometheus[name] for name in std.objectFields(kp.kubePrometheus) }
|
|
{ ['0prometheus-operator-' + name]: kp.prometheusOperator[name] for name in std.objectFields(kp.prometheusOperator) }
|
|
{ ['prometheus-adapter-' + name]: kp.prometheusAdapter[name] for name in std.objectFields(kp.prometheusAdapter) }
|
|
{ ['prometheus-' + name]: kp.prometheus[name] for name in std.objectFields(kp.prometheus) }
|
|
{ ['alertmanager-' + name]: kp.alertmanager[name] for name in std.objectFields(kp.alertmanager) }
|
|
{ ['kube-state-metrics-' + name]: kp.kubeStateMetrics[name] for name in std.objectFields(kp.kubeStateMetrics) }
|
|
{ ['node-exporter-' + name]: kp.nodeExporter[name] for name in std.objectFields(kp.nodeExporter) }
|
|
{ ['grafana-' + name]: kp.grafana[name] for name in std.objectFields(kp.grafana) }
|
|
{ ['ingress-' + name]: kp.ingress[name] for name in std.objectFields(kp.ingress) }
|
|
{ ['smtp-server-' + name]: kp.smtpServer[name] for name in std.objectFields(kp.smtpServer) }
|
|
|
|
{ // Dynamically generate additional modules from vars.jsonnet
|
|
[std.asciiLower(module.name) + '-' + name]: kp[module.name][name]
|
|
for module in vars.modules
|
|
if module.enabled
|
|
for name in std.objectFields(kp[module.name])
|
|
}
|