123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- #! /bin/sh
- # 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.
- ### BEGIN INIT INFO
- # Provides: hadoop-tasktracker
- # Required-Start: $remote_fs $syslog
- # Required-Stop: $remote_fs $syslog
- # Default-Start: 2 3 4 5
- # Default-Stop:
- # Short-Description: Apache Hadoop Task Tracker server
- ### END INIT INFO
- set -e
- # /etc/init.d/hadoop-tasktracker: start and stop the Apache Hadoop Task Tracker daemon
- test -x /usr/bin/hadoop || exit 0
- ( /usr/bin/hadoop 2>&1 | grep -q hadoop ) 2>/dev/null || exit 0
- umask 022
- if test -f /etc/default/hadoop-env.sh; then
- . /etc/default/hadoop-env.sh
- fi
- . /lib/lsb/init-functions
- # Are we running from init?
- run_by_init() {
- ([ "$previous" ] && [ "$runlevel" ]) || [ "$runlevel" = S ]
- }
- check_for_no_start() {
- # forget it if we're trying to start, and /etc/hadoop/hadoop-tasktracker_not_to_be_run exists
- if [ -e /etc/hadoop/hadoop-tasktracker_not_to_be_run ]; then
- if [ "$1" = log_end_msg ]; then
- log_end_msg 0
- fi
- if ! run_by_init; then
- log_action_msg "Apache Hadoop Task Tracker server not in use (/etc/hadoop/hadoop-tasktracker_not_to_be_run)"
- fi
- exit 0
- fi
- }
- check_privsep_dir() {
- # Create the PrivSep empty dir if necessary
- if [ ! -d ${HADOOP_PID_DIR} ]; then
- mkdir -p ${HADOOP_PID_DIR}
- chown root:hadoop ${HADOOP_PID_DIR}
- chmod 0775 ${HADOOP_PID_DIR}
- fi
- }
- export PATH="${PATH:+$PATH:}/usr/sbin:/usr/bin"
- export HADOOP_PREFIX=${HADOOP_PREFIX:-/usr}
- case "$1" in
- start)
- check_privsep_dir
- check_for_no_start
- log_daemon_msg "Starting Apache Hadoop Task Tracker server" "hadoop-tasktracker"
- if start-stop-daemon --start --quiet --oknodo --pidfile ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid -c mapred -x ${HADOOP_PREFIX}/sbin/hadoop-daemon.sh -- --config ${HADOOP_CONF_DIR} start tasktracker; then
- log_end_msg 0
- else
- log_end_msg 1
- fi
- ;;
- stop)
- log_daemon_msg "Stopping Apache Hadoop Task Tracker server" "hadoop-tasktracker"
- if start-stop-daemon --stop --quiet --oknodo --pidfile ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid; then
- log_end_msg 0
- else
- log_end_msg 1
- fi
- ;;
- restart)
- check_privsep_dir
- log_daemon_msg "Restarting Apache Hadoop Task Tracker server" "hadoop-tasktracker"
- start-stop-daemon --stop --quiet --oknodo --retry 30 --pidfile ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid
- check_for_no_start log_end_msg
- if start-stop-daemon --start --quiet --oknodo --pidfile ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid -c mapred -x ${HADOOP_PREFIX}/sbin/hadoop-daemon.sh -- --config ${HADOOP_CONF_DIR} start tasktracker; then
- log_end_msg 0
- else
- log_end_msg 1
- fi
- ;;
- try-restart)
- check_privsep_dir
- log_daemon_msg "Restarting Apache Hadoop Task Tracker server" "hadoop-tasktracker"
- set +e
- start-stop-daemon --stop --quiet --retry 30 --pidfile ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid
- RET="$?"
- set -e
- case $RET in
- 0)
- # old daemon stopped
- check_for_no_start log_end_msg
- if start-stop-daemon --start --quiet --oknodo --pidfile ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid -c mapred -x ${HADOOP_PREFIX}/sbin/hadoop-daemon.sh -- --config ${HADOOP_CONF_DIR} start tasktracker; then
- log_end_msg 0
- else
- log_end_msg 1
- fi
- ;;
- 1)
- # daemon not running
- log_progress_msg "(not running)"
- log_end_msg 0
- ;;
- *)
- # failed to stop
- log_progress_msg "(failed to stop)"
- log_end_msg 1
- ;;
- esac
- ;;
- status)
- status_of_proc -p ${HADOOP_PID_DIR}/hadoop-mapred-tasktracker.pid ${JAVA_HOME}/bin/java hadoop-tasktracker && exit 0 || exit $?
- ;;
- *)
- log_action_msg "Usage: /etc/init.d/hadoop-tasktracker {start|stop|restart|try-restart|status}"
- exit 1
- esac
- exit 0
|