superlint/.automation/test/ansible/roles/ghe_initialize/templates/ghe-config-apply.sh

194 lines
6.5 KiB
Bash
Raw Normal View History

2020-06-23 11:02:45 -05:00
#!/usr/bin/env bash
2020-02-04 08:49:58 -06:00
################################################################################
# Script to run ghe-config-apply on the primary GHES instance
# and wait for any previous runs to complete
################################################################################
###########
# Globals #
###########
2020-11-06 23:10:09 +01:00
GHE_CONFIG_PID='/var/run/ghe-config.pid' # PID file when a config is running
GHE_APPLY_COMMAND='ghe-config-apply' # Command running when a config run
SLEEP_SECONDS=20 # Seconds to sleep before next check
PID_CHECK_LIMIT=15 # How many times to check the pid before moving on
PID_CHECK=0 # Count of times to check the pid
PROCESS_CHECK_LIMIT=15 # How many times to check the process before moving on
PROCESS_CHECK=0 # Count of times to check the process
2020-02-04 08:49:58 -06:00
################################################################################
########################### SUB ROUTINES BELOW #################################
################################################################################
################################################################################
#### Function CheckShellErrors #################################################
CheckShellErrors() {
COUNTER=$1
##############################
# Check the shell for errors #
##############################
if [ "${ERROR_CODE}" -ne 0 ]; then
error "Failed to sleep!"
error "[${SLEEP_CMD}]"
info "Will try to call apply as last effort..."
####################################
# Call config apply as last effort #
####################################
RunConfigApply
else
#####################
# Increment counter #
#####################
((COUNTER++))
##########################################
# Try to check for the pid/process again #
##########################################
$2
fi
return "$COUNTER"
}
################################################################################
2020-02-04 08:49:58 -06:00
#### Function CheckGHEPid ######################################################
2020-11-06 23:10:09 +01:00
CheckGHEPid() {
2020-02-04 08:49:58 -06:00
##################################
# Check to prevent infinite loop #
##################################
2020-07-21 12:09:07 -05:00
if [ ${PID_CHECK} -gt ${PID_CHECK_LIMIT} ]; then
2020-02-04 08:49:58 -06:00
# Over the limit, move on
2020-07-30 14:15:42 -05:00
info "We have checked the pid ${PID_CHECK} times, moving on..."
2020-02-04 08:49:58 -06:00
else
################################################
# Check to see if the PID is alive and running #
################################################
2020-07-21 12:09:07 -05:00
if [ ! -f "${GHE_CONFIG_PID}" ]; then
2020-02-04 08:49:58 -06:00
# File not found
2020-07-30 14:15:42 -05:00
info "We're good to move forward, no .pid file found at:[${GHE_CONFIG_PID}]"
2020-02-04 08:49:58 -06:00
else
# Found the pid running, need to sleep
2020-07-30 14:15:42 -05:00
info "Current PID found, sleeping ${SLEEP_SECONDS} seconds before next check..."
2020-02-04 08:49:58 -06:00
################
# Sleep it off #
################
2020-07-21 12:09:07 -05:00
SLEEP_CMD=$(sleep ${SLEEP_SECONDS} 2>&1)
2020-02-04 08:49:58 -06:00
#######################
# Load the error code #
#######################
ERROR_CODE=$?
PID_CHECK=CheckShellErrors "PID_CHECK" "CheckGHEPid"
2020-02-04 08:49:58 -06:00
fi
fi
}
################################################################################
#### Function CheckGHEProcess ##################################################
2020-11-06 23:10:09 +01:00
CheckGHEProcess() {
2020-02-04 08:49:58 -06:00
##################################
# Check to prevent infinite loop #
##################################
2020-07-21 12:09:07 -05:00
if [ ${PROCESS_CHECK} -gt ${PROCESS_CHECK_LIMIT} ]; then
2020-02-04 08:49:58 -06:00
# Over the limit, move on
2020-07-30 14:15:42 -05:00
info "We have checked the process ${PROCESS_CHECK} times, moving on..."
2020-02-04 08:49:58 -06:00
else
####################################################
# Check to see if the process is alive and running #
####################################################
2020-07-21 12:09:07 -05:00
CHECK_PROCESS_CMD=$(pgrep -f "${GHE_APPLY_COMMAND}" 2>&1)
2020-02-04 08:49:58 -06:00
#######################
# Load the error code #
#######################
ERROR_CODE=$?
##############################
# Check the shell for errors #
##############################
2020-07-21 12:09:07 -05:00
if [ ${ERROR_CODE} -ne 0 ]; then
2020-02-04 08:49:58 -06:00
# No process running on the system
2020-07-30 14:15:42 -05:00
info "Were good to move forward, no process like:[${GHE_APPLY_COMMAND}] running currently on the system"
2020-02-04 08:49:58 -06:00
else
# Found the process running, need to sleep
2020-07-30 14:15:42 -05:00
info "Current process alive:[${CHECK_PROCESS_CMD}], sleeping ${SLEEP_SECONDS} seconds before next check..."
2020-02-04 08:49:58 -06:00
################
# Sleep it off #
################
2020-07-21 12:09:07 -05:00
SLEEP_CMD=$(sleep ${SLEEP_SECONDS} 2>&1)
2020-02-04 08:49:58 -06:00
#######################
# Load the error code #
#######################
ERROR_CODE=$?
PROCESS_CHECK=CheckShellErrors "PROCESS_CHECK" "CheckGHEProcess"
2020-02-04 08:49:58 -06:00
fi
fi
}
################################################################################
#### Function RunConfigApply ###################################################
2020-11-06 23:10:09 +01:00
RunConfigApply() {
2020-02-04 08:49:58 -06:00
##########
# Header #
##########
2020-07-30 14:15:42 -05:00
info "Running ${GHE_APPLY_COMMAND} to the server..."
2020-02-04 08:49:58 -06:00
##############################################
# Run the command to apply changes to server #
##############################################
APPLY_CMD=$(ghe-config-apply 2>&1)
#######################
# Load the error code #
#######################
ERROR_CODE=$?
##############################
# Check the shell for errors #
##############################
2020-07-21 12:09:07 -05:00
if [ ${ERROR_CODE} -ne 0 ]; then
2020-02-04 08:49:58 -06:00
# Errors
2020-07-27 16:35:53 -05:00
error "Failed to run config apply command!"
fatal "[${APPLY_CMD}]"
2020-02-04 08:49:58 -06:00
else
# Success
2020-07-30 14:15:42 -05:00
info "Successfully ran ${F[C]}${GHE_APPLY_COMMAND}"
2020-02-04 08:49:58 -06:00
fi
}
################################################################################
################################## MAIN ########################################
################################################################################
######################
# Check for pid file #
######################
CheckGHEPid
#############################
# Check for running process #
#############################
CheckGHEProcess
####################
# Run config apply #
####################
RunConfigApply
2020-06-24 11:47:18 -05:00
###########################################
2020-06-23 16:48:01 -05:00
# We're going to run it again after a nap #
2020-06-24 11:47:18 -05:00
# to make sure there is no crazy actions #
###########################################
2020-02-04 08:49:58 -06:00
sleep 300s
######################
# Check for pid file #
######################
CheckGHEPid
#############################
# Check for running process #
#############################
CheckGHEProcess
####################
# Run config apply #
####################
RunConfigApply