-#! /bin/sh
-
-php_fpm_BIN=/usr/bin/php-cgi
-php_fpm_CONF=/etc/php/fpm.conf
-php_fpm_PID=/var/run/php/fpm.pid
-
-
-php_opts="--fpm-config $php_fpm_CONF"
-
-
-wait_for_pid () {
- try=0
-
- while test $try -lt 35 ; do
-
- case "$1" in
- 'created')
- if [ -f "$2" ] ; then
- try=''
- break
- fi
- ;;
+#!/bin/sh
+#
+# @processname@ PHP FastCGI Process Manager
+#
+# chkconfig: 345 80 30
+#
+# description: PHP FastCGI Process Manager
+#
+# processname: @processname@
+# config: /etc/php/fpm.conf
+# pidfile: /var/run/@processname@.pid
+#
+
+# Source function library
+. /etc/rc.d/init.d/functions
+
+# Get network config
+. /etc/sysconfig/network
+
+configfile=/etc/php/fpm.conf
+lockfile=/var/lock/subsys/@processname@
+pidfile=$(sed -ne 's,.*"\?pid_file"\?>\([^<]\+\)<.*,\1,p' $configfile)
+pidfile=${pidfile:-/var/run/@processname@.pid}
+
+start() {
+ # Check if the service is already running?
+ if [ -f $lockfile ]; then
+ msg_already_running "PHP FastCGI Process Manager (@processname@)"
+ return
+ fi
+
+ msg_starting "PHP FastCGI Process Manager (@processname@)"
+ daemon --pidfile $pidfile /usr/sbin/@processname@ --fpm --fpm-config $configfile
+ RETVAL=$?
+ [ $RETVAL -eq 0 ] && touch $lockfile
+}
- 'removed')
- if [ ! -f "$2" ] ; then
- try=''
- break
- fi
- ;;
- esac
+stop() {
+ if [ ! -f $lockfile ]; then
+ msg_not_running "PHP FastCGI Process Manager (@processname@)"
+ return
+ fi
+
+ # Stop daemons.
+ msg_stopping "PHP FastCGI Process Manager (@processname@)"
+ # always gracefully shut down @processname@
+ /sbin/start-stop-daemon -q --stop -s QUIT --retry QUIT/600/TERM/10 --pidfile $pidfile
+ [ "$?" -eq 0 ] && ok || fail
+ rm -f $lockfile
+}
- echo -n .
- try=`expr $try + 1`
- sleep 1
+reload() {
+ local sig=${1:-HUP}
+ local retnr=${2:-7}
+ if [ ! -f $lockfile ]; then
+ msg_not_running "PHP FastCGI Process Manager (@processname@)"
+ RETVAL=$retnr
+ return
+ fi
+
+ msg_reloading "PHP FastCGI Process Manager (@processname@)"
+ killproc --pidfile $pidfile @processname@ -$sig
+ RETVAL=$?
+}
- done
+condrestart() {
+ if [ ! -f $lockfile ]; then
+ msg_not_running "PHP FastCGI Process Manager (@processname@)"
+ RETVAL=$1
+ return
+ fi
+ stop
+ start
}
+RETVAL=0
+# See how we were called.
case "$1" in
- start)
- echo -n "Starting php_fpm "
-
- $php_fpm_BIN --fpm $php_opts
-
- if [ "$?" != 0 ] ; then
- echo " failed"
- exit 1
- fi
-
- wait_for_pid created $php_fpm_PID
-
- if [ -n "$try" ] ; then
- echo " failed"
- exit 1
- else
- echo " done"
- fi
+ start)
+ start
;;
-
- stop)
- echo -n "Shutting down php_fpm "
-
- if [ ! -r $php_fpm_PID ] ; then
- echo "warning, no pid file found - php-fpm is not running ?"
- exit 1
- fi
-
- kill -TERM `cat $php_fpm_PID`
-
- wait_for_pid removed $php_fpm_PID
-
- if [ -n "$try" ] ; then
- echo " failed"
- exit 1
- else
- echo " done"
- fi
+ stop|quit)
+ stop
;;
-
- quit)
- echo -n "Gracefully shutting down php_fpm "
-
- if [ ! -r $php_fpm_PID ] ; then
- echo "warning, no pid file found - php-fpm is not running ?"
- exit 1
- fi
-
- kill -QUIT `cat $php_fpm_PID`
-
- wait_for_pid removed $php_fpm_PID
-
- if [ -n "$try" ] ; then
- echo " failed"
- exit 1
- else
- echo " done"
- fi
+ restart)
+ stop
+ start
;;
-
- restart)
- $0 stop
- $0 start
+ try-restart)
+ condrestart 0
;;
-
- reload)
-
- echo -n "Reload service php-fpm "
-
- if [ ! -r $php_fpm_PID ] ; then
- echo "warning, no pid file found - php-fpm is not running ?"
- exit 1
- fi
-
- kill -USR2 `cat $php_fpm_PID`
-
- echo " done"
+ reload|force-reload)
+ reload USR2 7
;;
-
- logrotate)
-
- echo -n "Re-opening php-fpm log file "
-
- if [ ! -r $php_fpm_PID ] ; then
- echo "warning, no pid file found - php-fpm is not running ?"
- exit 1
- fi
-
- kill -USR1 `cat $php_fpm_PID`
-
- echo " done"
+ flush-logs|logrotate)
+ reload USR1 0
;;
-
- *)
- echo "Usage: $0 {start|stop|quit|restart|reload|logrotate}"
- exit 1
+ status)
+ status --pidfile $pidfile @processname@
+ RETVAL=$?
+ ;;
+ *)
+ msg_usage "$0 {start|stop|restart|try-restart|reload|force-reload|flush-logs|status}"
+ exit 3
;;
-
esac
+
+exit $RETVAL