DCAE R6 updates
[oom.git] / kubernetes / dcaegen2 / components / dcae-inventory-api / templates / deployment.yaml
1 #============LICENSE_START========================================================
2 # ================================================================================
3 # Copyright (c) 2019 AT&T Intellectual Property. All rights reserved.
4 # ================================================================================
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at
8 #
9 #     http://www.apache.org/licenses/LICENSE-2.0
10 #
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
16 # ============LICENSE_END=========================================================
17
18 apiVersion: extensions/v1beta1
19 kind: Deployment
20 metadata:
21   name: {{ include "common.fullname" . }}
22   namespace: {{ include "common.namespace" . }}
23   labels:
24     app: {{ include "common.name" . }}
25     chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
26     release: {{ include "common.release" . }}
27     heritage: {{ .Release.Service }}
28 spec:
29   replicas: 1
30   template:
31     metadata:
32       labels:
33         app: {{ include "common.name" . }}
34         release: {{ include "common.release" . }}
35     spec:
36       initContainers:
37         - name: {{ include "common.name" . }}-readiness
38           image: {{ .Values.global.readinessRepository }}/{{ .Values.global.readinessImage }}
39           imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
40           command:
41             - /root/ready.py
42           args:
43             - --container-name
44             - {{ .Values.postgres.nameOverride }}
45             - "-t"
46             - "15"
47           env:
48           - name: NAMESPACE
49             valueFrom:
50               fieldRef:
51                 apiVersion: v1
52                 fieldPath: metadata.namespace
53         - name: init-tls
54           env:
55           - name: aaf_locator_fqdn
56             value: dcae
57           - name: POD_IP
58             valueFrom:
59               fieldRef:
60                 apiVersion: v1
61                 fieldPath: status.podIP
62           image: {{ .Values.global.tlsRepository }}/{{ .Values.global.tlsImage }}
63           imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
64           resources: {}
65           volumeMounts:
66             - mountPath: /opt/app/osaaf
67               name: tls-info
68       containers:
69         - name: {{ include "common.name" . }}
70           image: "{{ include "common.repository" . }}/{{ .Values.image }}"
71           imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
72           # Assumes that the Docker image is built with ENTRYPOINT set to
73           # ["java", "-jar", "/opt/inventory-api-x.y.z.jar", "server"]
74           # where "x.y.z" is the version number (matches the Docker image version number)
75           # The arg below adds a parameter, the path to a config file.
76           # This tells the inventory-api app to get its configuration from the file
77           # rather than querying Consul.
78           args:
79             - "/opt/config.json"
80           resources:
81 {{ include "common.resources" . | indent 12 }}
82           ports:
83           - containerPort: {{ .Values.service.internalPort }}
84           # disable liveness probe when breakpoints set in debugger
85           # so K8s doesn't restart unresponsive container
86           {{- if eq .Values.liveness.enabled true }}
87           livenessProbe:
88             tcpSocket:
89               port: {{ .Values.service.internalPort }}
90             initialDelaySeconds: {{ .Values.liveness.initialDelaySeconds }}
91             periodSeconds: {{ .Values.liveness.periodSeconds }}
92           {{ end }}
93           readinessProbe:
94             httpGet:
95               path: {{ .Values.readiness.path }}
96               port: {{ .Values.service.internalPort }}
97               scheme: {{ .Values.readiness.scheme }}
98             initialDelaySeconds: {{ .Values.readiness.initialDelaySeconds }}
99             periodSeconds: {{ .Values.readiness.periodSeconds }}
100           volumeMounts:
101             - name: {{  include "common.fullname" . }}-inv-config
102               mountPath: /opt/config.json
103               subPath: config.json
104             - mountPath: /opt/cert/
105               name: tls-info
106             - mountPath: /opt/logs/
107               name: component-log
108           env:
109             - name: CONSUL_HOST
110               value: consul.{{ include "common.namespace" . }}
111         - name: {{ include "common.name" . }}-filebeat
112           env:
113             - name: POD_IP
114               valueFrom:
115                 fieldRef:
116                   apiVersion: v1
117                   fieldPath: status.podIP
118           image: {{ .Values.global.loggingRepository }}/{{ .Values.global.loggingImage }}
119           imagePullPolicy: IfNotPresent
120           resources: {}
121           volumeMounts:
122           - mountPath: /var/log/onap/inventory
123             name: component-log
124           - mountPath: /usr/share/filebeat/data
125             name: filebeat-data
126           - mountPath: /usr/share/filebeat/filebeat.yml
127             name: filebeat-conf
128             subPath: filebeat.yml
129       volumes:
130         - emptyDir: {}
131           name: component-log
132         - emptyDir: {}
133           name: filebeat-data
134         - configMap:
135             defaultMode: 420
136             name: {{ include "common.fullname" . }}-filebeat-configmap
137           name: filebeat-conf
138         - name: {{ include "common.fullname" . }}-inv-config
139           configMap:
140             name: {{ include "common.fullname" . }}-configmap
141         - emptyDir: {}
142           name: tls-info
143       imagePullSecrets:
144       - name: "{{ include "common.namespace" . }}-docker-registry-key"
145