2015-03-16 22:45:01 -04:00
|
|
|
#!/usr/bin/env bash
|
2011-10-23 19:03:32 -04:00
|
|
|
#/**
|
|
|
|
# * Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
# * or more contributor license agreements. See the NOTICE file
|
|
|
|
# * distributed with this work for additional information
|
|
|
|
# * regarding copyright ownership. The ASF licenses this file
|
|
|
|
# * to you under the Apache License, Version 2.0 (the
|
|
|
|
# * "License"); you may not use this file except in compliance
|
|
|
|
# * with the License. You may obtain a copy of the License at
|
|
|
|
# *
|
|
|
|
# * http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
# *
|
|
|
|
# * Unless required by applicable law or agreed to in writing, software
|
|
|
|
# * distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# * See the License for the specific language governing permissions and
|
|
|
|
# * limitations under the License.
|
|
|
|
# */
|
2010-07-19 18:59:51 -04:00
|
|
|
# This is used for starting multiple regionservers on the same machine.
|
|
|
|
# run it from hbase-dir/ just like 'bin/hbase'
|
|
|
|
# Supports up to 100 regionservers (limitation = overlapping ports)
|
|
|
|
|
2010-07-27 17:50:05 -04:00
|
|
|
bin=`dirname "${BASH_SOURCE-$0}"`
|
2010-07-19 18:59:51 -04:00
|
|
|
bin=`cd "$bin" >/dev/null && pwd`
|
|
|
|
|
|
|
|
if [ $# -lt 2 ]; then
|
2010-07-27 17:50:05 -04:00
|
|
|
S=`basename "${BASH_SOURCE-$0}"`
|
2016-12-20 20:26:44 -05:00
|
|
|
echo "Usage: $S [--config <conf-dir>] [--autostart-window-size <window size in hours>]"
|
|
|
|
echo " [--autostart-window-retry-limit <retry count limit for autostart>] [autostart|start|stop] offset(s)"
|
2010-07-19 18:59:51 -04:00
|
|
|
echo " e.g. $S start 1 2"
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
2016-12-20 20:26:44 -05:00
|
|
|
# default autostart args value indicating infinite window size and no retry limit
|
|
|
|
AUTOSTART_WINDOW_SIZE=0
|
|
|
|
AUTOSTART_WINDOW_RETRY_LIMIT=0
|
|
|
|
|
2013-06-19 00:51:01 -04:00
|
|
|
. "$bin"/hbase-config.sh
|
|
|
|
|
2010-07-19 18:59:51 -04:00
|
|
|
# sanity check: make sure your regionserver opts don't use ports [i.e. JMX/DBG]
|
|
|
|
export HBASE_REGIONSERVER_OPTS=" "
|
|
|
|
|
|
|
|
run_regionserver () {
|
|
|
|
DN=$2
|
|
|
|
export HBASE_IDENT_STRING="$USER-$DN"
|
|
|
|
HBASE_REGIONSERVER_ARGS="\
|
2016-12-20 20:26:44 -05:00
|
|
|
-Dhbase.regionserver.port=`expr 16200 + $DN` \
|
|
|
|
-Dhbase.regionserver.info.port=`expr 16300 + $DN`"
|
|
|
|
|
|
|
|
"$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
|
2010-07-19 18:59:51 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
cmd=$1
|
|
|
|
shift;
|
|
|
|
|
|
|
|
for i in $*
|
|
|
|
do
|
2015-02-04 06:01:53 -05:00
|
|
|
if [[ "$i" =~ ^[0-9]+$ ]]; then
|
|
|
|
run_regionserver $cmd $i
|
|
|
|
else
|
|
|
|
echo "Invalid argument"
|
|
|
|
fi
|
2010-07-19 18:59:51 -04:00
|
|
|
done
|