NIFI-8215 --wait-for-init in nifi.sh refactored for POSIX sh

This fixes #4814

Signed-off-by: Joey Frazee <jfrazee@apache.org>
This commit is contained in:
Peter Gyori 2021-02-09 16:13:37 +01:00 committed by Joey Frazee
parent 13d6da73ac
commit b9b131239c
1 changed files with 14 additions and 17 deletions

View File

@ -248,9 +248,8 @@ SERVICEDESCRIPTOR
} }
is_nonzero_integer() { is_nonzero_integer() {
regex='^[1-9][0-9]*$'
if [[ $1 =~ $regex ]]; then if [ "$1" -gt 0 ] 2>/dev/null; then
return 0 return 0
else else
return 1 return 1
@ -262,9 +261,9 @@ run() {
BOOTSTRAP_CONF="${BOOTSTRAP_CONF_DIR}/bootstrap.conf"; BOOTSTRAP_CONF="${BOOTSTRAP_CONF_DIR}/bootstrap.conf";
BOOTSTRAP_LIBS="${NIFI_HOME}/lib/bootstrap/*" BOOTSTRAP_LIBS="${NIFI_HOME}/lib/bootstrap/*"
declare -ir WAIT_FOR_INIT_DEFAULT_TIMEOUT=900 WAIT_FOR_INIT_DEFAULT_TIMEOUT=900
declare -ir WAIT_FOR_INIT_SLEEP_TIME=2 WAIT_FOR_INIT_SLEEP_TIME=2
declare -ir WAIT_FOR_INIT_FEEDBACK_INTERVAL=10 WAIT_FOR_INIT_FEEDBACK_INTERVAL=10
run_as_user=$(grep '^\s*run.as' "${BOOTSTRAP_CONF}" | cut -d'=' -f2) run_as_user=$(grep '^\s*run.as' "${BOOTSTRAP_CONF}" | cut -d'=' -f2)
# If the run as user is the same as that starting the process, ignore this configuration # If the run as user is the same as that starting the process, ignore this configuration
@ -363,32 +362,30 @@ run() {
if [ "$2" = "--wait-for-init" ]; then if [ "$2" = "--wait-for-init" ]; then
declare -i wait_timeout
if is_nonzero_integer "$3" ; then if is_nonzero_integer "$3" ; then
wait_timeout="$3" wait_timeout="$3"
else else
wait_timeout=$WAIT_FOR_INIT_DEFAULT_TIMEOUT wait_timeout=$WAIT_FOR_INIT_DEFAULT_TIMEOUT
fi fi
declare -i starttime=$(date +%s) starttime=$(date +%s)
declare -i endtime=$starttime+$wait_timeout endtime=$(($starttime+$wait_timeout))
declare -i current_time=$starttime current_time=$starttime
declare -i time_at_previous_loop time_since_feedback=0
declare -i time_since_feedback=0 not_running_counter=0
declare -i not_running_counter=0
is_nifi_loaded="false" # 3 possible values: "true", "false", "not_running". "not_running" means NiFi has not been started. is_nifi_loaded="false" # 3 possible values: "true", "false", "not_running". "not_running" means NiFi has not been started.
while [ "$is_nifi_loaded" != "true" ]; do while [ "$is_nifi_loaded" != "true" ]; do
time_at_previous_loop=$current_time time_at_previous_loop=$current_time
current_time=$(date +%s) current_time=$(date +%s)
if (( current_time >= endtime )); then if [ "$current_time" -ge "$endtime" ]; then
echo "Exited the script due to --wait-for-init timeout" echo "Exited the script due to --wait-for-init timeout"
break; break;
fi fi
((time_since_feedback += current_time - time_at_previous_loop)) time_since_feedback=$(($time_since_feedback+($current_time-$time_at_previous_loop)))
if (( time_since_feedback >= WAIT_FOR_INIT_FEEDBACK_INTERVAL )); then if [ "$time_since_feedback" -ge "$WAIT_FOR_INIT_FEEDBACK_INTERVAL" ]; then
time_since_feedback=0 time_since_feedback=0
echo "NiFi has not fully initialized yet..." echo "NiFi has not fully initialized yet..."
fi fi
@ -396,8 +393,8 @@ run() {
is_nifi_loaded=$( eval "cd ${NIFI_HOME} && ${run_bootstrap_cmd} is_loaded" ) is_nifi_loaded=$( eval "cd ${NIFI_HOME} && ${run_bootstrap_cmd} is_loaded" )
if [ "$is_nifi_loaded" = "not_running" ]; then if [ "$is_nifi_loaded" = "not_running" ]; then
((not_running_counter++)) not_running_counter=$(($not_running_counter+1))
if (( not_running_counter >= 3 )); then if [ "$not_running_counter" -ge 3 ]; then
echo "NiFi is not running. Stopped waiting for it to initialize." echo "NiFi is not running. Stopped waiting for it to initialize."
break; break;
fi fi