forked from MarquezProject/marquez
-
Notifications
You must be signed in to change notification settings - Fork 0
/
deployment.yaml
100 lines (100 loc) · 4.1 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
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ include "common.names.fullname" . }}
labels: {{- include "common.labels.standard" . | nindent 4 }}
{{- if .Values.commonLabels }}
{{- include "common.tplvalues.render" (dict "value" .Values.commonLabels "context" $) | nindent 4 }}
{{- end }}
app.kubernetes.io/component: marquez
{{- if .Values.commonAnnotations }}
annotations: {{- include "common.tplvalues.render" (dict "value" .Values.commonAnnotations "context" $) | nindent 4 }}
{{- end }}
spec:
selector:
matchLabels: {{- include "common.labels.matchLabels" . | nindent 6 }}
app.kubernetes.io/component: marquez
replicas: {{ default 1 .Values.marquez.replicaCount }}
template:
metadata:
labels: {{- include "common.labels.standard" . | nindent 8 }}
app.kubernetes.io/component: marquez
spec:
{{- if .Values.postgresql.enabled }}
# This init container is for avoiding CrashLoopback errors in the Marquez container because the PostgreSQL container is not ready
initContainers:
- name: wait-for-db
image: postgres:12.1
imagePullPolicy: IfNotPresent
command:
- /bin/bash
args:
- -ec
- until pg_isready -h ${POSTGRES_HOST} -p ${POSTGRES_PORT}; do echo waiting for database; sleep 2; done;
env:
- name: POSTGRES_HOST
value: {{ include "marquez.database.host" . | quote }}
- name: POSTGRES_PORT
value: {{ include "marquez.database.port" . | quote }}
{{- end }}
containers:
- name: {{ .Chart.Name }}
image: {{ include "marquez.image" . }}
imagePullPolicy: {{ .Values.marquez.image.pullPolicy }}
volumeMounts:
- name: marquez-volume
mountPath: /usr/src/app/config.yml
subPath: config.yml
ports:
- name: http
containerPort: {{ .Values.marquez.port }}
protocol: TCP
- name: http-admin
containerPort: {{ .Values.marquez.adminPort }}
protocol: TCP
livenessProbe:
httpGet:
path: /healthcheck
port: http-admin
readinessProbe:
httpGet:
path: /healthcheck
port: http-admin
env:
- name: MARQUEZ_PORT
value: {{ .Values.marquez.port | quote }}
- name: MARQUEZ_ADMIN_PORT
value: {{ .Values.marquez.adminPort | quote }}
- name: MARQUEZ_CONFIG
value: /usr/src/app/config.yml
- name: POSTGRES_HOST
value: {{ include "marquez.database.host" . | quote }}
- name: POSTGRES_PORT
value: {{ include "marquez.database.port" . | quote }}
- name: POSTGRES_DB
value: {{ include "marquez.database.name" . | quote }}
- name: POSTGRES_USER
value: {{ include "marquez.database.user" . | quote }}
- name: POSTGRES_PASSWORD
valueFrom:
secretKeyRef:
name: {{ include "marquez.postgresql.secretName" . }}
key: {{ include "marquez.database.existingsecret.key" . }}
- name: MIGRATE_ON_STARTUP
value: {{ .Values.marquez.migrateOnStartup | quote }}
{{- if .Values.marquez.resources }}
resources: {{- toYaml .Values.marquez.resources | nindent 12 }}
{{- end }}
volumes:
- name: marquez-volume
configMap:
name: {{ include "marquez.fullname" . }}-config
{{- if .Values.affinity }}
affinity: {{- include "common.tplvalues.render" (dict "value" .Values.affinity "context" $) | nindent 8 }}
{{- end }}
{{- if .Values.nodeSelector }}
nodeSelector: {{- include "common.tplvalues.render" (dict "value" .Values.nodeSelector "context" $) | nindent 8 }}
{{- end }}
{{- if .Values.tolerations }}
tolerations: {{- include "common.tplvalues.render" (dict "value" .Values.tolerations "context" $) | nindent 8 }}
{{- end }}