[CONSUL] Add limits to consul chart.
[oom.git] / kubernetes / esr / charts / esr-server / templates / deployment.yaml
1 # Copyright © 2017 Amdocs, Bell Canada
2 # Modifications Copyright © 2018 AT&T
3 #
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
7 #
8 #       http://www.apache.org/licenses/LICENSE-2.0
9 #
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
15
16 apiVersion: apps/v1
17 kind: Deployment
18 metadata:
19   name: {{ include "common.fullname" . }}
20   namespace: {{ include "common.namespace" . }}
21   labels:
22     app: {{ include "common.name" . }}
23     chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
24     release: {{ include "common.release" . }}
25     heritage: {{ .Release.Service }}
26 spec:
27   selector:
28     matchLabels:
29       app: {{ include "common.name" . }}
30   replicas: {{ .Values.replicaCount }}
31   template:
32     metadata:
33       labels:
34         app: {{ include "common.name" . }}
35         release: {{ include "common.release" . }}
36     spec:
37       securityContext:
38         runAsUser: 1000
39         runAsGroup: 1001
40         fsGroup: 1001
41       initContainers:
42       - command:
43         - cp
44         args:
45         - -r
46         - -T
47         - /home/esr/conf
48         - /opt/conf
49         securityContext:
50           privileged: true
51         image: "{{ include "common.repository" . }}/{{ .Values.image }}"
52         imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
53         name: create-conf-dir
54         volumeMounts:
55         - name: conf-dir
56           mountPath: /opt/conf
57
58       containers:
59         - name: {{ .Chart.Name }}
60           image: "{{ include "common.repository" . }}/{{ .Values.image }}"
61           imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
62           ports:
63           - containerPort: {{ .Values.service.internalPort }}
64           # disable liveness probe when breakpoints set in debugger
65           # so K8s doesn't restart unresponsive container
66           {{- if eq .Values.liveness.enabled true }}
67           livenessProbe:
68             tcpSocket:
69               port: {{ .Values.service.internalPort }}
70             initialDelaySeconds: {{ .Values.liveness.initialDelaySeconds }}
71             periodSeconds: {{ .Values.liveness.periodSeconds }}
72           {{ end -}}
73           readinessProbe:
74             tcpSocket:
75               port: {{ .Values.service.internalPort }}
76             initialDelaySeconds: {{ .Values.readiness.initialDelaySeconds }}
77             periodSeconds: {{ .Values.readiness.periodSeconds }}
78           env:
79             - name: MSB_ADDR
80               value: {{ tpl .Values.msbaddr . }}
81           volumeMounts:
82           - mountPath: /etc/localtime
83             name: localtime
84             readOnly: true
85           - mountPath: /home/esr/works/logs
86             name: {{ include "common.fullname" . }}-logs
87           - mountPath: /home/esr/conf
88             name: conf-dir
89           resources:
90 {{ include "common.resources" . | indent 12 }}
91         {{- if .Values.nodeSelector }}
92         nodeSelector:
93 {{ toYaml .Values.nodeSelector | indent 10 }}
94         {{- end -}}
95         {{- if .Values.affinity }}
96         affinity:
97 {{ toYaml .Values.affinity | indent 10 }}
98         {{- end }}
99         # Filebeat sidecar container
100         - name: {{ include "common.name" . }}-filebeat-onap
101           securityContext:
102             runAsUser: 1000
103             runAsGroup: 1000
104           image: "{{ .Values.global.loggingRepository }}/{{ .Values.global.loggingImage }}"
105           imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
106           volumeMounts:
107           - name: {{ include "common.fullname" . }}-filebeat-conf
108             mountPath: /usr/share/filebeat/filebeat.yml
109             subPath: filebeat.yml
110           - name: {{ include "common.fullname" . }}-data-filebeat
111             mountPath: /usr/share/filebeat/data
112           - name: {{ include "common.fullname" . }}-logs
113             mountPath: /var/log/onap/esr/esr-server
114           - mountPath: /opt/ajsc/etc/config/logback.xml
115             name: {{ include "common.fullname" . }}-log-conf
116             subPath: logback.xml
117       volumes:
118         - name: localtime
119           hostPath:
120             path: /etc/localtime
121         - name: {{ include "common.fullname" . }}-log-conf
122           configMap:
123             name: {{ include "common.fullname" . }}-log
124         - name: {{ include "common.fullname" . }}-filebeat-conf
125           configMap:
126             name: {{ include "common.fullname" . }}-esr-filebeat-configmap
127         - name: {{ include "common.fullname" . }}-data-filebeat
128           emptyDir: {}
129         - name:  {{ include "common.fullname" . }}-logs
130           emptyDir: {}
131         - name: conf-dir
132           emptyDir: {}
133
134       imagePullSecrets:
135       - name: "{{ include "common.namespace" . }}-docker-registry-key"