195 lines
6.0 KiB
YAML
195 lines
6.0 KiB
YAML
{{- /*
|
|
Copyright Broadcom, Inc. All Rights Reserved.
|
|
SPDX-License-Identifier: APACHE-2.0
|
|
*/}}
|
|
|
|
apiVersion: v1
|
|
kind: ConfigMap
|
|
metadata:
|
|
name: {{ printf "%s-health" (include "common.names.fullname" .) }}
|
|
namespace: {{ include "common.names.namespace" . | quote }}
|
|
labels: {{- include "common.labels.standard" ( dict "customLabels" .Values.commonLabels "context" $ ) | nindent 4 }}
|
|
{{- if .Values.commonAnnotations }}
|
|
annotations: {{- include "common.tplvalues.render" ( dict "value" .Values.commonAnnotations "context" $ ) | nindent 4 }}
|
|
{{- end }}
|
|
data:
|
|
ping_readiness_local.sh: |-
|
|
#!/bin/bash
|
|
|
|
[[ -f $VALKEY_PASSWORD_FILE ]] && export VALKEY_PASSWORD="$(< "${VALKEY_PASSWORD_FILE}")"
|
|
[[ -n "$VALKEY_PASSWORD" ]] && export REDISCLI_AUTH="$VALKEY_PASSWORD"
|
|
response=$(
|
|
timeout -s 15 $1 \
|
|
valkey-cli \
|
|
-h localhost \
|
|
{{- if .Values.tls.enabled }}
|
|
-p $VALKEY_TLS_PORT \
|
|
--tls \
|
|
--cacert {{ template "valkey.tlsCACert" . }} \
|
|
{{- if .Values.tls.authClients }}
|
|
--cert {{ template "valkey.tlsCert" . }} \
|
|
--key {{ template "valkey.tlsCertKey" . }} \
|
|
{{- end }}
|
|
{{- else }}
|
|
-p $VALKEY_PORT \
|
|
{{- end }}
|
|
ping
|
|
)
|
|
if [ "$?" -eq "124" ]; then
|
|
echo "Timed out"
|
|
exit 1
|
|
fi
|
|
if [ "$response" != "PONG" ]; then
|
|
echo "$response"
|
|
exit 1
|
|
fi
|
|
ping_liveness_local.sh: |-
|
|
#!/bin/bash
|
|
|
|
[[ -f $VALKEY_PASSWORD_FILE ]] && export VALKEY_PASSWORD="$(< "${VALKEY_PASSWORD_FILE}")"
|
|
[[ -n "$VALKEY_PASSWORD" ]] && export REDISCLI_AUTH="$VALKEY_PASSWORD"
|
|
response=$(
|
|
timeout -s 15 $1 \
|
|
valkey-cli \
|
|
-h localhost \
|
|
{{- if .Values.tls.enabled }}
|
|
-p $VALKEY_TLS_PORT \
|
|
--tls \
|
|
--cacert {{ template "valkey.tlsCACert" . }} \
|
|
{{- if .Values.tls.authClients }}
|
|
--cert {{ template "valkey.tlsCert" . }} \
|
|
--key {{ template "valkey.tlsCertKey" . }} \
|
|
{{- end }}
|
|
{{- else }}
|
|
-p $VALKEY_PORT \
|
|
{{- end }}
|
|
ping
|
|
)
|
|
if [ "$?" -eq "124" ]; then
|
|
echo "Timed out"
|
|
exit 1
|
|
fi
|
|
responseFirstWord=$(echo $response | head -n1 | awk '{print $1;}')
|
|
if [ "$response" != "PONG" ] && [ "$responseFirstWord" != "LOADING" ] && [ "$responseFirstWord" != "MASTERDOWN" ]; then
|
|
echo "$response"
|
|
exit 1
|
|
fi
|
|
{{- if .Values.sentinel.enabled }}
|
|
ping_sentinel.sh: |-
|
|
#!/bin/bash
|
|
|
|
{{- if .Values.auth.sentinel }}
|
|
[[ -f $VALKEY_PASSWORD_FILE ]] && export VALKEY_PASSWORD="$(< "${VALKEY_PASSWORD_FILE}")"
|
|
[[ -n "$VALKEY_PASSWORD" ]] && export REDISCLI_AUTH="$VALKEY_PASSWORD"
|
|
{{- end }}
|
|
response=$(
|
|
timeout -s 15 $1 \
|
|
valkey-cli \
|
|
-h localhost \
|
|
{{- if .Values.tls.enabled }}
|
|
-p $VALKEY_SENTINEL_TLS_PORT_NUMBER \
|
|
--tls \
|
|
--cacert "$VALKEY_SENTINEL_TLS_CA_FILE" \
|
|
{{- if .Values.tls.authClients }}
|
|
--cert "$VALKEY_SENTINEL_TLS_CERT_FILE" \
|
|
--key "$VALKEY_SENTINEL_TLS_KEY_FILE" \
|
|
{{- end }}
|
|
{{- else }}
|
|
-p $VALKEY_SENTINEL_PORT \
|
|
{{- end }}
|
|
ping
|
|
)
|
|
if [ "$?" -eq "124" ]; then
|
|
echo "Timed out"
|
|
exit 1
|
|
fi
|
|
if [ "$response" != "PONG" ]; then
|
|
echo "$response"
|
|
exit 1
|
|
fi
|
|
parse_sentinels.awk: |-
|
|
/ip/ {FOUND_IP=1}
|
|
/port/ {FOUND_PORT=1}
|
|
/runid/ {FOUND_RUNID=1}
|
|
!/ip|port|runid/ {
|
|
if (FOUND_IP==1) {
|
|
IP=$1; FOUND_IP=0;
|
|
}
|
|
else if (FOUND_PORT==1) {
|
|
PORT=$1;
|
|
FOUND_PORT=0;
|
|
} else if (FOUND_RUNID==1) {
|
|
printf "\nsentinel known-sentinel {{ .Values.sentinel.primarySet }} %s %s %s", IP, PORT, $0; FOUND_RUNID=0;
|
|
}
|
|
}
|
|
{{- end }}
|
|
ping_readiness_primary.sh: |-
|
|
#!/bin/bash
|
|
|
|
[[ -f $VALKEY_PRIMARY_PASSWORD_FILE ]] && export VALKEY_PRIMARY_PASSWORD="$(< "${VALKEY_PRIMARY_PASSWORD_FILE}")"
|
|
[[ -n "$VALKEY_PRIMARY_PASSWORD" ]] && export REDISCLI_AUTH="$VALKEY_PRIMARY_PASSWORD"
|
|
response=$(
|
|
timeout -s 15 $1 \
|
|
valkey-cli \
|
|
-h $VALKEY_PRIMARY_HOST \
|
|
-p $VALKEY_PRIMARY_PORT_NUMBER \
|
|
{{- if .Values.tls.enabled }}
|
|
--tls \
|
|
--cacert {{ template "valkey.tlsCACert" . }} \
|
|
{{- if .Values.tls.authClients }}
|
|
--cert {{ template "valkey.tlsCert" . }} \
|
|
--key {{ template "valkey.tlsCertKey" . }} \
|
|
{{- end }}
|
|
{{- end }}
|
|
ping
|
|
)
|
|
if [ "$?" -eq "124" ]; then
|
|
echo "Timed out"
|
|
exit 1
|
|
fi
|
|
if [ "$response" != "PONG" ]; then
|
|
echo "$response"
|
|
exit 1
|
|
fi
|
|
ping_liveness_primary.sh: |-
|
|
#!/bin/bash
|
|
|
|
[[ -f $VALKEY_PRIMARY_PASSWORD_FILE ]] && export VALKEY_PRIMARY_PASSWORD="$(< "${VALKEY_PRIMARY_PASSWORD_FILE}")"
|
|
[[ -n "$VALKEY_PRIMARY_PASSWORD" ]] && export REDISCLI_AUTH="$VALKEY_PRIMARY_PASSWORD"
|
|
response=$(
|
|
timeout -s 15 $1 \
|
|
valkey-cli \
|
|
-h $VALKEY_PRIMARY_HOST \
|
|
-p $VALKEY_PRIMARY_PORT_NUMBER \
|
|
{{- if .Values.tls.enabled }}
|
|
--tls \
|
|
--cacert {{ template "valkey.tlsCACert" . }} \
|
|
{{- if .Values.tls.authClients }}
|
|
--cert {{ template "valkey.tlsCert" . }} \
|
|
--key {{ template "valkey.tlsCertKey" . }} \
|
|
{{- end }}
|
|
{{- end }}
|
|
ping
|
|
)
|
|
if [ "$?" -eq "124" ]; then
|
|
echo "Timed out"
|
|
exit 1
|
|
fi
|
|
responseFirstWord=$(echo $response | head -n1 | awk '{print $1;}')
|
|
if [ "$response" != "PONG" ] && [ "$responseFirstWord" != "LOADING" ]; then
|
|
echo "$response"
|
|
exit 1
|
|
fi
|
|
ping_readiness_local_and_primary.sh: |-
|
|
script_dir="$(dirname "$0")"
|
|
exit_status=0
|
|
"$script_dir/ping_readiness_local.sh" $1 || exit_status=$?
|
|
"$script_dir/ping_readiness_primary.sh" $1 || exit_status=$?
|
|
exit $exit_status
|
|
ping_liveness_local_and_primary.sh: |-
|
|
script_dir="$(dirname "$0")"
|
|
exit_status=0
|
|
"$script_dir/ping_liveness_local.sh" $1 || exit_status=$?
|
|
"$script_dir/ping_liveness_primary.sh" $1 || exit_status=$?
|
|
exit $exit_status
|