All Downloads are FREE. Search and download functionalities are using the official Maven repository.

bin.jobtracker.sh Maven / Gradle / Ivy

There is a newer version: 1.7.0
Show newest version
#!/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