blob: 711b5219a71af9de3ee93464a1f0d6e48cf48b81 [file] [log] [blame]
#!/usr/bin/env bash
#
# 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.
# Set Jetty related environment variables
setup_jetty_log_and_pid() {
if [ "${JETTY_OUT}" = "" ]; then
export JETTY_OUT=${OOZIE_LOG}/jetty.out
print "Setting JETTY_OUT: ${JETTY_OUT}"
else
print "Using JETTY_OUT: ${JETTY_OUT}"
fi
if [ "${JETTY_PID_FILE}" = "" ]; then
export JETTY_PID_FILE=${JETTY_DIR}/oozie.pid
print "Setting JETTY_PID_FILE: ${JETTY_PID_FILE}"
else
print "Using JETTY_PID_FILE: ${JETTY_PID_FILE}"
fi
}
setup_java_opts() {
if [ -z "${JAVA_HOME}" -a -z "${JRE_HOME}" ]; then
if ${darwin}; then
if [ -x '/usr/libexec/java_home' ] ; then
export JAVA_HOME=`/usr/libexec/java_home`
elif [ -d "/System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home" ]; then
export JAVA_HOME="/System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home"
fi
else
JAVA_PATH=`which java 2>/dev/null`
if [ "x${JAVA_PATH}" != "x" ]; then
JAVA_PATH=`dirname ${JAVA_PATH} 2>/dev/null`
fi
if [ "x${JRE_HOME}" = "x" ]; then
if [ -x /usr/bin/java ]; then
JRE_HOME=/usr
fi
fi
fi
if [ -z "${JAVA_HOME}" -a -z "${JRE_HOME}" ]; then
echo "Neither the JAVA_HOME nor the JRE_HOME environment variable is defined"
echo "At least one of these environment variable is needed to run this program"
exit 1
fi
fi
if [ -z "${JRE_HOME}" ]; then
JRE_HOME="${JAVA_HOME}"
fi
JAVA_BIN="${JRE_HOME}"/bin/java
echo "Using Java executable from ${JRE_HOME}"
}
setup_jetty_opts() {
echo "Using JETTY_OPTS: ${JETTY_OPTS}"
jetty_opts="-Doozie.home.dir=${OOZIE_HOME}";
jetty_opts="${jetty_opts} -Doozie.config.dir=${OOZIE_CONFIG}";
jetty_opts="${jetty_opts} -Doozie.log.dir=${OOZIE_LOG}";
jetty_opts="${jetty_opts} -Doozie.data.dir=${OOZIE_DATA}";
jetty_opts="${jetty_opts} -Doozie.instance.id=${OOZIE_INSTANCE_ID}";
jetty_opts="${jetty_opts} -Doozie.config.file=${OOZIE_CONFIG_FILE}";
jetty_opts="${jetty_opts} -Doozie.log4j.file=${OOZIE_LOG4J_FILE}";
jetty_opts="${jetty_opts} -Doozie.log4j.reload=${OOZIE_LOG4J_RELOAD}";
# add required native libraries such as compression codecs
jetty_opts="${jetty_opts} -Djava.library.path=${JAVA_LIBRARY_PATH}";
jetty_opts="${jetty_opts} -cp ${JETTY_DIR}/*:${JETTY_DIR}/dependency/*:${BASEDIR}/lib/*:${BASEDIR}/libtools/*:${JETTY_DIR}"
echo "Adding to JETTY_OPTS: ${jetty_opts}"
export JETTY_OPTS="${JETTY_OPTS} ${jetty_opts}"
}
start_jetty() {
if [ ! -z "${JETTY_PID_FILE}" ]; then
if [ -f "${JETTY_PID_FILE}" ]; then
if [ -s "${JETTY_PID_FILE}" ]; then
echo "Existing PID file found during start."
if [ -r "${JETTY_PID_FILE}" ]; then
PID=$(cat "${JETTY_PID_FILE}")
ps -p "$PID" >/dev/null 2>&1
if [ $? -eq 0 ] ; then
echo "Oozie server appears to still be running with PID $PID. Start aborted."
echo "If the following process is not a Jetty process, remove the PID file and try again:"
ps -f -p "$PID"
exit 1
else
echo "Removing/clearing stale PID file."
rm -f "${JETTY_PID_FILE}" >/dev/null 2>&1
if [ $? != 0 ]; then
if [ -w "${JETTY_PID_FILE}" ]; then
cat /dev/null > "${JETTY_PID_FILE}"
else
echo "Unable to remove or clear stale PID file. Start aborted."
exit 1
fi
fi
fi
else
echo "Unable to read PID file. Start aborted."
exit 1
fi
else
rm -f "$JETTY_PID_FILE" >/dev/null 2>&1
if [ $? != 0 ]; then
if [ ! -w "$JETTY_PID_FILE" ]; then
echo "Unable to remove or write to empty PID file. Start aborted."
exit 1
fi
fi
fi
fi
fi
${JAVA_BIN} ${JETTY_OPTS} org.apache.oozie.server.EmbeddedOozieServer >> "${JETTY_OUT}" 2>&1 &
PID=$!
if [ ${PID} ]; then
echo -n "Oozie server started"
fi
if [ ! -z "${JETTY_PID_FILE}" ]; then
echo -n $! > "${JETTY_PID_FILE}"
echo -n " - PID: ${PID}."
fi
echo
}
run_jetty() {
${JAVA_BIN} ${JETTY_OPTS} org.apache.oozie.server.EmbeddedOozieServer
}
#TODO allow users to force kill jetty. Add --force
stop_jetty() {
if [ ! -z "${JETTY_PID_FILE}" ]; then
if [ -f "${JETTY_PID_FILE}" ]; then
if [ -s "${JETTY_PID_FILE}" ]; then
kill -0 "$(cat "${JETTY_PID_FILE}")" >/dev/null 2>&1
if [ $? -gt 0 ]; then
echo "PID file found but no matching process was found. Stop aborted."
exit 1
fi
else
echo "PID file is empty and has been ignored."
fi
else
echo "\$JETTY_PID_FILE was set but the specified file does not exist. Is Oozie server running? Stop aborted."
exit 1
fi
fi
kill "$(cat "${JETTY_PID_FILE}")"
RETRY_COUNT=5
if [ ! -z "${JETTY_PID_FILE}" ]; then
if [ -f "${JETTY_PID_FILE}" ]; then
while [ $RETRY_COUNT -ge 0 ]; do
kill -0 "$(cat ${JETTY_PID_FILE})" >/dev/null 2>&1
if [ $? -gt 0 ]; then
rm -f "${JETTY_PID_FILE}" >/dev/null 2>&1
if [ $? != 0 ]; then
if [ -w "${JETTY_PID_FILE}" ]; then
cat /dev/null > "${JETTY_PID_FILE}"
else
echo "Oozie server stopped but the PID file could not be removed or cleared."
fi
fi
break
fi
if [ ${RETRY_COUNT} -gt 0 ]; then
sleep 1
fi
if [ ${RETRY_COUNT} -eq 0 ]; then
echo "Oozie server did not stop in time. PID file was not removed."
fi
RETRY_COUNT=$((RETRY_COUNT - 1))
done
fi
fi
}
symlink_lib() {
test -e ${BASEDIR}/lib || ln -s ${JETTY_DIR}/webapp/WEB-INF/lib ${BASEDIR}/lib
}
jetty_main() {
source ${BASEDIR}/bin/oozie-sys.sh
JETTY_DIR=${BASEDIR}/embedded-oozie-server
setup_jetty_log_and_pid
setup_java_opts
setup_jetty_opts
actionCmd=$1
case $actionCmd in
(run)
${BASEDIR}/bin/oozie-setup.sh
symlink_lib
setup_ooziedb
run_jetty
;;
(start)
${BASEDIR}/bin/oozie-setup.sh
symlink_lib
setup_ooziedb
start_jetty
;;
(stop)
stop_jetty
;;
esac
}