-#! /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
- ;;
-
- 'removed')
- if [ ! -f "$2" ] ; then
- try=''
- break
- fi
- ;;
- esac
+#!/bin/sh
+#
+# php-fpm PHP FastCGI Process Manager
+#
+# chkconfig: 345 80 30
+#
+# description: PHP FastCGI Process Manager
+#
+# processname: php-fpm
+# config: /etc/php/php-fpm.conf
+# pidfile: /var/run/php/fpm.pid
+#
+# $Id$
+
+# Source function library
+. /etc/rc.d/init.d/functions
+
+# Get network config
+. /etc/sysconfig/network
+
+pidfile=/var/run/php/fpm.pid
+
+start() {
+ # Check if the service is already running?
+ if [ ! -f /var/lock/subsys/php-fpm ]; then
+ msg_starting "PHP FastCGI Process Manager"
+ daemon --pidfile $pidfile /usr/sbin/php-fpm --fpm-config /etc/php/php-fpm.conf
+ RETVAL=$?
+ [ $RETVAL -eq 0 ] && touch /var/lock/subsys/php-fpm
+ else
+ msg_already_running "PHP FastCGI Process Manager"
+ fi
+}
- echo -n .
- try=`expr $try + 1`
- sleep 1
+stop() {
+ if [ -f /var/lock/subsys/php-fpm ]; then
+ # Stop daemons.
+ msg_stopping "PHP FastCGI Process Manager"
+ # always gracefully shut down php-fpm
+ /sbin/start-stop-daemon -q --stop -s QUIT --retry QUIT/600/TERM/10 --pidfile $pidfile
+ [ "$?" -eq 0 ] && ok || fail
+ rm -f /var/lock/subsys/php-fpm
+ else
+ msg_not_running "PHP FastCGI Process Manager"
+ fi
+}
- done
+reload() {
+ local sig=${1:-HUP}
+ local retnr=${2:-7}
+ if [ -f /var/lock/subsys/php-fpm ]; then
+ msg_reloading "PHP FastCGI Process Manager"
+ killproc --pidfile $pidfile php-fpm -$sig
+ RETVAL=$?
+ else
+ msg_not_running "PHP FastCGI Process Manager"
+ RETVAL=$retnr
+ fi
+}
+condrestart() {
+ if [ -f /var/lock/subsys/php-fpm ]; then
+ stop
+ start
+ else
+ msg_not_running "PHP FastCGI Process Manager"
+ RETVAL=$1
+ fi
}
+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 php-fpm
+ RETVAL=$?
+ ;;
+ *)
+ msg_usage "$0 {start|stop|restart|try-restart|reload|force-reload|flush-logs|status}"
+ exit 3
;;
-
esac
+
+exit $RETVAL