celeryd-multi 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. #!/bin/sh -e
  2. ### BEGIN INIT INFO
  3. # Provides: celeryd-multi
  4. # Required-Start: $network $local_fs $remote_fs
  5. # Required-Stop: $network $local_fs $remote_fs
  6. # Default-Start: 2 3 4 5
  7. # Default-Stop: 0 1 6
  8. # Short-Description: celery task multiple workers daemon
  9. ### END INIT INFO
  10. # OS X Debug replacements to lsb-functions.
  11. #log_action_msg () {
  12. # echo $*
  13. #}
  14. #log_daemon_msg () {
  15. # echo $*
  16. #}
  17. #log_end_msg () {
  18. # if [ $1 -eq 0 ]; then
  19. # echo "ok"
  20. # else
  21. # echo "failed!"
  22. # fi
  23. #}
  24. set -e
  25. CELERYD_PID_FILE="/var/run/celeryd-%n.pid"
  26. CELERYD_LOG_FILE="/var/log/celeryd-%n.log"
  27. CELERYD_LOG_LEVEL="INFO"
  28. CELERYD_NUM_WORKERS=2
  29. DEFAULT_CELERYD="celeryd"
  30. # /etc/init.d/celeryd-multi start and stop the celery task worker daemon.
  31. if test -f /etc/default/celeryd; then
  32. . /etc/default/celeryd
  33. fi
  34. export CELERY_LOADER
  35. . /lib/lsb/init-functions
  36. CELERYD_OPTS="$CELERYD_OPTS -f $CELERYD_LOG_FILE -l $CELERYD_LOG_LEVEL"
  37. if [ -n "$2" ]; then
  38. CELERYD_OPTS="$CELERYD_OPTS $2"
  39. fi
  40. # Extra start-stop-daemon options, like user/group.
  41. if [ -n "$CELERYD_USER" ]; then
  42. DAEMON_OPTS="$DAEMON_OPTS --chuid $CELERYD_USER"
  43. fi
  44. if [ -n "$CELERYD_GROUP" ]; then
  45. DAEMON_OPTS="$DAEMON_OPTS --group $CELERYD_GROUP"
  46. fi
  47. # Are we running from init?
  48. run_by_init() {
  49. ([ "$previous" ] && [ "$runlevel" ]) || [ "$runlevel" = S ]
  50. }
  51. check_dev_null() {
  52. if [ ! -c /dev/null ]; then
  53. if [ "$1" = log_end_msg ]; then
  54. log_end_msg 1 || true
  55. fi
  56. if ! run_by_init; then
  57. log_action_msg "/dev/null is not a character device!"
  58. fi
  59. exit 1
  60. fi
  61. }
  62. export PATH="${PATH:+$PATH:}/usr/sbin:/sbin"
  63. if [ ! -z "$VIRTUALENV" ]; then
  64. export PATH="$VIRTUALENV/bin:$PATH"
  65. CELERYD="$VIRTUALENV/bin/$CELERYD"
  66. fi
  67. if [ -f "$CELERYD" -a ! -x "$CELERYD" ]; then
  68. echo "ERROR: $CELERYD is not executable."
  69. echo "Please make it executable by doing: chmod +x '$CELERYD'"
  70. echo "celeryd is disabled"
  71. exit
  72. fi
  73. WORKERS=$CELERYD_NUM_WORKERS
  74. stop_worker () {
  75. cmd="start-stop-daemon --stop --quiet $* --pidfile $CELERYD_PID_FILE"
  76. stopcmd=`celeryd-multi expand "$cmd" $WORKERS`
  77. log_daemon_msg "Stopping celery task workers..."
  78. if eval "$stopcmd"; then
  79. log_end_msg 0
  80. else
  81. log_end_msg 1
  82. fi
  83. }
  84. start_worker () {
  85. check_dev_null
  86. cmd="start-stop-daemon --start $DAEMON_OPTS \
  87. --quiet --oknodo --background \
  88. --make-pidfile $* \
  89. --pidfile $CELERYD_PID_FILE \
  90. --exec $CELERYD --"
  91. for wname in `celeryd-multi names $WORKERS $CELERYD_OPTS`; do
  92. log_daemon_msg "Starting celery task worker" "$wname"
  93. startcmd=`celeryd-multi get "$wname" $WORKERS --cmd="$cmd" $CELERYD_OPTS`
  94. if `$startcmd`; then
  95. log_end_msg 0
  96. else
  97. log_end_msg 1
  98. fi
  99. done
  100. }
  101. case "$1" in
  102. start)
  103. start_worker
  104. ;;
  105. stop)
  106. stop_worker --oknodo
  107. ;;
  108. reload|force-reload)
  109. echo "Use start+stop"
  110. ;;
  111. restart)
  112. stop_worker --retry 30 --oknodo
  113. start_worker
  114. ;;
  115. try-restart)
  116. log_daemon_msg "Restarting celery task worker server" "celeryd"
  117. set +e
  118. stop_worker --retry 30
  119. RET="$?"
  120. set -e
  121. case $RET in
  122. 0)
  123. # old daemon stopped
  124. check_dev_null log_end_msg
  125. start_worker
  126. ;;
  127. 1)
  128. # daemon not running
  129. log_progress_msg "(not running)"
  130. log_end_msg 0
  131. ;;
  132. *)
  133. # failed to stop
  134. log_progress_msg "(failed to stop)"
  135. log_end_msg 1
  136. ;;
  137. esac
  138. ;;
  139. status)
  140. pidfiles=`celeryd-multi expand "$CELERYD_PID_FILE" $WORKERS $DAEMON_OPTS`
  141. for pidfile in $pidfiles; do
  142. status_of_proc -p $pidfile $CELERYD celeryd && exit 0 || exit $?
  143. done
  144. ;;
  145. *)
  146. log_action_msg "Usage: /etc/init.d/celeryd-multi {start|stop|force-reload|restart|try-restart|status}"
  147. exit 1
  148. esac
  149. exit 0