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