scripts-configmap.yaml 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. apiVersion: v1
  2. kind: ConfigMap
  3. metadata:
  4. name: {{ template "kafka.fullname" . }}-scripts
  5. labels: {{- include "common.labels.standard" . | nindent 4 }}
  6. {{- if .Values.commonLabels }}
  7. {{- include "common.tplvalues.render" ( dict "value" .Values.commonLabels "context" $ ) | nindent 4 }}
  8. {{- end }}
  9. {{- if .Values.commonAnnotations }}
  10. annotations: {{- include "common.tplvalues.render" ( dict "value" .Values.commonAnnotations "context" $ ) | nindent 4 }}
  11. {{- end }}
  12. data:
  13. {{- $fullname := include "kafka.fullname" . }}
  14. {{- $releaseNamespace := .Release.Namespace }}
  15. {{- $clusterDomain := .Values.clusterDomain }}
  16. {{- $interBrokerPort := .Values.service.internalPort }}
  17. {{- $clientPort := .Values.service.port }}
  18. {{- $jksTruststoreSecret := coalesce .Values.auth.tls.jksTruststoreSecret .Values.auth.jksTruststoreSecret -}}
  19. {{- $jksTruststore := coalesce .Values.auth.tls.jksTruststore .Values.auth.jksTruststore -}}
  20. {{- $jksKeystoreSAN := coalesce .Values.auth.tls.jksKeystoreSAN .Values.auth.jksKeystoreSAN -}}
  21. {{- if .Values.externalAccess.autoDiscovery.enabled }}
  22. auto-discovery.sh: |-
  23. #!/bin/bash
  24. SVC_NAME="${MY_POD_NAME}-external"
  25. {{- if eq .Values.externalAccess.service.type "LoadBalancer" }}
  26. # Auxiliary functions
  27. retry_while() {
  28. local -r cmd="${1:?cmd is missing}"
  29. local -r retries="${2:-12}"
  30. local -r sleep_time="${3:-5}"
  31. local return_value=1
  32. read -r -a command <<< "$cmd"
  33. for ((i = 1 ; i <= retries ; i+=1 )); do
  34. "${command[@]}" && return_value=0 && break
  35. sleep "$sleep_time"
  36. done
  37. return $return_value
  38. }
  39. k8s_svc_lb_ip() {
  40. local namespace=${1:?namespace is missing}
  41. local service=${2:?service is missing}
  42. local service_ip=$(kubectl get svc "$service" -n "$namespace" -o jsonpath="{.status.loadBalancer.ingress[0].ip}")
  43. local service_hostname=$(kubectl get svc "$service" -n "$namespace" -o jsonpath="{.status.loadBalancer.ingress[0].hostname}")
  44. if [[ -n ${service_ip} ]]; then
  45. echo "${service_ip}"
  46. else
  47. echo "${service_hostname}"
  48. fi
  49. }
  50. k8s_svc_lb_ip_ready() {
  51. local namespace=${1:?namespace is missing}
  52. local service=${2:?service is missing}
  53. [[ -n "$(k8s_svc_lb_ip "$namespace" "$service")" ]]
  54. }
  55. # Wait until LoadBalancer IP is ready
  56. retry_while "k8s_svc_lb_ip_ready {{ $releaseNamespace }} $SVC_NAME" || exit 1
  57. # Obtain LoadBalancer external IP
  58. k8s_svc_lb_ip "{{ $releaseNamespace }}" "$SVC_NAME" | tee "$SHARED_FILE"
  59. {{- else if eq .Values.externalAccess.service.type "NodePort" }}
  60. k8s_svc_node_port() {
  61. local namespace=${1:?namespace is missing}
  62. local service=${2:?service is missing}
  63. local index=${3:-0}
  64. local node_port="$(kubectl get svc "$service" -n "$namespace" -o jsonpath="{.spec.ports[$index].nodePort}")"
  65. echo "$node_port"
  66. }
  67. k8s_svc_node_port "{{ $releaseNamespace }}" "$SVC_NAME" | tee "$SHARED_FILE"
  68. {{- end }}
  69. {{- end }}
  70. setup.sh: |-
  71. #!/bin/bash
  72. ID="${MY_POD_NAME#"{{ $fullname }}-"}"
  73. if [[ -f "/bitnami/kafka/data/meta.properties" ]]; then
  74. export KAFKA_CFG_BROKER_ID="$(grep "broker.id" /bitnami/kafka/data/meta.properties | awk -F '=' '{print $2}')"
  75. else
  76. export KAFKA_CFG_BROKER_ID="$((ID + {{ .Values.minBrokerId }}))"
  77. fi
  78. {{- if .Values.externalAccess.enabled }}
  79. # Configure external ip and port
  80. {{- if eq .Values.externalAccess.service.type "LoadBalancer" }}
  81. {{- if .Values.externalAccess.autoDiscovery.enabled }}
  82. export EXTERNAL_ACCESS_IP="$(<${SHARED_FILE})"
  83. {{- else }}
  84. export EXTERNAL_ACCESS_IP=$(echo '{{ .Values.externalAccess.service.loadBalancerIPs }}' | tr -d '[]' | cut -d ' ' -f "$(($ID + 1))")
  85. {{- end }}
  86. export EXTERNAL_ACCESS_PORT={{ .Values.externalAccess.service.port }}
  87. {{- else if eq .Values.externalAccess.service.type "NodePort" }}
  88. {{- if or .Values.externalAccess.service.useHostIPs .Values.externalAccess.autoDiscovery.enabled }}
  89. export EXTERNAL_ACCESS_IP="${HOST_IP}"
  90. {{- else if .Values.externalAccess.service.domain }}
  91. export EXTERNAL_ACCESS_IP={{ .Values.externalAccess.service.domain }}
  92. {{- else }}
  93. export EXTERNAL_ACCESS_IP=$(curl -s https://ipinfo.io/ip)
  94. {{- end }}
  95. {{- if .Values.externalAccess.autoDiscovery.enabled }}
  96. export EXTERNAL_ACCESS_PORT="$(<${SHARED_FILE})"
  97. {{- else }}
  98. export EXTERNAL_ACCESS_PORT=$(echo '{{ .Values.externalAccess.service.nodePorts }}' | tr -d '[]' | cut -d ' ' -f "$(($ID + 1))")
  99. {{- end }}
  100. {{- end }}
  101. # Configure Kafka advertised listeners
  102. {{- if .Values.advertisedListeners }}
  103. export KAFKA_CFG_ADVERTISED_LISTENERS={{ join "," .Values.advertisedListeners }}
  104. {{- else }}
  105. export KAFKA_CFG_ADVERTISED_LISTENERS="INTERNAL://${MY_POD_NAME}.{{ $fullname }}-headless.{{ $releaseNamespace }}.svc.{{ $clusterDomain }}:{{ $interBrokerPort }},CLIENT://${MY_POD_NAME}.{{ $fullname }}-headless.{{ $releaseNamespace }}.svc.{{ $clusterDomain }}:{{ $clientPort }},EXTERNAL://${EXTERNAL_ACCESS_IP}:${EXTERNAL_ACCESS_PORT}"
  106. {{- end }}
  107. {{- end }}
  108. {{- if (include "kafka.tlsEncryption" .) }}
  109. mkdir -p /opt/bitnami/kafka/config/certs
  110. {{- if eq .Values.auth.tls.type "jks" }}
  111. JKS_TRUSTSTORE={{ printf "/%s/%s" (ternary "certs" "truststore" (empty $jksTruststoreSecret)) (default "kafka.truststore.jks" $jksTruststore) | quote }}
  112. JKS_KEYSTORE={{ printf "/certs/%s" (default "kafka-${ID}.keystore.jks" $jksKeystoreSAN) | quote }}
  113. if [[ -f "$JKS_TRUSTSTORE" ]] && [[ -f "$JKS_KEYSTORE" ]]; then
  114. cp "$JKS_TRUSTSTORE" "/opt/bitnami/kafka/config/certs/kafka.truststore.jks"
  115. cp "$JKS_KEYSTORE" "/opt/bitnami/kafka/config/certs/kafka.keystore.jks"
  116. else
  117. echo "Couldn't find the expected Java Key Stores (JKS) files! They are mandatory when encryption via TLS is enabled."
  118. exit 1
  119. fi
  120. {{- else if eq .Values.auth.tls.type "pem" }}
  121. PEM_CA="/certs/kafka.truststore.pem"
  122. PEM_CERT="/certs/kafka-${ID}.keystore.pem"
  123. PEM_KEY="/certs/kafka-${ID}.keystore.key"
  124. if [[ -f "$PEM_CA" ]] && [[ -f "$PEM_CERT" ]] && [[ -f "$PEM_KEY" ]]; then
  125. cp "$PEM_CA" "/opt/bitnami/kafka/config/certs/kafka.truststore.pem"
  126. cp "$PEM_CERT" "/opt/bitnami/kafka/config/certs/kafka.keystore.pem"
  127. # Ensure the key used PEM format with PKCS#8
  128. openssl pkcs8 -topk8 -nocrypt -in "$PEM_KEY" > "/opt/bitnami/kafka/config/certs/kafka.keystore.key"
  129. else
  130. echo "Couldn't find the expected PEM files! They are mandatory when encryption via TLS is enabled."
  131. exit 1
  132. fi
  133. {{- end }}
  134. {{- end }}
  135. exec /entrypoint.sh /run.sh