Merge "Add a service_check function"

This commit is contained in:
Jenkins 2012-12-12 18:20:01 +00:00 committed by Gerrit Code Review
commit dd0bed5dd0
2 changed files with 48 additions and 1 deletions

View File

@ -715,6 +715,8 @@ function restart_service() {
function screen_it { function screen_it {
NL=`echo -ne '\015'` NL=`echo -ne '\015'`
SCREEN_NAME=${SCREEN_NAME:-stack} SCREEN_NAME=${SCREEN_NAME:-stack}
SERVICE_DIR=${SERVICE_DIR:-${DEST}/status}
if is_service_enabled $1; then if is_service_enabled $1; then
# Append the service to the screen rc file # Append the service to the screen rc file
screen_rc "$1" "$2" screen_rc "$1" "$2"
@ -730,7 +732,7 @@ function screen_it {
screen -S $SCREEN_NAME -p $1 -X log on screen -S $SCREEN_NAME -p $1 -X log on
ln -sf ${SCREEN_LOGDIR}/screen-${1}.${CURRENT_LOG_TIME}.log ${SCREEN_LOGDIR}/screen-${1}.log ln -sf ${SCREEN_LOGDIR}/screen-${1}.${CURRENT_LOG_TIME}.log ${SCREEN_LOGDIR}/screen-${1}.log
fi fi
screen -S $SCREEN_NAME -p $1 -X stuff "$2$NL" screen -S $SCREEN_NAME -p $1 -X stuff "$2 || touch \"$SERVICE_DIR/$SCREEN_NAME/$1.failure\"$NL"
fi fi
} }
@ -755,6 +757,47 @@ function screen_rc {
fi fi
} }
# Helper to remove the *.failure files under $SERVICE_DIR/$SCREEN_NAME
# This is used for service_check when all the screen_it are called finished
# init_service_check
function init_service_check() {
SCREEN_NAME=${SCREEN_NAME:-stack}
SERVICE_DIR=${SERVICE_DIR:-${DEST}/status}
if [[ ! -d "$SERVICE_DIR/$SCREEN_NAME" ]]; then
mkdir -p "$SERVICE_DIR/$SCREEN_NAME"
fi
rm -f "$SERVICE_DIR/$SCREEN_NAME"/*.failure
}
# Helper to get the status of each running service
# service_check
function service_check() {
local service
local failures
SCREEN_NAME=${SCREEN_NAME:-stack}
SERVICE_DIR=${SERVICE_DIR:-${DEST}/status}
if [[ ! -d "$SERVICE_DIR/$SCREEN_NAME" ]]; then
echo "No service status directory found"
return
fi
# Check if there is any falure flag file under $SERVICE_DIR/$SCREEN_NAME
failures=`ls "$SERVICE_DIR/$SCREEN_NAME"/*.failure 2>/dev/null`
for service in $failures; do
service=`basename $service`
service=${service::-8}
echo "Error: Service $service is not running"
done
if [ -n "$failures" ]; then
echo "More details about the above errors can be found with screen, with ./rejoin-stack.sh"
fi
}
# ``pip install`` the dependencies of the package before ``setup.py develop`` # ``pip install`` the dependencies of the package before ``setup.py develop``
# so pip and not distutils processes the dependency chain # so pip and not distutils processes the dependency chain

View File

@ -923,6 +923,8 @@ sleep 1
# Set a reasonable status bar # Set a reasonable status bar
screen -r $SCREEN_NAME -X hardstatus alwayslastline "$SCREEN_HARDSTATUS" screen -r $SCREEN_NAME -X hardstatus alwayslastline "$SCREEN_HARDSTATUS"
# Initialize the directory for service status check
init_service_check
# Keystone # Keystone
# -------- # --------
@ -1700,6 +1702,8 @@ if [[ -x $TOP_DIR/local.sh ]]; then
$TOP_DIR/local.sh $TOP_DIR/local.sh
fi fi
# Check the status of running services
service_check
# Fin # Fin
# === # ===