--- /dev/null
+{{- if .Values.server.enabled -}}
+{{- if .Values.server.statefulSet.enabled -}}
+apiVersion: apps/v1
+kind: StatefulSet
+metadata:
+{{- if .Values.server.statefulSet.annotations }}
+ annotations:
+{{ toYaml .Values.server.statefulSet.annotations | indent 4 }}
+{{- end }}
+ labels:
+ {{- include "prometheus.server.labels" . | nindent 4 }}
+ {{- if .Values.server.statefulSet.labels}}
+ {{ toYaml .Values.server.statefulSet.labels | nindent 4 }}
+ {{- end}}
+ name: {{ template "prometheus.server.fullname" . }}
+{{ include "prometheus.namespace" . | indent 2 }}
+spec:
+ serviceName: {{ template "prometheus.server.fullname" . }}-headless
+ selector:
+ matchLabels:
+ {{- include "prometheus.server.matchLabels" . | nindent 6 }}
+ replicas: {{ .Values.server.replicaCount }}
+ podManagementPolicy: {{ .Values.server.statefulSet.podManagementPolicy }}
+ template:
+ metadata:
+ {{- if .Values.server.podAnnotations }}
+ annotations:
+{{ toYaml .Values.server.podAnnotations | indent 8 }}
+ {{- end }}
+ labels:
+ {{- include "prometheus.server.labels" . | nindent 8 }}
+ {{- if .Values.server.statefulSet.labels}}
+ {{ toYaml .Values.server.statefulSet.labels | nindent 8 }}
+ {{- end}}
+ spec:
+{{- if .Values.server.priorityClassName }}
+ priorityClassName: "{{ .Values.server.priorityClassName }}"
+{{- end }}
+{{- if .Values.server.schedulerName }}
+ schedulerName: "{{ .Values.server.schedulerName }}"
+{{- end }}
+ {{- if or (.Values.server.enableServiceLinks) (eq (.Values.server.enableServiceLinks | toString) "<nil>") }}
+ enableServiceLinks: true
+ {{- else }}
+ enableServiceLinks: false
+ {{- end }}
+ serviceAccountName: {{ template "prometheus.serviceAccountName.server" . }}
+ containers:
+ {{- if .Values.configmapReload.prometheus.enabled }}
+ - name: {{ template "prometheus.name" . }}-{{ .Values.server.name }}-{{ .Values.configmapReload.prometheus.name }}
+ image: "{{ .Values.configmapReload.prometheus.image.repository }}:{{ .Values.configmapReload.prometheus.image.tag }}"
+ imagePullPolicy: "{{ .Values.configmapReload.prometheus.image.pullPolicy }}"
+ args:
+ - --volume-dir=/etc/config
+ - --webhook-url=http://127.0.0.1:9090{{ .Values.server.prefixURL }}/-/reload
+ {{- range $key, $value := .Values.configmapReload.prometheus.extraArgs }}
+ - --{{ $key }}={{ $value }}
+ {{- end }}
+ {{- range .Values.configmapReload.prometheus.extraVolumeDirs }}
+ - --volume-dir={{ . }}
+ {{- end }}
+ resources:
+{{ toYaml .Values.configmapReload.prometheus.resources | indent 12 }}
+ volumeMounts:
+ - name: config-volume
+ mountPath: /etc/config
+ readOnly: true
+ {{- range .Values.configmapReload.prometheus.extraConfigmapMounts }}
+ - name: {{ $.Values.configmapReload.prometheus.name }}-{{ .name }}
+ mountPath: {{ .mountPath }}
+ subPath: {{ .subPath }}
+ readOnly: {{ .readOnly }}
+ {{- end }}
+ {{- end }}
+ - name: {{ template "prometheus.name" . }}-{{ .Values.server.name }}
+ image: "{{ .Values.server.image.repository }}:{{ .Values.server.image.tag }}"
+ imagePullPolicy: "{{ .Values.server.image.pullPolicy }}"
+ {{- if .Values.server.env }}
+ env:
+{{ toYaml .Values.server.env | indent 12}}
+ {{- end }}
+ args:
+ {{- if .Values.server.retention }}
+ - --storage.tsdb.retention.time={{ .Values.server.retention }}
+ {{- end }}
+ - --config.file={{ .Values.server.configPath }}
+ - --storage.tsdb.path={{ .Values.server.persistentVolume.mountPath }}
+ - --web.console.libraries=/etc/prometheus/console_libraries
+ - --web.console.templates=/etc/prometheus/consoles
+ {{- range .Values.server.extraFlags }}
+ - --{{ . }}
+ {{- end }}
+ {{- range $key, $value := .Values.server.extraArgs }}
+ - --{{ $key }}={{ $value }}
+ {{- end }}
+ {{- if .Values.server.baseURL }}
+ - --web.external-url={{ .Values.server.baseURL }}
+ {{- end }}
+ ports:
+ - containerPort: 9090
+ readinessProbe:
+ httpGet:
+ path: {{ .Values.server.prefixURL }}/-/ready
+ port: 9090
+ initialDelaySeconds: {{ .Values.server.readinessProbeInitialDelay }}
+ timeoutSeconds: {{ .Values.server.readinessProbeTimeout }}
+ livenessProbe:
+ httpGet:
+ path: {{ .Values.server.prefixURL }}/-/healthy
+ port: 9090
+ initialDelaySeconds: {{ .Values.server.livenessProbeInitialDelay }}
+ timeoutSeconds: {{ .Values.server.livenessProbeTimeout }}
+ resources:
+{{ toYaml .Values.server.resources | indent 12 }}
+ volumeMounts:
+ - name: config-volume
+ mountPath: /etc/config
+ - name: storage-volume
+ mountPath: {{ .Values.server.persistentVolume.mountPath }}
+ subPath: "{{ .Values.server.persistentVolume.subPath }}"
+ {{- range .Values.server.extraHostPathMounts }}
+ - name: {{ .name }}
+ mountPath: {{ .mountPath }}
+ subPath: {{ .subPath }}
+ readOnly: {{ .readOnly }}
+ {{- end }}
+ {{- range .Values.server.extraConfigmapMounts }}
+ - name: {{ $.Values.server.name }}-{{ .name }}
+ mountPath: {{ .mountPath }}
+ subPath: {{ .subPath }}
+ readOnly: {{ .readOnly }}
+ {{- end }}
+ {{- range .Values.server.extraSecretMounts }}
+ - name: {{ .name }}
+ mountPath: {{ .mountPath }}
+ subPath: {{ .subPath }}
+ readOnly: {{ .readOnly }}
+ {{- end }}
+ {{- if .Values.server.extraVolumeMounts }}
+ {{ toYaml .Values.server.extraVolumeMounts | nindent 12 }}
+ {{- end }}
+ {{- if .Values.server.sidecarContainers }}
+ {{- toYaml .Values.server.sidecarContainers | nindent 8 }}
+ {{- end }}
+ {{- if .Values.imagePullSecrets }}
+ imagePullSecrets:
+ {{ toYaml .Values.imagePullSecrets | indent 2 }}
+ {{- end }}
+ {{- if .Values.server.nodeSelector }}
+ nodeSelector:
+{{ toYaml .Values.server.nodeSelector | indent 8 }}
+ {{- end }}
+ {{- if .Values.server.hostAliases }}
+ hostAliases:
+{{ toYaml .Values.server.hostAliases | indent 8 }}
+ {{- end }}
+ {{- if .Values.server.securityContext }}
+ securityContext:
+{{ toYaml .Values.server.securityContext | indent 8 }}
+ {{- end }}
+ {{- if .Values.server.tolerations }}
+ tolerations:
+{{ toYaml .Values.server.tolerations | indent 8 }}
+ {{- end }}
+ {{- if .Values.server.affinity }}
+ affinity:
+{{ toYaml .Values.server.affinity | indent 8 }}
+ {{- end }}
+ terminationGracePeriodSeconds: {{ .Values.server.terminationGracePeriodSeconds }}
+ volumes:
+ - name: config-volume
+ configMap:
+ name: {{ if .Values.server.configMapOverrideName }}{{ .Release.Name }}-{{ .Values.server.configMapOverrideName }}{{- else }}{{ template "prometheus.server.fullname" . }}{{- end }}
+ {{- range .Values.server.extraHostPathMounts }}
+ - name: {{ .name }}
+ hostPath:
+ path: {{ .hostPath }}
+ {{- end }}
+ {{- range .Values.configmapReload.prometheus.extraConfigmapMounts }}
+ - name: {{ $.Values.configmapReload.prometheus.name }}-{{ .name }}
+ configMap:
+ name: {{ .configMap }}
+ {{- end }}
+ {{- range .Values.server.extraConfigmapMounts }}
+ - name: {{ $.Values.server.name }}-{{ .name }}
+ configMap:
+ name: {{ .configMap }}
+ {{- end }}
+ {{- range .Values.server.extraSecretMounts }}
+ - name: {{ .name }}
+ secret:
+ secretName: {{ .secretName }}
+ {{- end }}
+ {{- range .Values.configmapReload.prometheus.extraConfigmapMounts }}
+ - name: {{ .name }}
+ configMap:
+ name: {{ .configMap }}
+ {{- end }}
+{{- if .Values.server.extraVolumes }}
+{{ toYaml .Values.server.extraVolumes | indent 8}}
+{{- end }}
+{{- if .Values.server.persistentVolume.enabled }}
+ volumeClaimTemplates:
+ - metadata:
+ name: storage-volume
+ {{- if .Values.server.persistentVolume.annotations }}
+ annotations:
+{{ toYaml .Values.server.persistentVolume.annotations | indent 10 }}
+ {{- end }}
+ spec:
+ accessModes:
+{{ toYaml .Values.server.persistentVolume.accessModes | indent 10 }}
+ resources:
+ requests:
+ storage: "{{ .Values.server.persistentVolume.size }}"
+ {{- if .Values.server.persistentVolume.storageClass }}
+ {{- if (eq "-" .Values.server.persistentVolume.storageClass) }}
+ storageClassName: ""
+ {{- else }}
+ storageClassName: "{{ .Values.server.persistentVolume.storageClass }}"
+ {{- end }}
+ {{- end }}
+{{- else }}
+ - name: storage-volume
+ emptyDir: {}
+{{- end }}
+{{- end }}
+{{- end }}