1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-18 06:04:06 +03:00

ctdb-scripts: Only run unhealthy call-out when passing threshold

For memory usage, no need to dump all of this data on every failed
monitor event.  The first call will be enough to diagnose the problem.
The node will then go unhealthy, drop clients and memory usage should
then drop.

Signed-off-by: Martin Schwenke <martin@meltin.net>
Reviewed-by: Amitay Isaacs <amitay@gmail.com>

Autobuild-User(master): Amitay Isaacs <amitay@samba.org>
Autobuild-Date(master): Fri Jul 22 07:32:54 UTC 2022 on sn-devel-184
This commit is contained in:
Martin Schwenke 2022-06-10 10:32:01 +10:00 committed by Amitay Isaacs
parent 36bd6fd01f
commit e396eb9fbc

View File

@ -44,13 +44,23 @@ check_thresholds()
# script_state_dir set by ctdb_setup_state_dir()
# shellcheck disable=SC2154
_cache="${script_state_dir}/cache_${_t}"
if [ -r "$_cache" ]; then
read -r _prev <"$_cache"
else
_prev=0
fi
if validate_percentage "$_unhealthy_threshold" "$_thing"; then
if [ "$_usage" -ge "$_unhealthy_threshold" ]; then
printf 'ERROR: %s utilization %d%% >= threshold %d%%\n' \
"$_thing" \
"$_usage" \
"$_unhealthy_threshold"
eval "$_unhealthy_callout"
# Only run unhealthy callout if passing the
# unhealthy threshold. That is, if the
# previous usage was below the threshold.
if [ "$_prev" -lt "$_unhealthy_threshold" ]; then
eval "$_unhealthy_callout"
fi
echo "$_usage" >"$_cache"
exit 1
fi
@ -58,11 +68,6 @@ check_thresholds()
if validate_percentage "$_warn_threshold" "$_thing"; then
if [ "$_usage" -ge "$_warn_threshold" ]; then
if [ -r "$_cache" ]; then
read -r _prev <"$_cache"
else
_prev=""
fi
if [ "$_usage" = "$_prev" ]; then
return
fi