HBASE-15924 Enhance hbase services autorestart capability to hbase-daemon.sh
Signed-off-by: Andrew Purtell <apurtell@apache.org>
This commit is contained in:
parent
5ebb25d601
commit
06b67a632c
|
@ -66,6 +66,24 @@ do
|
||||||
shift
|
shift
|
||||||
# shellcheck disable=SC2034
|
# shellcheck disable=SC2034
|
||||||
AUTH_AS_SERVER="true"
|
AUTH_AS_SERVER="true"
|
||||||
|
elif [ "--autostart-window-size" = "$1" ]
|
||||||
|
then
|
||||||
|
shift
|
||||||
|
AUTOSTART_WINDOW_SIZE=$(( $1 + 0 ))
|
||||||
|
if [ $AUTOSTART_WINDOW_SIZE -lt 0 ]; then
|
||||||
|
echo "Invalid value for --autostart-window-size, should be a positive integer"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
shift
|
||||||
|
elif [ "--autostart-window-retry-limit" = "$1" ]
|
||||||
|
then
|
||||||
|
shift
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=$(( $1 + 0 ))
|
||||||
|
if [ $AUTOSTART_WINDOW_RETRY_LIMIT -lt 0 ]; then
|
||||||
|
echo "Invalid value for --autostart-window-retry-limit, should be a positive integer"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
shift
|
||||||
else
|
else
|
||||||
# Presume we are at end of options and break
|
# Presume we are at end of options and break
|
||||||
break
|
break
|
||||||
|
|
|
@ -33,7 +33,9 @@
|
||||||
# Modelled after $HADOOP_HOME/bin/hadoop-daemon.sh
|
# Modelled after $HADOOP_HOME/bin/hadoop-daemon.sh
|
||||||
|
|
||||||
usage="Usage: hbase-daemon.sh [--config <conf-dir>]\
|
usage="Usage: hbase-daemon.sh [--config <conf-dir>]\
|
||||||
(start|stop|restart|autorestart|foreground_start) <hbase-command> \
|
[--autostart-window-size <window size in hours>]\
|
||||||
|
[--autostart-window-retry-limit <retry count limit for autostart>]\
|
||||||
|
(start|stop|restart|autostart|autorestart|foreground_start) <hbase-command> \
|
||||||
<args...>"
|
<args...>"
|
||||||
|
|
||||||
# if no args specified, show usage
|
# if no args specified, show usage
|
||||||
|
@ -42,6 +44,10 @@ if [ $# -le 1 ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# default autostart args value indicating infinite window size and no retry limit
|
||||||
|
AUTOSTART_WINDOW_SIZE=0
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
||||||
|
|
||||||
bin=`dirname "${BASH_SOURCE-$0}"`
|
bin=`dirname "${BASH_SOURCE-$0}"`
|
||||||
bin=`cd "$bin">/dev/null; pwd`
|
bin=`cd "$bin">/dev/null; pwd`
|
||||||
|
|
||||||
|
@ -162,7 +168,7 @@ HBASE_LOGGC=${HBASE_LOGGC:-"$HBASE_LOG_DIR/$HBASE_LOG_PREFIX.gc"}
|
||||||
HBASE_LOGLOG=${HBASE_LOGLOG:-"${HBASE_LOG_DIR}/${HBASE_LOGFILE}"}
|
HBASE_LOGLOG=${HBASE_LOGLOG:-"${HBASE_LOG_DIR}/${HBASE_LOGFILE}"}
|
||||||
HBASE_PID=$HBASE_PID_DIR/hbase-$HBASE_IDENT_STRING-$command.pid
|
HBASE_PID=$HBASE_PID_DIR/hbase-$HBASE_IDENT_STRING-$command.pid
|
||||||
export HBASE_ZNODE_FILE=$HBASE_PID_DIR/hbase-$HBASE_IDENT_STRING-$command.znode
|
export HBASE_ZNODE_FILE=$HBASE_PID_DIR/hbase-$HBASE_IDENT_STRING-$command.znode
|
||||||
export HBASE_START_FILE=$HBASE_PID_DIR/hbase-$HBASE_IDENT_STRING-$command.autorestart
|
export HBASE_AUTOSTART_FILE=$HBASE_PID_DIR/hbase-$HBASE_IDENT_STRING-$command.autostart
|
||||||
|
|
||||||
if [ -n "$SERVER_GC_OPTS" ]; then
|
if [ -n "$SERVER_GC_OPTS" ]; then
|
||||||
export SERVER_GC_OPTS=${SERVER_GC_OPTS/"-Xloggc:<FILE-PATH>"/"-Xloggc:${HBASE_LOGGC}"}
|
export SERVER_GC_OPTS=${SERVER_GC_OPTS/"-Xloggc:<FILE-PATH>"/"-Xloggc:${HBASE_LOGGC}"}
|
||||||
|
@ -185,19 +191,38 @@ case $startStop in
|
||||||
check_before_start
|
check_before_start
|
||||||
hbase_rotate_log $HBASE_LOGOUT
|
hbase_rotate_log $HBASE_LOGOUT
|
||||||
hbase_rotate_log $HBASE_LOGGC
|
hbase_rotate_log $HBASE_LOGGC
|
||||||
echo starting $command, logging to $HBASE_LOGOUT
|
echo running $command, logging to $HBASE_LOGOUT
|
||||||
$thiscmd --config "${HBASE_CONF_DIR}" \
|
$thiscmd --config "${HBASE_CONF_DIR}" \
|
||||||
foreground_start $command $args < /dev/null > ${HBASE_LOGOUT} 2>&1 &
|
foreground_start $command $args < /dev/null > ${HBASE_LOGOUT} 2>&1 &
|
||||||
disown -h -r
|
disown -h -r
|
||||||
sleep 1; head "${HBASE_LOGOUT}"
|
sleep 1; head "${HBASE_LOGOUT}"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(autorestart)
|
(autostart)
|
||||||
check_before_start
|
check_before_start
|
||||||
hbase_rotate_log $HBASE_LOGOUT
|
hbase_rotate_log $HBASE_LOGOUT
|
||||||
hbase_rotate_log $HBASE_LOGGC
|
hbase_rotate_log $HBASE_LOGGC
|
||||||
nohup $thiscmd --config "${HBASE_CONF_DIR}" \
|
echo running $command, logging to $HBASE_LOGOUT
|
||||||
internal_autorestart $command $args < /dev/null > ${HBASE_LOGOUT} 2>&1 &
|
nohup $thiscmd --config "${HBASE_CONF_DIR}" --autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT} \
|
||||||
|
internal_autostart $command $args < /dev/null > ${HBASE_LOGOUT} 2>&1 &
|
||||||
|
;;
|
||||||
|
|
||||||
|
(autorestart)
|
||||||
|
echo running $command, logging to $HBASE_LOGOUT
|
||||||
|
# stop the command
|
||||||
|
$thiscmd --config "${HBASE_CONF_DIR}" stop $command $args &
|
||||||
|
wait_until_done $!
|
||||||
|
# wait a user-specified sleep period
|
||||||
|
sp=${HBASE_RESTART_SLEEP:-3}
|
||||||
|
if [ $sp -gt 0 ]; then
|
||||||
|
sleep $sp
|
||||||
|
fi
|
||||||
|
|
||||||
|
check_before_start
|
||||||
|
hbase_rotate_log $HBASE_LOGOUT
|
||||||
|
hbase_rotate_log $HBASE_LOGGC
|
||||||
|
nohup $thiscmd --config "${HBASE_CONF_DIR}" --autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT} \
|
||||||
|
internal_autostart $command $args < /dev/null > ${HBASE_LOGOUT} 2>&1 &
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(foreground_start)
|
(foreground_start)
|
||||||
|
@ -226,19 +251,33 @@ case $startStop in
|
||||||
wait $hbase_pid
|
wait $hbase_pid
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(internal_autorestart)
|
(internal_autostart)
|
||||||
touch "$HBASE_START_FILE"
|
ONE_HOUR_IN_SECS=3600
|
||||||
#keep starting the command until asked to stop. Reloop on software crash
|
autostartWindowStartDate=`date +%s`
|
||||||
|
autostartCount=0
|
||||||
|
touch "$HBASE_AUTOSTART_FILE"
|
||||||
|
|
||||||
|
# keep starting the command until asked to stop. Reloop on software crash
|
||||||
while true
|
while true
|
||||||
do
|
do
|
||||||
lastLaunchDate=`date +%s`
|
if [ -f $HBASE_PID ] && kill -0 "$(cat "$HBASE_PID")" > /dev/null 2>&1 ; then
|
||||||
$thiscmd --config "${HBASE_CONF_DIR}" foreground_start $command $args
|
wait "$(cat "$HBASE_PID")"
|
||||||
|
else
|
||||||
#if the file does not exist it means that it was not stopped properly by the stop command
|
#if the file does not exist it means that it was not stopped properly by the stop command
|
||||||
if [ ! -f "$HBASE_START_FILE" ]; then
|
if [ ! -f "$HBASE_AUTOSTART_FILE" ]; then
|
||||||
|
echo "`date` HBase might be stopped removing the autostart file. Exiting Autostart process" >> ${HBASE_LOGOUT}
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echo "`date` Autostarting hbase $command service. Attempt no: $(( $autostartCount + 1))" >> ${HBASE_LOGLOG}
|
||||||
|
touch "$HBASE_AUTOSTART_FILE"
|
||||||
|
$thiscmd --config "${HBASE_CONF_DIR}" foreground_start $command $args
|
||||||
|
autostartCount=$(( $autostartCount + 1 ))
|
||||||
|
|
||||||
|
# HBASE-6504 - only take the first line of the output in case verbose gc is on
|
||||||
|
distMode=`$bin/hbase --config "$HBASE_CONF_DIR" org.apache.hadoop.hbase.util.HBaseConfTool hbase.cluster.distributed | head -n 1`
|
||||||
|
|
||||||
|
if [ "$distMode" != 'false' ]; then
|
||||||
#if the cluster is being stopped then do not restart it again.
|
#if the cluster is being stopped then do not restart it again.
|
||||||
zparent=`$bin/hbase org.apache.hadoop.hbase.util.HBaseConfTool zookeeper.znode.parent`
|
zparent=`$bin/hbase org.apache.hadoop.hbase.util.HBaseConfTool zookeeper.znode.parent`
|
||||||
if [ "$zparent" == "null" ]; then zparent="/hbase"; fi
|
if [ "$zparent" == "null" ]; then zparent="/hbase"; fi
|
||||||
|
@ -246,28 +285,50 @@ case $startStop in
|
||||||
if [ "$zkrunning" == "null" ]; then zkrunning="running"; fi
|
if [ "$zkrunning" == "null" ]; then zkrunning="running"; fi
|
||||||
zkFullRunning=$zparent/$zkrunning
|
zkFullRunning=$zparent/$zkrunning
|
||||||
$bin/hbase zkcli stat $zkFullRunning 2>&1 | grep "Node does not exist" 1>/dev/null 2>&1
|
$bin/hbase zkcli stat $zkFullRunning 2>&1 | grep "Node does not exist" 1>/dev/null 2>&1
|
||||||
|
|
||||||
#grep returns 0 if it found something, 1 otherwise
|
#grep returns 0 if it found something, 1 otherwise
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "`date` hbase znode does not exist. Exiting Autostart process" >> ${HBASE_LOGOUT}
|
||||||
|
rm -f "$HBASE_AUTOSTART_FILE"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#If ZooKeeper cannot be found, then do not restart
|
#If ZooKeeper cannot be found, then do not restart
|
||||||
$bin/hbase zkcli stat $zkFullRunning 2>&1 | grep Exception | grep ConnectionLoss 1>/dev/null 2>&1
|
$bin/hbase zkcli stat $zkFullRunning 2>&1 | grep Exception | grep ConnectionLoss 1>/dev/null 2>&1
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "`date` zookeeper not found. Exiting Autostart process" >> ${HBASE_LOGOUT}
|
||||||
|
rm -f "$HBASE_AUTOSTART_FILE"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
curDate=`date +%s`
|
||||||
|
autostartWindowReset=false
|
||||||
|
|
||||||
|
# reset the auto start window size if it exceeds
|
||||||
|
if [ $AUTOSTART_WINDOW_SIZE -gt 0 ] && [ $(( $curDate - $autostartWindowStartDate )) -gt $(( $AUTOSTART_WINDOW_SIZE * $ONE_HOUR_IN_SECS )) ]; then
|
||||||
|
echo "Resetting Autorestart window size: $autostartWindowStartDate" >> ${HBASE_LOGOUT}
|
||||||
|
autostartWindowStartDate=$curDate
|
||||||
|
autostartWindowReset=true
|
||||||
|
autostartCount=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# kill autostart if the retry limit is exceeded within the given window size (window size other then 0)
|
||||||
|
if ! $autostartWindowReset && [ $AUTOSTART_WINDOW_RETRY_LIMIT -gt 0 ] && [ $autostartCount -gt $AUTOSTART_WINDOW_RETRY_LIMIT ]; then
|
||||||
|
echo "`date` Autostart window retry limit: $AUTOSTART_WINDOW_RETRY_LIMIT exceeded for given window size: $AUTOSTART_WINDOW_SIZE hours.. Exiting..." >> ${HBASE_LOGLOG}
|
||||||
|
rm -f "$HBASE_AUTOSTART_FILE"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#if it was launched less than 5 minutes ago, then wait for 5 minutes before starting it again.
|
# wait for shutdown hook to complete
|
||||||
curDate=`date +%s`
|
sleep 20
|
||||||
limitDate=`expr $lastLaunchDate + 300`
|
|
||||||
if [ $limitDate -gt $curDate ]; then
|
|
||||||
sleep 300
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(stop)
|
(stop)
|
||||||
rm -f "$HBASE_START_FILE"
|
echo running $command, logging to $HBASE_LOGOUT
|
||||||
|
rm -f "$HBASE_AUTOSTART_FILE"
|
||||||
if [ -f $HBASE_PID ]; then
|
if [ -f $HBASE_PID ]; then
|
||||||
pidToKill=`cat $HBASE_PID`
|
pidToKill=`cat $HBASE_PID`
|
||||||
# kill -0 == see if the PID exists
|
# kill -0 == see if the PID exists
|
||||||
|
@ -287,6 +348,7 @@ case $startStop in
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(restart)
|
(restart)
|
||||||
|
echo running $command, logging to $HBASE_LOGOUT
|
||||||
# stop the command
|
# stop the command
|
||||||
$thiscmd --config "${HBASE_CONF_DIR}" stop $command $args &
|
$thiscmd --config "${HBASE_CONF_DIR}" stop $command $args &
|
||||||
wait_until_done $!
|
wait_until_done $!
|
||||||
|
|
|
@ -21,8 +21,9 @@
|
||||||
# Run a hbase command on all slave hosts.
|
# Run a hbase command on all slave hosts.
|
||||||
# Modelled after $HADOOP_HOME/bin/hadoop-daemons.sh
|
# Modelled after $HADOOP_HOME/bin/hadoop-daemons.sh
|
||||||
|
|
||||||
usage="Usage: hbase-daemons.sh [--config <hbase-confdir>] \
|
usage="Usage: hbase-daemons.sh [--config <hbase-confdir>] [--autostart-window-size <window size in hours>]\
|
||||||
[--hosts regionserversfile] [start|stop] command args..."
|
[--autostart-window-retry-limit <retry count limit for autostart>] \
|
||||||
|
[--hosts regionserversfile] [autostart|autorestart|restart|start|stop] command args..."
|
||||||
|
|
||||||
# if no args specified, show usage
|
# if no args specified, show usage
|
||||||
if [ $# -le 1 ]; then
|
if [ $# -le 1 ]; then
|
||||||
|
@ -33,9 +34,18 @@ fi
|
||||||
bin=`dirname "${BASH_SOURCE-$0}"`
|
bin=`dirname "${BASH_SOURCE-$0}"`
|
||||||
bin=`cd "$bin">/dev/null; pwd`
|
bin=`cd "$bin">/dev/null; pwd`
|
||||||
|
|
||||||
|
# default autostart args value indicating infinite window size and no retry limit
|
||||||
|
AUTOSTART_WINDOW_SIZE=0
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
||||||
|
|
||||||
. $bin/hbase-config.sh
|
. $bin/hbase-config.sh
|
||||||
|
|
||||||
remote_cmd="cd ${HBASE_HOME}; $bin/hbase-daemon.sh --config ${HBASE_CONF_DIR} $@"
|
if [[ "$1" = "autostart" || "$1" = "autorestart" ]]
|
||||||
|
then
|
||||||
|
autostart_args="--autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
remote_cmd="$bin/hbase-daemon.sh --config ${HBASE_CONF_DIR} ${autostart_args} $@"
|
||||||
args="--hosts ${HBASE_REGIONSERVERS} --config ${HBASE_CONF_DIR} $remote_cmd"
|
args="--hosts ${HBASE_REGIONSERVERS} --config ${HBASE_CONF_DIR} $remote_cmd"
|
||||||
|
|
||||||
command=$2
|
command=$2
|
||||||
|
@ -50,4 +60,3 @@ case $command in
|
||||||
exec "$bin/regionservers.sh" $args
|
exec "$bin/regionservers.sh" $args
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|
|
@ -25,12 +25,16 @@ bin=`cd "$bin" >/dev/null && pwd`
|
||||||
|
|
||||||
if [ $# -lt 2 ]; then
|
if [ $# -lt 2 ]; then
|
||||||
S=`basename "${BASH_SOURCE-$0}"`
|
S=`basename "${BASH_SOURCE-$0}"`
|
||||||
echo "Usage: $S [--config <conf-dir>] [start|stop] offset(s)"
|
echo "Usage: $S [--config <conf-dir>] [--autostart-window-size <window size in hours>]"
|
||||||
echo ""
|
echo " [--autostart-window-retry-limit <retry count limit for autostart>] [autostart|start|stop] offset(s)"
|
||||||
echo " e.g. $S start 1"
|
echo " e.g. $S start 1"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# default autostart args value indicating infinite window size and no retry limit
|
||||||
|
AUTOSTART_WINDOW_SIZE=0
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
||||||
|
|
||||||
. "$bin"/hbase-config.sh
|
. "$bin"/hbase-config.sh
|
||||||
|
|
||||||
# sanity check: make sure your master opts don't use ports [i.e. JMX/DBG]
|
# sanity check: make sure your master opts don't use ports [i.e. JMX/DBG]
|
||||||
|
@ -45,7 +49,7 @@ run_master () {
|
||||||
-D hbase.regionserver.port=`expr 16020 + $DN` \
|
-D hbase.regionserver.port=`expr 16020 + $DN` \
|
||||||
-D hbase.regionserver.info.port=`expr 16030 + $DN` \
|
-D hbase.regionserver.info.port=`expr 16030 + $DN` \
|
||||||
--backup"
|
--backup"
|
||||||
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" $1 master $HBASE_MASTER_ARGS
|
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" --autostart-window-size "${AUTOSTART_WINDOW_SIZE}" --autostart-window-retry-limit "${AUTOSTART_WINDOW_RETRY_LIMIT}" $1 master $HBASE_MASTER_ARGS
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd=$1
|
cmd=$1
|
||||||
|
|
|
@ -25,12 +25,16 @@ bin=`cd "$bin" >/dev/null && pwd`
|
||||||
|
|
||||||
if [ $# -lt 2 ]; then
|
if [ $# -lt 2 ]; then
|
||||||
S=`basename "${BASH_SOURCE-$0}"`
|
S=`basename "${BASH_SOURCE-$0}"`
|
||||||
echo "Usage: $S [--config <conf-dir>] [start|stop] offset(s)"
|
echo "Usage: $S [--config <conf-dir>] [--autostart-window-size <window size in hours>]"
|
||||||
echo ""
|
echo " [--autostart-window-retry-limit <retry count limit for autostart>] [autostart|start|stop] offset(s)"
|
||||||
echo " e.g. $S start 1 2"
|
echo " e.g. $S start 1 2"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# default autostart args value indicating infinite window size and no retry limit
|
||||||
|
AUTOSTART_WINDOW_SIZE=0
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
||||||
|
|
||||||
. "$bin"/hbase-config.sh
|
. "$bin"/hbase-config.sh
|
||||||
|
|
||||||
# sanity check: make sure your regionserver opts don't use ports [i.e. JMX/DBG]
|
# sanity check: make sure your regionserver opts don't use ports [i.e. JMX/DBG]
|
||||||
|
@ -40,9 +44,13 @@ run_regionserver () {
|
||||||
DN=$2
|
DN=$2
|
||||||
export HBASE_IDENT_STRING="$USER-$DN"
|
export HBASE_IDENT_STRING="$USER-$DN"
|
||||||
HBASE_REGIONSERVER_ARGS="\
|
HBASE_REGIONSERVER_ARGS="\
|
||||||
-D hbase.regionserver.port=`expr 16200 + $DN` \
|
-Dhbase.regionserver.port=`expr 16200 + $DN` \
|
||||||
-D hbase.regionserver.info.port=`expr 16300 + $DN`"
|
-Dhbase.regionserver.info.port=`expr 16300 + $DN`"
|
||||||
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" $1 regionserver $HBASE_REGIONSERVER_ARGS
|
|
||||||
|
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" \
|
||||||
|
--autostart-window-size "${AUTOSTART_WINDOW_SIZE}" \
|
||||||
|
--autostart-window-retry-limit "${AUTOSTART_WINDOW_RETRY_LIMIT}" \
|
||||||
|
$1 regionserver $HBASE_REGIONSERVER_ARGS
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd=$1
|
cmd=$1
|
||||||
|
|
|
@ -59,7 +59,12 @@ fi
|
||||||
|
|
||||||
regionservers=`cat "$HOSTLIST"`
|
regionservers=`cat "$HOSTLIST"`
|
||||||
if [ "$regionservers" = "localhost" ]; then
|
if [ "$regionservers" = "localhost" ]; then
|
||||||
"$bin"/local-regionservers.sh start 1
|
HBASE_REGIONSERVER_ARGS="\
|
||||||
|
-Dhbase.regionserver.port=16201 \
|
||||||
|
-Dhbase.regionserver.info.port=16301"
|
||||||
|
|
||||||
|
$"${@// /\\ }" ${HBASE_REGIONSERVER_ARGS} \
|
||||||
|
2>&1 | sed "s/^/$regionserver: /" &
|
||||||
else
|
else
|
||||||
for regionserver in `cat "$HOSTLIST"`; do
|
for regionserver in `cat "$HOSTLIST"`; do
|
||||||
if ${HBASE_SLAVE_PARALLEL:-true}; then
|
if ${HBASE_SLAVE_PARALLEL:-true}; then
|
||||||
|
|
|
@ -32,8 +32,9 @@
|
||||||
#
|
#
|
||||||
# Modelled after $HADOOP_HOME/bin/slaves.sh.
|
# Modelled after $HADOOP_HOME/bin/slaves.sh.
|
||||||
|
|
||||||
usage_str="Usage: `basename $0` [--config <hbase-confdir>] [--rs-only] [--master-only]\
|
usage_str="Usage: `basename $0` [--config <hbase-confdir>] [--autostart-window-size <window size in hours>]\
|
||||||
[--graceful [--maxthreads xx] [--noack] [--movetimeout]]"
|
[--autostart-window-retry-limit <retry count limit for autostart>] [--autostart] [--rs-only] [--master-only] \
|
||||||
|
[--graceful] [--maxthreads xx] [--noack] [--movetimeout]]"
|
||||||
|
|
||||||
function usage() {
|
function usage() {
|
||||||
echo "${usage_str}"
|
echo "${usage_str}"
|
||||||
|
@ -42,6 +43,10 @@ function usage() {
|
||||||
bin=`dirname "$0"`
|
bin=`dirname "$0"`
|
||||||
bin=`cd "$bin">/dev/null; pwd`
|
bin=`cd "$bin">/dev/null; pwd`
|
||||||
|
|
||||||
|
# default autostart args value indicating infinite window size and no retry limit
|
||||||
|
AUTOSTART_WINDOW_SIZE=0
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
||||||
|
|
||||||
. "$bin"/hbase-config.sh
|
. "$bin"/hbase-config.sh
|
||||||
|
|
||||||
# start hbase daemons
|
# start hbase daemons
|
||||||
|
@ -55,8 +60,9 @@ RR_RS=1
|
||||||
RR_MASTER=1
|
RR_MASTER=1
|
||||||
RR_GRACEFUL=0
|
RR_GRACEFUL=0
|
||||||
RR_MAXTHREADS=1
|
RR_MAXTHREADS=1
|
||||||
RR_NOACK=
|
START_CMD_NON_DIST_MODE=restart
|
||||||
RR_MOVE_TIMEOUT=2147483647
|
START_CMD_DIST_MODE=start
|
||||||
|
RESTART_CMD_REGIONSERVER=restart
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
|
@ -66,6 +72,12 @@ while [ $# -gt 0 ]; do
|
||||||
RR_GRACEFUL=0
|
RR_GRACEFUL=0
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
|
--autostart)
|
||||||
|
START_CMD_NON_DIST_MODE="--autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT} autorestart"
|
||||||
|
START_CMD_DIST_MODE="--autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT} autostart"
|
||||||
|
RESTART_CMD_REGIONSERVER="--autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT} autorestart"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
--master-only)
|
--master-only)
|
||||||
RR_RS=0
|
RR_RS=0
|
||||||
RR_MASTER=1
|
RR_MASTER=1
|
||||||
|
@ -112,7 +124,7 @@ if [ "$distMode" == 'false' ]; then
|
||||||
echo Cant do selective rolling restart if not running distributed
|
echo Cant do selective rolling restart if not running distributed
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
"$bin"/hbase-daemon.sh restart master
|
"$bin"/hbase-daemon.sh ${START_CMD_NON_DIST_MODE} master
|
||||||
else
|
else
|
||||||
zparent=`$bin/hbase org.apache.hadoop.hbase.util.HBaseConfTool zookeeper.znode.parent`
|
zparent=`$bin/hbase org.apache.hadoop.hbase.util.HBaseConfTool zookeeper.znode.parent`
|
||||||
if [ "$zparent" == "null" ]; then zparent="/hbase"; fi
|
if [ "$zparent" == "null" ]; then zparent="/hbase"; fi
|
||||||
|
@ -136,9 +148,9 @@ else
|
||||||
echo #force a newline
|
echo #force a newline
|
||||||
|
|
||||||
# all masters are down, now restart
|
# all masters are down, now restart
|
||||||
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" start master
|
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" ${START_CMD_DIST_MODE} master
|
||||||
"$bin"/hbase-daemons.sh --config "${HBASE_CONF_DIR}" \
|
"$bin"/hbase-daemons.sh --config "${HBASE_CONF_DIR}" \
|
||||||
--hosts "${HBASE_BACKUP_MASTERS}" start master-backup
|
--hosts "${HBASE_BACKUP_MASTERS}" ${START_CMD_DIST_MODE} master-backup
|
||||||
|
|
||||||
echo "Wait a minute for master to come up join cluster"
|
echo "Wait a minute for master to come up join cluster"
|
||||||
sleep 60
|
sleep 60
|
||||||
|
@ -177,7 +189,7 @@ else
|
||||||
# unlike the masters, roll all regionservers one-at-a-time
|
# unlike the masters, roll all regionservers one-at-a-time
|
||||||
export HBASE_SLAVE_PARALLEL=false
|
export HBASE_SLAVE_PARALLEL=false
|
||||||
"$bin"/hbase-daemons.sh --config "${HBASE_CONF_DIR}" \
|
"$bin"/hbase-daemons.sh --config "${HBASE_CONF_DIR}" \
|
||||||
--hosts "${HBASE_REGIONSERVERS}" restart regionserver
|
--hosts "${HBASE_REGIONSERVERS}" ${RESTART_CMD_REGIONSERVER} regionserver
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $RR_GRACEFUL -eq 1 ]; then
|
if [ $RR_GRACEFUL -eq 1 ]; then
|
||||||
|
|
|
@ -22,11 +22,17 @@
|
||||||
|
|
||||||
# Start hadoop hbase daemons.
|
# Start hadoop hbase daemons.
|
||||||
# Run this on master node.
|
# Run this on master node.
|
||||||
usage="Usage: start-hbase.sh"
|
usage="Usage: start-hbase.sh [--autostart-window-size <window size in hours>]\
|
||||||
|
[--autostart-window-retry-limit <retry count limit for autostart>]\
|
||||||
|
[autostart|start]"
|
||||||
|
|
||||||
bin=`dirname "${BASH_SOURCE-$0}"`
|
bin=`dirname "${BASH_SOURCE-$0}"`
|
||||||
bin=`cd "$bin">/dev/null; pwd`
|
bin=`cd "$bin">/dev/null; pwd`
|
||||||
|
|
||||||
|
# default autostart args value indicating infinite window size and no retry limit
|
||||||
|
AUTOSTART_WINDOW_SIZE=0
|
||||||
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
||||||
|
|
||||||
. "$bin"/hbase-config.sh
|
. "$bin"/hbase-config.sh
|
||||||
|
|
||||||
# start hbase daemons
|
# start hbase daemons
|
||||||
|
@ -36,10 +42,9 @@ then
|
||||||
exit $errCode
|
exit $errCode
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = "autostart" ]
|
||||||
if [ "$1" = "autorestart" ]
|
|
||||||
then
|
then
|
||||||
commandToRun="autorestart"
|
commandToRun="--autostart-window-size ${AUTOSTART_WINDOW_SIZE} --autostart-window-retry-limit ${AUTOSTART_WINDOW_RETRY_LIMIT} autostart"
|
||||||
else
|
else
|
||||||
commandToRun="start"
|
commandToRun="start"
|
||||||
fi
|
fi
|
||||||
|
@ -47,10 +52,9 @@ fi
|
||||||
# HBASE-6504 - only take the first line of the output in case verbose gc is on
|
# HBASE-6504 - only take the first line of the output in case verbose gc is on
|
||||||
distMode=`$bin/hbase --config "$HBASE_CONF_DIR" org.apache.hadoop.hbase.util.HBaseConfTool hbase.cluster.distributed | head -n 1`
|
distMode=`$bin/hbase --config "$HBASE_CONF_DIR" org.apache.hadoop.hbase.util.HBaseConfTool hbase.cluster.distributed | head -n 1`
|
||||||
|
|
||||||
|
|
||||||
if [ "$distMode" == 'false' ]
|
if [ "$distMode" == 'false' ]
|
||||||
then
|
then
|
||||||
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" $commandToRun master $@
|
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" $commandToRun master
|
||||||
else
|
else
|
||||||
"$bin"/hbase-daemons.sh --config "${HBASE_CONF_DIR}" $commandToRun zookeeper
|
"$bin"/hbase-daemons.sh --config "${HBASE_CONF_DIR}" $commandToRun zookeeper
|
||||||
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" $commandToRun master
|
"$bin"/hbase-daemon.sh --config "${HBASE_CONF_DIR}" $commandToRun master
|
||||||
|
|
Loading…
Reference in New Issue