git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@1034453 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Bosanac Dejan 2010-11-12 16:32:00 +00:00
parent c9c6e62a60
commit 2e1a014fec
1 changed files with 25 additions and 17 deletions

View File

@ -199,7 +199,8 @@ if [ "$CONFIG_LOAD" != "yes" ];then
echo "(you can configure options in one of these file: $ACTIVEMQ_CONFIGS)" echo "(you can configure options in one of these file: $ACTIVEMQ_CONFIGS)"
echo echo
echo "INFO: Invoke the following command to create a configuration file" echo "INFO: Invoke the following command to create a configuration file"
echo "$0 setup [ $(echo $ACTIVEMQ_CONFIGS|sed 's/[ ][ ]*/ | /') ]" CONFIGS=`echo $ACTIVEMQ_CONFIGS|sed 's/[ ][ ]*/ | /'`
echo "$0 setup [ $CONFIGS ]"
echo echo
fi fi
fi fi
@ -327,16 +328,16 @@ fi
# - if $ACTIVEMQ_USER is set, the function tries starts the java process whith the specified # - if $ACTIVEMQ_USER is set, the function tries starts the java process whith the specified
# user # user
invokeJar(){ invokeJar(){
local PIDFILE="$1" PIDFILE="$1"
local RET="1" RET="1"
local CUSER="$(whoami 2>/dev/null)" CUSER="$(whoami 2>/dev/null)"
# Solaris fix # Solaris fix
if ( ! [ $? -eq 0 ] ) ; then if [ ! $? -eq 0 ]; then
local CUSER="$(/usr/ucb/whoami)" CUSER="$(/usr/ucb/whoami)"
fi fi
if ( ! [ -f "${ACTIVEMQ_HOME}/bin/run.jar" ] );then if [ ! -f "${ACTIVEMQ_HOME}/bin/run.jar" ];then
echo "ERROR: '${ACTIVEMQ_HOME}/bin/run.jar' does not exist" echo "ERROR: '${ACTIVEMQ_HOME}/bin/run.jar' does not exist"
exit 1 exit 1
fi fi
@ -362,12 +363,13 @@ invokeJar(){
echo \"INFO: pidfile created : '$PIDFILE' (pid '\$APID')\";exit \$RET" $DOIT_POSTFIX echo \"INFO: pidfile created : '$PIDFILE' (pid '\$APID')\";exit \$RET" $DOIT_POSTFIX
RET="$?" RET="$?"
elif [ -n "$PIDFILE" ] && [ "$PIDFILE" = "stop" ];then elif [ -n "$PIDFILE" ] && [ "$PIDFILE" = "stop" ];then
PID=`cat $ACTIVEMQ_PIDFILE`
$DOIT_PREFIX "$JAVACMD $ACTIVEMQ_OPTS $ACTIVEMQ_DEBUG_OPTS \ $DOIT_PREFIX "$JAVACMD $ACTIVEMQ_OPTS $ACTIVEMQ_DEBUG_OPTS \
-Dactivemq.classpath=\"${ACTIVEMQ_CLASSPATH}\" \ -Dactivemq.classpath=\"${ACTIVEMQ_CLASSPATH}\" \
-Dactivemq.home=\"${ACTIVEMQ_HOME}\" \ -Dactivemq.home=\"${ACTIVEMQ_HOME}\" \
-Dactivemq.base=\"${ACTIVEMQ_BASE}\" \ -Dactivemq.base=\"${ACTIVEMQ_BASE}\" \
$ACTIVEMQ_CYGWIN \ $ACTIVEMQ_CYGWIN \
-jar \"${ACTIVEMQ_HOME}/bin/run.jar\" $COMMANDLINE_ARGS --pid $(cat $ACTIVEMQ_PIDFILE) & -jar \"${ACTIVEMQ_HOME}/bin/run.jar\" $COMMANDLINE_ARGS --pid $PID &
RET=\"\$?\"; APID=\"\$!\"; RET=\"\$?\"; APID=\"\$!\";
echo \$APID > $ACTIVEMQ_DATA_DIR/stop.pid" $DOIT_POSTFIX echo \$APID > $ACTIVEMQ_DATA_DIR/stop.pid" $DOIT_POSTFIX
else else
@ -398,7 +400,9 @@ checkRunning(){
echo "ERROR: Pidfile '$ACTIVEMQ_PIDFILE' exists but contains no pid" echo "ERROR: Pidfile '$ACTIVEMQ_PIDFILE' exists but contains no pid"
return 2 return 2
fi fi
if (ps -p $(cat $ACTIVEMQ_PIDFILE)|grep java >/dev/null);then PID=`cat $ACTIVEMQ_PIDFILE`
RET=`ps -p $PID|grep java`
if [ -n "$RET" ];then
return 0; return 0;
else else
return 1; return 1;
@ -415,7 +419,8 @@ checkStopRunning(){
echo "ERROR: Pidfile '$PID' exists but contains no pid" echo "ERROR: Pidfile '$PID' exists but contains no pid"
return 2 return 2
fi fi
if (ps -p $(cat $PID)|grep java >/dev/null);then RET=`ps -p $(cat $PID)|grep java`
if [ -n "$RET" ];then
return 0; return 0;
else else
return 1; return 1;
@ -436,7 +441,8 @@ checkStopRunning(){
invoke_status(){ invoke_status(){
if ( checkRunning );then if ( checkRunning );then
echo "ActiveMQ is running (pid '$(cat $ACTIVEMQ_PIDFILE)')" PID=`cat $ACTIVEMQ_PIDFILE`
echo "ActiveMQ is running (pid '$PID')"
exit 0 exit 0
fi fi
echo "ActiveMQ not running" echo "ActiveMQ not running"
@ -456,7 +462,8 @@ invoke_status(){
invoke_start(){ invoke_start(){
if ( checkRunning );then if ( checkRunning );then
echo "INFO: Process with pid '$(cat $ACTIVEMQ_PIDFILE)' is already running" PID=`cat $ACTIVEMQ_PIDFILE`
echo "INFO: Process with pid '$PID' is already running"
exit 0 exit 0
fi fi
@ -513,13 +520,14 @@ invoke_stop(){
COMMANDLINE_ARGS="$COMMANDLINE_ARGS $ACTIVEMQ_SUNJMX_CONTROL" COMMANDLINE_ARGS="$COMMANDLINE_ARGS $ACTIVEMQ_SUNJMX_CONTROL"
invokeJar "stop" invokeJar "stop"
RET="$?" RET="$?"
echo "INFO: Waiting at least $ACTIVEMQ_KILL_MAXSECONDS seconds for regular process termination of pid '$(cat $ACTIVEMQ_PIDFILE)' : " PID=`cat $ACTIVEMQ_PIDFILE`
echo "INFO: Waiting at least $ACTIVEMQ_KILL_MAXSECONDS seconds for regular process termination of pid '$PID' : "
FOUND="0" FOUND="0"
i=1 i=1
while [ $i != $ACTIVEMQ_KILL_MAXSECONDS ]; do while [ $i != $ACTIVEMQ_KILL_MAXSECONDS ]; do
if (! checkStopRunning);then if [ ! checkStopRunning ];then
if (! checkRunning); then if [ ! checkRunning ]; then
echo " FINISHED" echo " FINISHED"
FOUND="1" FOUND="1"
fi fi
@ -538,8 +546,8 @@ invoke_stop(){
done done
if [ "$FOUND" -ne "1" ];then if [ "$FOUND" -ne "1" ];then
echo echo
echo "INFO: Regular shutdown not successful, sending SIGKILL to process with pid '$(cat $ACTIVEMQ_PIDFILE)'" echo "INFO: Regular shutdown not successful, sending SIGKILL to process with pid '$PID'"
kill -KILL $(cat $ACTIVEMQ_PIDFILE) kill -KILL $PID
RET="1" RET="1"
fi fi
elif [ -f "$ACTIVEMQ_PIDFILE" ];then elif [ -f "$ACTIVEMQ_PIDFILE" ];then