[CONSUL] Add limits to consul chart.
[oom.git] / kubernetes / so / charts / so-vnfm-adapter / templates / deployment.yaml
1 # Copyright © 2019 Nordix Foundation
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 apiVersion: apps/v1
15 kind: Deployment
16 metadata:
17   name: {{ include "common.fullname" . }}
18   namespace: {{ include "common.namespace" . }}
19   labels:
20     app: {{ include "common.fullname" . }}
21     chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
22     release: {{ include "common.release" . }}
23 spec:
24   selector:
25     matchLabels:
26       app: {{ include "common.name" . }}
27   replicas: {{ index .Values.replicaCount }}
28   minReadySeconds: {{ index .Values.minReadySeconds }}
29   strategy:
30     type: {{ index .Values.updateStrategy.type }}
31     rollingUpdate:
32       maxUnavailable: {{ index .Values.updateStrategy.maxUnavailable }}
33       maxSurge: {{ index .Values.updateStrategy.maxSurge }}
34   template:
35     metadata:
36       labels:
37         app: {{ include "common.name" . }}
38         release: {{ include "common.release" . }}
39     spec:
40       initContainers: {{ include "so.certificate.container_importer" . | nindent 6 }}
41       containers:
42       - name: {{ include "common.name" . }}
43         image: {{ include "common.repository" . }}/{{ .Values.image }}
44         resources:
45 {{ include "common.resources" . | indent 12 }}
46         env:
47         - name: TRUSTSTORE
48           value: {{ .Values.global.client.certs.truststore }}
49         - name: TRUSTSTORE_PASSWORD
50           valueFrom:
51             secretKeyRef:
52               name: {{ .Release.Name}}-so-client-certs-secret
53               key: trustStorePassword
54         {{ if eq .Values.global.security.aaf.enabled true }}
55         - name: KEYSTORE
56           value: {{ .Values.global.client.certs.keystore }}
57         - name: KEYSTORE_PASSWORD
58           valueFrom:
59             secretKeyRef:
60               name: {{ .Release.Name}}-so-client-certs-secret
61               key: keyStorePassword
62         {{- end }}
63         envFrom:
64         - configMapRef:
65             name: {{ include "common.fullname" . }}-configmap
66         imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
67         volumeMounts: {{ include "so.certificate.volume-mounts" . | nindent 8 }}
68         - name: logs
69           mountPath: /app/logs
70         - name: config
71           mountPath: /app/config
72           readOnly: true
73         - name: {{ include "common.fullname" . }}-truststore
74           mountPath: /app/client
75           readOnly: true
76         livenessProbe:
77           tcpSocket:
78             port: {{ index .Values.livenessProbe.port }}
79           initialDelaySeconds: {{ index .Values.livenessProbe.initialDelaySeconds}}
80           periodSeconds: {{ index .Values.livenessProbe.periodSeconds}}
81           successThreshold: {{ index .Values.livenessProbe.successThreshold}}
82           failureThreshold: {{ index .Values.livenessProbe.failureThreshold}}
83         ports:
84         - containerPort: {{ index .Values.containerPort }}
85           name: {{ .Values.service.portName }}
86           protocol: TCP
87       volumes: {{ include "so.certificate.volumes" . | nindent 6 }}
88       - name: logs
89         emptyDir: {}
90       - name: config
91         configMap:
92             name: {{ include "common.fullname" . }}-app-configmap
93       - name:  {{ include "common.fullname" . }}-truststore
94         secret:
95           secretName: {{ include "common.release" . }}-so-truststore-secret
96       imagePullSecrets:
97         - name: "{{ include "common.namespace" . }}-docker-registry-key"