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 masters on the same machine.
|
|
|
|
# run it from hbase-dir/ just like 'bin/hbase'
|
|
|
|
# Supports up to 10 masters (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"
|
|
|
|
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 master opts don't use ports [i.e. JMX/DBG]
|
|
|
|
export HBASE_MASTER_OPTS=" "
|
|
|
|
|
|
|
|
run_master () {
|
|
|
|
DN=$2
|
|
|
|
export HBASE_IDENT_STRING="$USER-$DN"
|
|
|
|
HBASE_MASTER_ARGS="\
|
2016-01-08 18:58:46 -05:00
|
|
|
-D hbase.master.port=`expr 16000 + $DN` \
|
2014-01-17 12:37:25 -05:00
|
|
|
-D hbase.master.info.port=`expr 16010 + $DN` \
|
2014-07-23 14:42:22 -04:00
|
|
|
-D hbase.regionserver.port=`expr 16020 + $DN` \
|
|
|
|
-D hbase.regionserver.info.port=`expr 16030 + $DN` \
|
2011-06-25 20:52:36 -04:00
|
|
|
--backup"
|
2016-12-20 20:26:44 -05:00
|
|
|
"$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
|
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_master $cmd $i
|
|
|
|
else
|
|
|
|
echo "Invalid argument"
|
|
|
|
fi
|
2010-07-19 18:59:51 -04:00
|
|
|
done
|