From 2922862538daa6994911aeb555618692f7999750 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 15:15:00 +0100 Subject: [PATCH 1/8] Add support for /etc/sysconfig/solr to specify pidfile and lockfile --- bin/scripts/rhel/solr | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index d1164648..4c52ebc3 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -29,17 +29,24 @@ JAVA_HOME= # Set java home here if java is not available in /usr/bin/java or /us source /etc/rc.d/init.d/functions +if [ -f /etc/sysconfig/solr ]; then + . /etc/sysconfig/solr +fi + +pidfile=${PIDFILE-/var/run/solr.pid} +lockfile=${LOCKFILE-/var/lock/subsys/$NAME} + for JAVA in "$JAVA_HOME/bin/java" "/usr/bin/java" "/usr/local/bin/java" do - if [ -x $JAVA ] + if [ -x $JAVA ] then - break - fi + break + fi done if [ ! -x $JAVA ] then - echo "Unable to locate java. Please set JAVA_HOME environment variable." - exit + echo "Unable to locate java. Please set JAVA_HOME environment variable." + exit fi RETVAL=0 @@ -47,20 +54,20 @@ RETVAL=0 d_start() { CURRENT_DIR=`pwd` cd $SOLR_HOME - daemon --check $NAME --pidfile /var/run/solr.pid nohup $JAVA -jar start.jar > /dev/null 2>&1 & + daemon --check $NAME --pidfile ${pidfile} nohup $JAVA -jar start.jar > /dev/null 2>&1 & RETVAL=$? sleep 1 # Sleep 1 second, to make sure java is registered. pid=`pidof java` - echo $pid > /var/run/solr.pid + echo $pid > ${pidfile} cd $CURRENT_DIR - [ $RETVAL -eq 0 ] && touch /var/lock/subsys/$NAME + [ $RETVAL -eq 0 ] && touch ${lockfile} return $RETVAL } d_stop() { - killproc -p /var/run/solr.pid $NAME >> /dev/null 2&>1 + killproc -p ${pidfile} $NAME >> /dev/null 2&>1 RETVAL=$? - [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/$NAME + [ $RETVAL -eq 0 ] && rm -f ${lockfile} return $RETVAL } @@ -71,13 +78,13 @@ d_restart() { } d_reload() { - killproc -p /var/run/solr.pid $NAME -HUP 2&>1 + killproc -p ${pidfile} $NAME -HUP 2&>1 RETVAL=$? return $RETVAL } d_status() { - status -p /var/run/solr.pid $NAME >> /dev/null 2&>1 + status -p ${pidfile} $NAME >> /dev/null 2&>1 return $? } From 742bfece5da3dd2b1a5abf243819481e0f7fd356 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 15:15:41 +0100 Subject: [PATCH 2/8] Make sure pid file is removed when stopping --- bin/scripts/rhel/solr | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index 4c52ebc3..61917510 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -67,7 +67,7 @@ d_start() { d_stop() { killproc -p ${pidfile} $NAME >> /dev/null 2&>1 RETVAL=$? - [ $RETVAL -eq 0 ] && rm -f ${lockfile} + [ $RETVAL -eq 0 ] && rm -f ${lockfile} ${pidfile} return $RETVAL } From e75956c8e3038ec969417da682e81938f409bed2 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 15:30:23 +0100 Subject: [PATCH 3/8] Add comments to rhel init script --- bin/scripts/rhel/solr | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index 61917510..18db537f 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -33,6 +33,8 @@ if [ -f /etc/sysconfig/solr ]; then . /etc/sysconfig/solr fi +# @todo allow user to set SOLR_HOME and JAVA_HOME in /etc/sysconfig/solr as well (maybe allow var name from http://gitorious.org/opensuse/webpin2/blobs/master/solr.init as well) +# @todo allow user to set up custom args for the JVM in /etc/sysconfig/solr pidfile=${PIDFILE-/var/run/solr.pid} lockfile=${LOCKFILE-/var/lock/subsys/$NAME} @@ -49,6 +51,8 @@ then exit fi +# @todo check as well that $SOLR_HOME is a dir and that it has in it start.jar + RETVAL=0 d_start() { @@ -57,6 +61,7 @@ d_start() { daemon --check $NAME --pidfile ${pidfile} nohup $JAVA -jar start.jar > /dev/null 2>&1 & RETVAL=$? sleep 1 # Sleep 1 second, to make sure java is registered. + # @bug this is plain wrong, we might get a different java here... pid=`pidof java` echo $pid > ${pidfile} cd $CURRENT_DIR From 50d8b08a57484b0ceaa52a57273cba43d0ee8ba7 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 15:51:26 +0100 Subject: [PATCH 4/8] rhel init script: avoid munging with stdout and stderr (example: apache init script does not do it); avoid creating pidfile if java process does not start --- bin/scripts/rhel/solr | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index 18db537f..05d9bc33 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -58,38 +58,41 @@ RETVAL=0 d_start() { CURRENT_DIR=`pwd` cd $SOLR_HOME - daemon --check $NAME --pidfile ${pidfile} nohup $JAVA -jar start.jar > /dev/null 2>&1 & + daemon --check $NAME --pidfile ${pidfile} nohup $JAVA -jar start.jar RETVAL=$? - sleep 1 # Sleep 1 second, to make sure java is registered. - # @bug this is plain wrong, we might get a different java here... - pid=`pidof java` - echo $pid > ${pidfile} cd $CURRENT_DIR - [ $RETVAL -eq 0 ] && touch ${lockfile} + if [ $RETVAL -eq 0 ] + then + sleep 1 # Sleep 1 second, to make sure java is registered. + # @bug this is plain wrong, we might get a different java here... + pid=`pidof java` + echo $pid > ${pidfile} + touch ${lockfile} + fi return $RETVAL } d_stop() { - killproc -p ${pidfile} $NAME >> /dev/null 2&>1 + killproc -p ${pidfile} $NAME >> /dev/null RETVAL=$? [ $RETVAL -eq 0 ] && rm -f ${lockfile} ${pidfile} return $RETVAL } d_restart() { - d_stop >> /dev/null 2&>1 + d_stop >> /dev/null sleep 1 - d_start >> /dev/null 2&>1 + d_start >> /dev/null } d_reload() { - killproc -p ${pidfile} $NAME -HUP 2&>1 + killproc -p ${pidfile} $NAME -HUP RETVAL=$? return $RETVAL } d_status() { - status -p ${pidfile} $NAME >> /dev/null 2&>1 + status -p ${pidfile} $NAME >> /dev/null return $? } From f7dc83ed289e24304420dd8fa6df2dcb4ea0edaf Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 15:58:31 +0100 Subject: [PATCH 5/8] rhel init script: make sure that solr_home is defined and contains solr --- bin/scripts/rhel/solr | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index 05d9bc33..80130807 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -51,7 +51,25 @@ then exit fi -# @todo check as well that $SOLR_HOME is a dir and that it has in it start.jar +if [ ! -d "$SOLR_HOME" ]; then + echo "the directory $SOLR_HOME (SOLR_HOME) does not exist"; + if [ "$1" = "stop" ]; then + exit 0 + else + exit 5 + fi; +fi + +SOLR_JAR="$SOLR_HOME/start.jar" + +if [ ! -f "$SOLR_JAR" ]; then + echo "$SOLR_JAR not installed"; + if [ "$1" = "stop" ]; then + exit 0 + else + exit 5 + fi +fi RETVAL=0 From 7ed6617d40f96434a371389e0bee035f9f863252 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 16:21:00 +0100 Subject: [PATCH 6/8] Add support for custom jvm options; more comments; tell rhel that we have a conf. file --- bin/scripts/rhel/solr | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index 80130807..c88f5a7c 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -4,9 +4,19 @@ # # Usage: # -# Set the correct SOLR_HOME value, and copy this file to /etc/init.d, then -# - either run chkconfig --add solr, or -# - symlink to /etc/init.d/solr to /etc/rc3./S70solr and /etc/rc5./k70solr +# 1. installation +# Copy this file to /etc/init.d, then +# - either run chkconfig --add solr, or +# - symlink to /etc/init.d/solr to /etc/rc3./S70solr and /etc/rc5./k70solr +# +# 2. configuration +# Set options in /etc/sysconfig/solr +# Variables which can be defined in /etc/sysconfig/solr: +# SOLR_HOME (mandatory) +# JAVA_HOME +# PIDFILE +# LOCKFILE +# OPTIONS (for the JVM command-line) # # Example: # cp solr /etc/init.d/solr @@ -15,26 +25,28 @@ # cd /etc/rc5.d && ln -s ../init.d/solr S70solr # cd /etc/rc3.d && ln -s ../init.d/solr K70solr # cd /etc/rc5.d && ln -s ../init.d/solr K70solr +# echo "SOLR_HOME=/var/www/ezpublish/extension/ezfind/java" > /etc/sysconfig/solr # # # chkconfig: 2345 64 36 # description: SOLR indexing server # processname: solr # pidfile: /var/run/solr.pid +# config: /etc/sysconfig/solr + +source /etc/rc.d/init.d/functions DESC="Solr indexing server" NAME=solr -SOLR_HOME= # Set solr home here (example: /var/www/ezpublish/extension/ezfind/java) -JAVA_HOME= # Set java home here if java is not available in /usr/bin/java or /usr/local/bin/java - -source /etc/rc.d/init.d/functions +SOLR_HOME= # Set solr home here if you can not create /etc/sysconfig/solr (example: /var/www/ezpublish/extension/ezfind/java) +JAVA_HOME= # Set java home here if java is not available in /usr/bin/java or /usr/local/bin/java and you can not create /etc/sysconfig/solr +OPTIONS= if [ -f /etc/sysconfig/solr ]; then . /etc/sysconfig/solr fi -# @todo allow user to set SOLR_HOME and JAVA_HOME in /etc/sysconfig/solr as well (maybe allow var name from http://gitorious.org/opensuse/webpin2/blobs/master/solr.init as well) -# @todo allow user to set up custom args for the JVM in /etc/sysconfig/solr +# @todo (maybe) allow var names from http://gitorious.org/opensuse/webpin2/blobs/master/solr.init as well pidfile=${PIDFILE-/var/run/solr.pid} lockfile=${LOCKFILE-/var/lock/subsys/$NAME} @@ -76,7 +88,7 @@ RETVAL=0 d_start() { CURRENT_DIR=`pwd` cd $SOLR_HOME - daemon --check $NAME --pidfile ${pidfile} nohup $JAVA -jar start.jar + daemon --check $NAME --pidfile ${pidfile} nohup $JAVA $OPTIONS -jar start.jar RETVAL=$? cd $CURRENT_DIR if [ $RETVAL -eq 0 ] From 5dad6c601cec9f56ff75ee98abbe135a73a090c3 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Tue, 30 Oct 2012 17:29:01 +0100 Subject: [PATCH 7/8] return error code when java not found; proper handling of ipes and error messages; code formatting; --- bin/scripts/rhel/solr | 76 +++++++++++++++++++++---------------------- 1 file changed, 37 insertions(+), 39 deletions(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index c88f5a7c..5d715cf8 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -28,6 +28,10 @@ # echo "SOLR_HOME=/var/www/ezpublish/extension/ezfind/java" > /etc/sysconfig/solr # # +# @todo use the standard messages from the init scripts for all operations instead of taking over with our version? +# +# @see http://fedoraproject.org/wiki/Packaging:SysVInitScript for return codes and general guidelines +# # chkconfig: 2345 64 36 # description: SOLR indexing server # processname: solr @@ -43,44 +47,42 @@ JAVA_HOME= # Set java home here if java is not available in /usr/bin/java or /us OPTIONS= if [ -f /etc/sysconfig/solr ]; then - . /etc/sysconfig/solr + . /etc/sysconfig/solr fi # @todo (maybe) allow var names from http://gitorious.org/opensuse/webpin2/blobs/master/solr.init as well pidfile=${PIDFILE-/var/run/solr.pid} -lockfile=${LOCKFILE-/var/lock/subsys/$NAME} +lockfile=${LOCKFILE-/var/lock/subsys/solr} +# check for java for JAVA in "$JAVA_HOME/bin/java" "/usr/bin/java" "/usr/local/bin/java" do - if [ -x $JAVA ] - then - break - fi + if [ -x $JAVA ]; then + break + fi done -if [ ! -x $JAVA ] -then - echo "Unable to locate java. Please set JAVA_HOME environment variable." - exit +if [ ! -x $JAVA ]; then + echo "Unable to locate java. Please set JAVA_HOME environment variable." + exit 6 fi +# check for solr if [ ! -d "$SOLR_HOME" ]; then - echo "the directory $SOLR_HOME (SOLR_HOME) does not exist"; - if [ "$1" = "stop" ]; then - exit 0 - else - exit 5 - fi; + echo "the directory $SOLR_HOME (SOLR_HOME) does not exist"; + if [ "$1" = "stop" ]; then + exit 0 + else + exit 5 + fi; fi - SOLR_JAR="$SOLR_HOME/start.jar" - if [ ! -f "$SOLR_JAR" ]; then - echo "$SOLR_JAR not installed"; - if [ "$1" = "stop" ]; then - exit 0 - else - exit 5 - fi + echo "$SOLR_JAR not installed"; + if [ "$1" = "stop" ]; then + exit 0 + else + exit 5 + fi fi RETVAL=0 @@ -88,13 +90,12 @@ RETVAL=0 d_start() { CURRENT_DIR=`pwd` cd $SOLR_HOME - daemon --check $NAME --pidfile ${pidfile} nohup $JAVA $OPTIONS -jar start.jar + daemon --check $NAME --pidfile ${pidfile} nohup $JAVA $OPTIONS -jar start.jar > /dev/null 2> /dev/null & RETVAL=$? cd $CURRENT_DIR - if [ $RETVAL -eq 0 ] - then + if [ $RETVAL -eq 0 ]; then sleep 1 # Sleep 1 second, to make sure java is registered. - # @bug this is plain wrong, we might get a different java here... + # @bug this is plain wrong, we might get many different java processes here... pid=`pidof java` echo $pid > ${pidfile} touch ${lockfile} @@ -103,7 +104,8 @@ d_start() { } d_stop() { - killproc -p ${pidfile} $NAME >> /dev/null + # d_stop returns 0 even when process has been killed by hand. This might be confusing, so we let its std err/out get through + killproc -p ${pidfile} $NAME RETVAL=$? [ $RETVAL -eq 0 ] && rm -f ${lockfile} ${pidfile} return $RETVAL @@ -116,21 +118,19 @@ d_restart() { } d_reload() { - killproc -p ${pidfile} $NAME -HUP - RETVAL=$? - return $RETVAL + killproc -p ${pidfile} $NAME -HUP 2> /dev/null + return $? } d_status() { - status -p ${pidfile} $NAME >> /dev/null + status -p ${pidfile} $NAME >> /dev/null 2> /dev/null return $? } case "$1" in start) echo " * Starting $DESC ($NAME)" - d_status - if [ $? -eq 0 ] + if d_status then echo " ...already running." else @@ -155,8 +155,7 @@ case "$1" in ;; restart) echo " * Restarting $DESC ($NAME)" - d_status - if [ $? -ne 0 ] + if d_status then echo " ...not running." RETVAL=1 @@ -176,8 +175,7 @@ case "$1" in echo " ...done." ;; status) - d_status - if [ $? -eq 0 ] + if d_status then echo " * $DESC ($NAME) is running" else From 74ec67bbb13b5cb966c7b41929715d9724f9ad83 Mon Sep 17 00:00:00 2001 From: Gaetano Giunta Date: Wed, 31 Oct 2012 12:52:09 +0100 Subject: [PATCH 8/8] Fix rhel init script: restart was broken --- bin/scripts/rhel/solr | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/bin/scripts/rhel/solr b/bin/scripts/rhel/solr index 5d715cf8..7adcf6a2 100644 --- a/bin/scripts/rhel/solr +++ b/bin/scripts/rhel/solr @@ -157,9 +157,6 @@ case "$1" in echo " * Restarting $DESC ($NAME)" if d_status then - echo " ...not running." - RETVAL=1 - else if d_restart then echo " * ...done." @@ -167,6 +164,9 @@ case "$1" in echo " * ...failed." RETVAL=1 fi + else + echo " ...not running." + RETVAL=1 fi ;; reload)