1 # Copyright © 2017 Amdocs, Bell Canada
2 # Modifications Copyright © 2018 AT&T
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
8 # http://www.apache.org/licenses/LICENSE-2.0
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.
16 apiVersion: apps/v1beta1
19 name: {{ include "common.fullname" . }}
20 namespace: {{ include "common.namespace" . }}
22 app: {{ include "common.name" . }}
23 chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
24 release: {{ .Release.Name }}
25 heritage: {{ .Release.Service }}
27 serviceName: {{ .Values.service.name }}
28 replicas: {{ .Values.replicaCount }}
29 podManagementPolicy: Parallel
33 app: {{ include "common.name" . }}
34 release: {{ .Release.Name }}
37 preferredDuringSchedulingIgnoredDuringExecution:
45 - {{ include "common.name" . }}
46 topologyKey: "kubernetes.io/hostname"
47 {{- if .Values.nodeAffinity }}
49 {{ toYaml .Values.nodeAffinity | indent 10 }}
52 - name: {{ include "common.name" . }}-initcontainer
53 image: "{{ .Values.global.ubuntuInitRepository }}/{{ .Values.ubuntuInitImage }}"
54 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
59 - {{ .Values.zookeeper.name }}
65 fieldPath: metadata.namespace
66 image: "{{ .Values.global.readinessRepository }}/{{ .Values.global.readinessImage }}"
67 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
68 name: {{ include "common.name" . }}-readiness
70 - name: {{ include "common.name" . }}
71 image: "{{ include "common.repository" . }}/{{ .Values.image }}"
72 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
74 {{ include "common.resources" . | indent 12 }}
76 - containerPort: {{ .Values.service.internalPort }}
77 {{ if eq .Values.liveness.enabled true }}
80 port: {{ .Values.service.internalPort }}
81 initialDelaySeconds: {{ .Values.liveness.initialDelaySeconds }}
82 periodSeconds: {{ .Values.liveness.periodSeconds }}
86 port: {{ .Values.service.internalPort }}
87 initialDelaySeconds: {{ .Values.readiness.initialDelaySeconds }}
88 periodSeconds: {{ .Values.readiness.periodSeconds }}
94 fieldPath: metadata.name
95 - name: HOST_NAMESPACE
99 fieldPath: metadata.namespace
100 - name: KAFKA_ZOOKEEPER_CONNECT
101 value: "{{.Values.zookeeper.name}}:{{.Values.zookeeper.port}}"
102 - name: KAFKA_LISTENER_SECURITY_PROTOCOL_MAP
103 value: "INTERNAL_PLAINTEXT:PLAINTEXT,EXTERNAL_PLAINTEXT:PLAINTEXT"
104 - name: KAFKA_ADVERTISED_LISTENERS
105 value: "INTERNAL_PLAINTEXT://$(HOST_NAME).{{ .Values.service.name }}.$(HOST_NAMESPACE).svc.cluster.local:{{ .Values.service.internalPort}}"
106 - name: KAFKA_LISTENERS
107 value: "INTERNAL_PLAINTEXT://0.0.0.0:{{.Values.service.internalPort}}"
108 - name: KAFKA_INTER_BROKER_LISTENER_NAME
109 value: "INTERNAL_PLAINTEXT"
110 - name: KAFKA_LOG_DIRS
112 - name: BROKER_ID_COMMAND
113 value: "hostname | awk -F '-' '{print $NF}'"
114 - name: KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR
115 value: "{{ .Values.replicaCount }}"
116 - name: KAFKA_DEFAULT_REPLICATION_FACTOR
117 value: "{{ .Values.replicaCount }}"
118 - name: KAFKA_NUM_PARTITIONS
119 value: "{{ .Values.defaultpartitions }}"
121 - mountPath: /etc/localtime
124 - mountPath: /var/run/docker.sock
128 {{- if .Values.tolerations }}
130 {{ toYaml .Values.tolerations | indent 10 }}
136 - name: docker-socket
138 path: /var/run/docker.sock
139 {{ if not .Values.persistence.enabled }}
143 volumeClaimTemplates:
147 app: {{ include "common.fullname" . }}
148 chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
149 release: "{{ .Release.Name }}"
150 heritage: "{{ .Release.Service }}"
153 - {{ .Values.persistence.accessMode | quote }}
156 storage: {{ .Values.persistence.size | quote }}
159 release: "{{ .Release.Name }}"
160 app: {{ .Values.service.name }}
161 chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
162 heritage: "{{ .Release.Service }}"
165 - name: "{{ include "common.namespace" . }}-docker-registry-key"