From e29d2dbcc579b52c7b97ff0ff7c9af33c9c41343 Mon Sep 17 00:00:00 2001 From: Taehyun Kim Date: Thu, 2 May 2019 12:12:45 +0900 Subject: [PATCH] rewrite without voting_config_exclusion https://github.com/elastic/helm-charts/issues/63#issuecomment-465081133 --- elasticsearch/templates/statefulset.yaml | 49 ++++++++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/elasticsearch/templates/statefulset.yaml b/elasticsearch/templates/statefulset.yaml index 3aaebfd66..55a0c2871 100644 --- a/elasticsearch/templates/statefulset.yaml +++ b/elasticsearch/templates/statefulset.yaml @@ -216,3 +216,52 @@ spec: {{- if .Values.extraVolumeMounts }} {{ tpl .Values.extraVolumeMounts . | indent 10 }} {{- end }} + {{- if eq .Values.roles.master "true" }} + - name: graceful-termination-handler + image: "{{ .Values.image }}:{{ .Values.imageTag }}" + imagePullPolicy: "{{ .Values.imagePullPolicy }}" + command: + - "sh" + - -c + - | + #!/usr/bin/env bash + set -eo pipefail + + http () { + local path="${1}" + if [ -n "${ELASTIC_USERNAME}" ] && [ -n "${ELASTIC_PASSWORD}" ]; then + BASIC_AUTH="-u ${ELASTIC_USERNAME}:${ELASTIC_PASSWORD}" + else + BASIC_AUTH='' + fi + curl -XGET -s -k --fail ${BASIC_AUTH} {{ .Values.protocol }}://${MASTER_SERVICE}:{{ .Values.httpPort }}${path} + } + + cleanup () { + while true ; do + local master="$(http "/_cat/master")" + if [[ $master == *"{{ template "uname" . }}"* && $master != *"${NODE_NAME}"* ]]; then + echo "This node is not master." + break + fi + echo "This node is still master, waiting gracefully for it to step down" + sleep 1 + done + + exit 0 + } + + trap cleanup SIGTERM + + while true; do + sleep 60 & + wait $! + done + env: + - name: NODE_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + - name: MASTER_SERVICE + value: "{{ template "masterService" . }}-headless" + {{- end }}