]> git.pld-linux.org Git - packages/memcached.git/blobdiff - memcached.init
- rebuild with libevent 2.1.11
[packages/memcached.git] / memcached.init
old mode 100644 (file)
new mode 100755 (executable)
index e4abfa3..d733d9c
 . /etc/sysconfig/network
 
 MEMUSAGE="64"
-MEMCACHED_RUNAS="nobody"
+MEMCACHED_RUNAS="memcached"
 MAXCONN="1024"
-LISTENON="127.0.0.1"
-PORT="11211"
+LISTEN="127.0.0.1:11211"
 
 # Get service config
 [ -f /etc/sysconfig/memcached ] && . /etc/sysconfig/memcached
 
+if [ "$LISTENON" -a "$PORT" ]; then
+       # backward compat config
+       LISTEN="$LISTENON:$PORT"
+fi
+
+start() {
+       # Check if the service is already running?
+       if [ -f /var/lock/subsys/memcached ]; then
+               msg_already_running "memcached"
+               return
+       fi
+
+       local listen ip port ret=0
+       for listen in $LISTEN; do
+               ip=${listen%:*}
+               port=${listen##*:}
+               msg_starting "memcached ($ip:$port)"
+               pidfile=/var/run/memcached/"$ip.$port.pid"
+               daemon --pidfile $pidfile --user $MEMCACHED_RUNAS \
+                       /usr/sbin/memcached -d -P $pidfile -l $ip -p $port \
+                       -m $MEMUSAGE -c $MAXCONN -u $MEMCACHED_RUNAS $MEMCACHED_OPTS
+               ret=$?
+               [ $ret = 0 ] || RETVAL=$?
+       done
+       [ $RETVAL -eq 0 ] && touch /var/lock/subsys/memcached
+}
+
+stop() {
+       if [ ! -f /var/lock/subsys/memcached ]; then
+               msg_not_running "memcached"
+               return
+       fi
+
+       local listen ip port
+       for listen in $LISTEN; do
+               ip=${listen%:*}
+               port=${listen##*:}
+               msg_stopping "memcached ($ip:$port)"
+               pidfile=/var/run/memcached/"$ip.$port.pid"
+               killproc --pidfile $pidfile memcached
+       done
+       rm -f /var/lock/subsys/memcached >/dev/null 2>&1
+}
+
+condrestart() {
+       if [ ! -f /var/lock/subsys/memcached ]; then
+               msg_not_running "memcached"
+               RETVAL=$1
+               return
+       fi
+
+       stop
+       start
+}
+
+reload() {
+       if [ ! -f /var/lock/subsys/memcached ]; then
+               msg_not_running "memcached"
+               RETVAL=7
+               return
+       fi
+
+       local listen ip port
+       for listen in $LISTEN; do
+               ip=${listen%:*}
+               port=${listen##*:}
+               msg_reloading "memcached ($ip:$port)"
+               pidfile=/var/run/memcached/"$ip.$port.pid"
+               killproc --pidfile $pidfile memcached -HUP
+               RETVAL=$((RETVAL + $?))
+       done
+}
+
 RETVAL=0
 # See how we were called.
 case "$1" in
   start)
-       # Check if the service is already running?
-       if [ ! -f /var/lock/subsys/memcached ]; then
-               msg_starting memcached
-               daemon /usr/sbin/memcached -d -p $PORT -l $LISTENON -m $MEMUSAGE -c $MAXCONN -u $MEMCACHED_RUNAS $MEMCACHED_OPTS
-               RETVAL=$?
-               [ $RETVAL -eq 0 ] && touch /var/lock/subsys/memcached
-       else
-               msg_already_running memcached
-       fi
+       start
        ;;
   stop)
-       if [ -f /var/lock/subsys/memcached ]; then
-               msg_stopping memcached
-               killproc memcached
-               rm -f /var/run/memcached.pid /var/lock/subsys/memcached >/dev/null 2>&1
-       else
-               msg_not_running memcached
-       fi
+       stop
        ;;
   restart)
-       $0 stop
-       $0 start
-       exit $?
+       stop
+       start
+       ;;
+  try-restart)
+       condrestart 0
+       ;;
+  reload|force-reload)
+       reload
        ;;
   status)
        status memcached
        exit $?
        ;;
-  reload|force-reload)
-       if [ -f /var/lock/subsys/memcached ]; then
-               msg_reloading memcached
-               killproc memcached -HUP
-               RETVAL=$?
-       else
-               msg_not_running memcached >&2
-               RETVAL=7
-       fi
-       ;;
   *)
-       msg_usage "$0 {start|stop|restart|reload|force-reload|status}"
+       msg_usage "$0 {start|stop|restart|try-restart|reload|force-reload|status}"
        exit 3
 esac
 
This page took 0.131041 seconds and 4 git commands to generate.