forked from kubegems/appstore-charts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdeployment.yaml
110 lines (110 loc) · 4.35 KB
/
deployment.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "prometheus-mysql-exporter.fullname" . }}
namespace: {{ .Release.Namespace }}
labels:
{{- include "prometheus-mysql-exporter.labels" . | nindent 4 }}
spec:
replicas: {{ .Values.replicaCount }}
selector:
matchLabels:
{{- include "prometheus-mysql-exporter.selectorLabels" . | nindent 6 }}
template:
metadata:
labels:
{{- include "prometheus-mysql-exporter.selectorLabels" . | nindent 8 }}
{{- if .Values.podLabels }}
{{ toYaml .Values.podLabels | trim | indent 8 }}
{{- end }}
annotations:
checksum/credentials: {{ include (print .Template.BasePath "/secret-env.yaml") . | sha256sum }}
spec:
serviceAccountName: {{ template "prometheus-mysql-exporter.serviceAccountName" . }}
securityContext:
{{- toYaml .Values.podSecurityContext | nindent 8 }}
containers:
- name: {{ .Chart.Name }}
securityContext:
{{- toYaml .Values.securityContext | nindent 12 }}
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
imagePullPolicy: {{ .Values.image.pullPolicy }}
{{- with .Values.collectors }}
args: [
{{- range $index, $element := . }}
{{- if and (typeIs "bool" $element) $element }}
{{ printf "--collect.%s" $index | quote | indent 12 }},
{{- else if and (typeIs "bool" $element) (not $element) }}
{{ printf "--no-collect.%s" $index | quote | indent 12 }},
{{- else }}
{{ printf "--collect.%s" $index | quote | indent 12 }}, {{ $element | quote }},
{{- end }}
{{- end }}
]
{{- end }}
{{- if not .Values.mysql.existingSecret }}
env:
- name: DB_PASSWORD
valueFrom:
secretKeyRef:
{{- if .Values.mysql.existingPasswordSecret.name }}
name: {{ .Values.mysql.existingPasswordSecret.name }}
key: {{ .Values.mysql.existingPasswordSecret.key }}
{{- else }}
name: {{ template "prometheus-mysql-exporter.fullname" . }}
key: password
{{- end }}
{{- end }}
{{- if .Values.mysql.existingSecret }}
envFrom:
- secretRef:
name: {{ template "prometheus-mysql-exporter.secret" . }}
{{- else }}
- name: DATA_SOURCE_NAME
value: "{{ .Values.mysql.user }}:$(DB_PASSWORD)@{{ if .Values.mysql.protocol }}{{ .Values.mysql.protocol }}{{ end }}({{ .Values.mysql.host }}:{{ .Values.mysql.port }})/{{ if .Values.mysql.db }}{{ .Values.mysql.db }}{{ end }}{{ if .Values.mysql.param }}?{{ .Values.mysql.param }}{{ end }}"
{{- end }}
ports:
- containerPort: {{ .Values.service.internalPort }}
livenessProbe:
httpGet:
path: /
port: {{ .Values.service.internalPort }}
readinessProbe:
httpGet:
path: /
port: {{ .Values.service.internalPort }}
{{- if .Values.cloudsqlproxy.enabled }}
- name: cloudsql-proxy
image: "{{ .Values.cloudsqlproxy.image.repo }}:{{ .Values.cloudsqlproxy.image.tag }}"
imagePullPolicy: "{{ .Values.cloudsqlproxy.image.PullPolicy }}"
command: ["/cloud_sql_proxy",
"-instances={{ .Values.cloudsqlproxy.instanceConnectionName }}=tcp:{{ .Values.cloudsqlproxy.port }}",
"-credential_file=/secrets/cloudsql/credentials.json"]
livenessProbe:
exec:
command: ["nc", "-z", "127.0.0.1", "3306"]
volumeMounts:
- name: cloudsql-proxy-sa-credentials
mountPath: /secrets/cloudsql
readOnly: true
{{- end }}
resources:
{{ toYaml .Values.resources | indent 12 }}
{{- with .Values.nodeSelector }}
nodeSelector:
{{ toYaml . | indent 8 }}
{{- end }}
{{- with .Values.affinity }}
affinity:
{{ toYaml . | indent 8 }}
{{- end }}
{{- with .Values.tolerations }}
tolerations:
{{ toYaml . | indent 8 }}
{{- end }}
{{- if .Values.cloudsqlproxy.enabled }}
volumes:
- name: cloudsql-proxy-sa-credentials
secret:
secretName: {{ if .Values.cloudsqlproxy.credentialsSecret }}{{ .Values.cloudsqlproxy.credentialsSecret }}{{ else }}{{ template "prometheus-mysql-exporter.cloudsqlsecret" . }}{{ end }}
{{- end }}