
bin.jobtracker.sh Maven / Gradle / Ivy
#!/usr/bin/env bash
# JVMFLAGS JVM参数可以在这里设置
JVMFLAGS=-Dfile.encoding=UTF-8
JOB_TRACKER_HOME="${BASH_SOURCE-$0}"
JOB_TRACKER_HOME="$(dirname "${JOB_TRACKER_HOME}")"
JOB_TRACKER_HOME="$(cd "${JOB_TRACKER_HOME}"; pwd)"
if [ "$JAVA_HOME" != "" ]; then
JAVA="$JAVA_HOME/bin/java"
else
JAVA=java
fi
mkdir -p $JOB_TRACKER_HOME/../logs
mkdir -p $JOB_TRACKER_HOME/../pid
#把lib下的所有jar都加入到classpath中
for i in "$JOB_TRACKER_HOME"/../lib/*.jar
do
CLASSPATH="$i:$CLASSPATH"
done
# echo $CLASSPATH
NODE_NAME="$1" # zoo
# 转化为绝对路径
CONF_HOME="${JOB_TRACKER_HOME}/../."
CONF_HOME="$(cd "$(dirname "${CONF_HOME}")"; pwd)"
CONF_HOME="$CONF_HOME/conf/$NODE_NAME"
_LTS_DAEMON_OUT="$JOB_TRACKER_HOME/../logs/jobtracker-$NODE_NAME.out"
LTS_MAIN="com.github.ltsopensource.startup.jobtracker.JobTrackerStartup"
LTS_PID_FILE="$JOB_TRACKER_HOME/../pid/jobtracker-$NODE_NAME.pid"
case $2 in
start)
echo "Starting LTS JOB_TRACKER [$NODE_NAME] ... "
if [ -f "$LTS_PID_FILE" ]; then
if kill -0 `cat "$LTS_PID_FILE"` > /dev/null 2>&1; then
echo $command already running as process `cat "$LTS_PID_FILE"`.
exit 0
fi
fi
nohup "$JAVA" -cp "$CLASSPATH" $JVMFLAGS $LTS_MAIN "$CONF_HOME" > "$_LTS_DAEMON_OUT" 2>&1 < /dev/null &
if [ $? -eq 0 ]
then
if /bin/echo -n $! > "$LTS_PID_FILE"
then
sleep 1
echo "STARTED"
else
echo "FAILED TO WRITE PID"
exit 1
fi
else
echo "JOB_TRACKER DID NOT START"
exit 1
fi
;;
restart)
sh $0 $1 stop
sleep 3
sh $0 $1 start
;;
stop)
echo "Stopping LTS JOB_TRACKER [$NODE_NAME] ... "
if [ ! -f "$LTS_PID_FILE" ]
then
echo "no jobtracker to started (could not find file $LTS_PID_FILE)"
else
kill -9 $(cat "$LTS_PID_FILE")
rm "$LTS_PID_FILE"
echo "STOPPED"
fi
exit 0
;;
*)
echo "Usage: $0 {nodeName} {start|stop|restart}" >&2
esac
© 2015 - 2025 Weber Informatics LLC | Privacy Policy