324 lines
9.7 KiB
YAML
324 lines
9.7 KiB
YAML
|
image:
|
||
|
repository: grafana/grafana
|
||
|
pullPolicy: IfNotPresent
|
||
|
tag: 10.2.3
|
||
|
|
||
|
sidecarImage:
|
||
|
repository: quay.io/kiwigrid/k8s-sidecar
|
||
|
tag: 1.25.3@sha256:8dc0aca015bf7173378ee5987dd78d49f94ff9a5c3495b3664141750cc55f444
|
||
|
|
||
|
securityContext:
|
||
|
container:
|
||
|
readOnlyRootFilesystem: false
|
||
|
service:
|
||
|
main:
|
||
|
ports:
|
||
|
main:
|
||
|
protocol: http
|
||
|
targetPort: 3000
|
||
|
port: 3000
|
||
|
workload:
|
||
|
main:
|
||
|
replicas: 2
|
||
|
strategy: RollingUpdate
|
||
|
podSpec:
|
||
|
containers:
|
||
|
main:
|
||
|
env:
|
||
|
GF_SECURITY_ADMIN_USER: "admin"
|
||
|
GF_SECURITY_ADMIN_PASSWORD: "testpassword"
|
||
|
GF_INSTALL_PLUGINS: ""
|
||
|
GF_AUTH_LDAP_ENABLED: "false"
|
||
|
GF_AUTH_LDAP_ALLOW_SIGN_UP: "false"
|
||
|
GF_SERVER_HTTP_PORT: 3000
|
||
|
probes:
|
||
|
liveness:
|
||
|
path: "/api/health"
|
||
|
readiness:
|
||
|
path: "/api/health"
|
||
|
startup:
|
||
|
path: "/api/health"
|
||
|
dashboards:
|
||
|
enabled: true
|
||
|
imageSelector: sidecarImage
|
||
|
env:
|
||
|
IGNORE_ALREADY_PROCESSED: false
|
||
|
METHOD: WATCH
|
||
|
LABEL: grafana_dashboard
|
||
|
LABEL_VALUE: ""
|
||
|
LOG_LEVEL: info
|
||
|
FOLDER: /tmp/dashboards
|
||
|
RESOURCE: both
|
||
|
UNIQUE_FILENAMES: false
|
||
|
# NAMESPACE: null
|
||
|
# FOLDER_ANNOTATION: null
|
||
|
# script: null
|
||
|
# WATCH_SERVER_TIMEOUT: 3600
|
||
|
# WATCH_CLIENT_TIMEOUT: 3600
|
||
|
SKIP_TLS_VERIFY: false
|
||
|
REQ_USERNAME: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_PASSWORD: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_URL: "http://localhost:3000/api/admin/provisioning/dashboards/reload"
|
||
|
REQ_METHOD: POST
|
||
|
probes:
|
||
|
liveness:
|
||
|
enabled: false
|
||
|
readiness:
|
||
|
enabled: false
|
||
|
startup:
|
||
|
enabled: false
|
||
|
datasources:
|
||
|
enabled: true
|
||
|
imageSelector: sidecarImage
|
||
|
env:
|
||
|
IGNORE_ALREADY_PROCESSED: false
|
||
|
METHOD: WATCH
|
||
|
LABEL: grafana_datasources
|
||
|
LABEL_VALUE: ""
|
||
|
LOG_LEVEL: info
|
||
|
FOLDER: /app/provisioning/datasources
|
||
|
RESOURCE: both
|
||
|
UNIQUE_FILENAMES: false
|
||
|
# NAMESPACE: null
|
||
|
# FOLDER_ANNOTATION: null
|
||
|
# script: null
|
||
|
# WATCH_SERVER_TIMEOUT: 3600
|
||
|
# WATCH_CLIENT_TIMEOUT: 3600
|
||
|
SKIP_TLS_VERIFY: false
|
||
|
REQ_USERNAME: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_PASSWORD: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_URL: "http://localhost:3000/api/admin/provisioning/datasources/reload"
|
||
|
REQ_METHOD: POST
|
||
|
probes:
|
||
|
liveness:
|
||
|
enabled: false
|
||
|
readiness:
|
||
|
enabled: false
|
||
|
startup:
|
||
|
enabled: false
|
||
|
alerts:
|
||
|
enabled: true
|
||
|
imageSelector: sidecarImage
|
||
|
env:
|
||
|
IGNORE_ALREADY_PROCESSED: false
|
||
|
METHOD: WATCH
|
||
|
LABEL: grafana_alerts
|
||
|
LABEL_VALUE: ""
|
||
|
LOG_LEVEL: info
|
||
|
FOLDER: /app/provisioning/alerts
|
||
|
RESOURCE: both
|
||
|
UNIQUE_FILENAMES: false
|
||
|
# NAMESPACE: null
|
||
|
# FOLDER_ANNOTATION: null
|
||
|
# script: null
|
||
|
# WATCH_SERVER_TIMEOUT: 3600
|
||
|
# WATCH_CLIENT_TIMEOUT: 3600
|
||
|
SKIP_TLS_VERIFY: false
|
||
|
REQ_USERNAME: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_PASSWORD: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_URL: "http://localhost:3000/api/admin/provisioning/alerts/reload"
|
||
|
REQ_METHOD: POST
|
||
|
probes:
|
||
|
liveness:
|
||
|
enabled: false
|
||
|
readiness:
|
||
|
enabled: false
|
||
|
startup:
|
||
|
enabled: false
|
||
|
plugins:
|
||
|
enabled: true
|
||
|
imageSelector: sidecarImage
|
||
|
env:
|
||
|
IGNORE_ALREADY_PROCESSED: false
|
||
|
METHOD: WATCH
|
||
|
LABEL: grafana_plugins
|
||
|
LABEL_VALUE: ""
|
||
|
LOG_LEVEL: info
|
||
|
FOLDER: /app/provisioning/plugins
|
||
|
RESOURCE: both
|
||
|
UNIQUE_FILENAMES: false
|
||
|
# NAMESPACE: null
|
||
|
# FOLDER_ANNOTATION: null
|
||
|
# script: null
|
||
|
# WATCH_SERVER_TIMEOUT: 3600
|
||
|
# WATCH_CLIENT_TIMEOUT: 3600
|
||
|
SKIP_TLS_VERIFY: false
|
||
|
REQ_USERNAME: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_PASSWORD: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_URL: "http://localhost:3000/api/admin/provisioning/plugins/reload"
|
||
|
REQ_METHOD: POST
|
||
|
probes:
|
||
|
liveness:
|
||
|
enabled: false
|
||
|
readiness:
|
||
|
enabled: false
|
||
|
startup:
|
||
|
enabled: false
|
||
|
notifiers:
|
||
|
enabled: true
|
||
|
imageSelector: sidecarImage
|
||
|
env:
|
||
|
IGNORE_ALREADY_PROCESSED: false
|
||
|
METHOD: WATCH
|
||
|
LABEL: grafana_notifiers
|
||
|
LABEL_VALUE: ""
|
||
|
LOG_LEVEL: info
|
||
|
FOLDER: /app/provisioning/notifiers
|
||
|
RESOURCE: both
|
||
|
UNIQUE_FILENAMES: false
|
||
|
# NAMESPACE: null
|
||
|
# FOLDER_ANNOTATION: null
|
||
|
# script: null
|
||
|
# WATCH_SERVER_TIMEOUT: 3600
|
||
|
# WATCH_CLIENT_TIMEOUT: 3600
|
||
|
SKIP_TLS_VERIFY: false
|
||
|
REQ_USERNAME: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_PASSWORD: "{{ .Values.workload.main.podSpec.containers.main.env.GF_SECURITY_ADMIN_USER }}"
|
||
|
REQ_URL: "http://localhost:3000/api/admin/provisioning/notifiers/reload"
|
||
|
REQ_METHOD: POST
|
||
|
probes:
|
||
|
liveness:
|
||
|
enabled: false
|
||
|
readiness:
|
||
|
enabled: false
|
||
|
startup:
|
||
|
enabled: false
|
||
|
|
||
|
configmap:
|
||
|
dashboard-provider:
|
||
|
enabled: true
|
||
|
data:
|
||
|
provider.yaml: |-
|
||
|
apiVersion: 1
|
||
|
providers:
|
||
|
- name: sidecarProvider
|
||
|
orgId: 1
|
||
|
folder: ''
|
||
|
type: file
|
||
|
disableDeletion: false
|
||
|
allowUiUpdates: false
|
||
|
updateIntervalSeconds: 30
|
||
|
options:
|
||
|
foldersFromFilesStructure: false
|
||
|
path: /tmp/dashboards
|
||
|
config:
|
||
|
enabled: true
|
||
|
data:
|
||
|
grafana.ini: |-
|
||
|
paths:
|
||
|
data: /var/lib/grafana/
|
||
|
logs: /var/log/grafana
|
||
|
plugins: /var/lib/grafana/plugins
|
||
|
provisioning: /etc/grafana/provisioning
|
||
|
analytics:
|
||
|
check_for_updates: true
|
||
|
log:
|
||
|
mode: console
|
||
|
grafana_net:
|
||
|
url: https://grafana.net
|
||
|
server:
|
||
|
domain: "{{ if (and .Values.ingress.main.enabled .Values.ingress.main.hosts) }}{{ .Values.ingress.main.hosts | first }}{{ else }}''{{ end }}"
|
||
|
ldap.toml: |-
|
||
|
# nope
|
||
|
|
||
|
persistence:
|
||
|
config:
|
||
|
enabled: true
|
||
|
type: configmap
|
||
|
objectName: config
|
||
|
mountPath: /etc/grafana/grafana.ini
|
||
|
subPath: grafana.ini
|
||
|
ldap:
|
||
|
enabled: true
|
||
|
type: configmap
|
||
|
objectName: config
|
||
|
mountPath: /etc/grafana/ldap.toml
|
||
|
subPath: ldap.toml
|
||
|
data:
|
||
|
enabled: true
|
||
|
mountPath: "/var/lib/grafana"
|
||
|
grafana-tmp:
|
||
|
enabled: true
|
||
|
type: emptyDir
|
||
|
mountPath: /app/tmp
|
||
|
targetSelectAll: true
|
||
|
sc-dashboard-volume:
|
||
|
enabled: true
|
||
|
type: emptyDir
|
||
|
mountPath: /tmp/dashboards
|
||
|
targetSelectAll: true
|
||
|
sc-dashboard-config:
|
||
|
enabled: true
|
||
|
type: configmap
|
||
|
objectName: dashboard-provider
|
||
|
mountPath: /etc/grafana/provisioning/dashboards/sc-dashboardproviders.yaml
|
||
|
subPath: provider.yaml
|
||
|
sc-datasource-volume:
|
||
|
enabled: true
|
||
|
type: emptyDir
|
||
|
mountPath: /etc/grafana/provisioning/datasources
|
||
|
targetSelectAll: true
|
||
|
sc-alerts-volume:
|
||
|
enabled: true
|
||
|
type: emptyDir
|
||
|
mountPath: /etc/grafana/provisioning/alerts
|
||
|
targetSelectAll: true
|
||
|
sc-plugins-volume:
|
||
|
enabled: true
|
||
|
type: emptyDir
|
||
|
mountPath: /etc/grafana/provisioning/plugins
|
||
|
targetSelectAll: true
|
||
|
sc-notifiers-volume:
|
||
|
enabled: true
|
||
|
type: emptyDir
|
||
|
mountPath: /etc/grafana/provisioning/notifiers
|
||
|
targetSelectAll: true
|
||
|
metrics:
|
||
|
main:
|
||
|
# -- Enable and configure a Prometheus serviceMonitor for the chart under this key.
|
||
|
# @default -- See values.yaml
|
||
|
enabled: true
|
||
|
type: "servicemonitor"
|
||
|
endpoints:
|
||
|
- port: main
|
||
|
path: /metrics
|
||
|
# -- Enable and configure Prometheus Rules for the chart under this key.
|
||
|
# @default -- See values.yaml
|
||
|
prometheusRule:
|
||
|
enabled: false
|
||
|
labels: {}
|
||
|
# -- Configure additionial rules for the chart under this key.
|
||
|
# @default -- See prometheusrules.yaml
|
||
|
rules: []
|
||
|
# - alert: UnifiPollerAbsent
|
||
|
# annotations:
|
||
|
# description: Unifi Poller has disappeared from Prometheus service discovery.
|
||
|
# summary: Unifi Poller is down.
|
||
|
# expr: |
|
||
|
# absent(up{job=~".*unifi-poller.*"} == 1)
|
||
|
# for: 5m
|
||
|
# labels:
|
||
|
# severity: critical
|
||
|
portal:
|
||
|
open:
|
||
|
enabled: true
|
||
|
|
||
|
# -- Whether Role Based Access Control objects like roles and rolebindings should be created
|
||
|
rbac:
|
||
|
main:
|
||
|
enabled: true
|
||
|
primary: true
|
||
|
clusterWide: true
|
||
|
rules:
|
||
|
- apiGroups: [""]
|
||
|
resources: ["configmaps", "secrets"]
|
||
|
verbs: ["get", "watch", "list"]
|
||
|
|
||
|
serviceAccount:
|
||
|
main:
|
||
|
enabled: true
|
||
|
primary: true
|
||
|
|
||
|
podOptions:
|
||
|
automountServiceAccountToken: true
|