celeryd 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. #!/bin/sh
  2. # ============================================
  3. # celeryd - Starts the Celery worker daemon.
  4. # ============================================
  5. #
  6. # :Usage: /etc/init.d/celeryd {start|stop|force-reload|restart|try-restart|status}
  7. #
  8. # :Configuration file: /etc/default/celeryd
  9. #
  10. # To configure celeryd you probably need to tell it where to chdir.
  11. #
  12. # EXAMPLE CONFIGURATION
  13. # =====================
  14. #
  15. # this is an example configuration for a Python project:
  16. #
  17. # /etc/default/celeryd:
  18. #
  19. # # Where to chdir at start.
  20. # CELERYD_CHDIR="/opt/Myproject/"
  21. #
  22. # # Extra arguments to celeryd
  23. # CELERYD_OPTS="--time-limit 300"
  24. #
  25. # # Name of the celery config module.#
  26. # CELERY_CONFIG_MODULE="celeryconfig"
  27. #
  28. # EXAMPLE DJANGO CONFIGURATION
  29. # ============================
  30. #
  31. # # Where the Django project is.
  32. # CELERYD_CHDIR="/opt/Project/"
  33. #
  34. # # Name of the projects settings module.
  35. # DJANGO_SETTINGS_MODULE="settings"
  36. #
  37. # # Path to celeryd
  38. # CELERYD="/opt/Project/manage.py celeryd"
  39. #
  40. # AVAILABLE OPTIONS
  41. # =================
  42. #
  43. # * CELERYD_OPTS
  44. # Additional arguments to celeryd, see ``celeryd --help`` for a list.
  45. #
  46. # * CELERYD_CHDIR
  47. # Path to chdir at start. Default is to stay in the current directory.
  48. #
  49. # * CELERYD_PIDFILE
  50. # Full path to the pidfile. Default is /var/run/celeryd.pid.
  51. #
  52. # * CELERYD_LOGFILE
  53. # Full path to the celeryd logfile. Default is /var/log/celeryd.log
  54. #
  55. # * CELERYD_LOG_LEVEL
  56. # Log level to use for celeryd. Default is INFO.
  57. #
  58. # * CELERYD
  59. # Path to the celeryd program. Default is ``celeryd``.
  60. # You can point this to an virtualenv, or even use manage.py for django.
  61. #
  62. # * CELERYD_USER
  63. # User to run celeryd as. Default is current user.
  64. #
  65. # * CELERYD_GROUP
  66. # Group to run celeryd as. Default is current user.
  67. ### BEGIN INIT INFO
  68. # Provides: celeryd
  69. # Required-Start:
  70. # Required-Stop:
  71. # Default-Start: 2 3 4 5
  72. # Default-Stop: 1
  73. # Short-Description: celery task worker daemon
  74. ### END INIT INFO
  75. set -e
  76. CELERYD_PID_FILE="/var/run/celeryd.pid"
  77. CELERYD_LOG_FILE="/var/log/celeryd.log"
  78. CELERYD_LOG_LEVEL="INFO"
  79. DEFAULT_CELERYD="celeryd"
  80. # /etc/init.d/ssh: start and stop the celery task worker daemon.
  81. if test -f /etc/default/celeryd; then
  82. . /etc/default/celeryd
  83. fi
  84. CELERYD=${CELERYD:-$DEFAULT_CELERYD}
  85. export CELERY_LOADER
  86. . /lib/lsb/init-functions
  87. CELERYD_OPTS="$CELERYD_OPTS -f $CELERYD_LOG_FILE -l $CELERYD_LOG_LEVEL"
  88. if [ -n "$2" ]; then
  89. CELERYD_OPTS="$CELERYD_OPTS $2"
  90. fi
  91. # Extra start-stop-daemon options, like user/group.
  92. if [ -n "$CELERYD_USER" ]; then
  93. DAEMON_OPTS="$DAEMON_OPTS --chuid $CELERYD_USER"
  94. fi
  95. if [ -n "$CELERYD_GROUP" ]; then
  96. DAEMON_OPTS="$DAEMON_OPTS --group $CELERYD_GROUP"
  97. fi
  98. if [ -n "$CELERYD_CHDIR" ]; then
  99. DAEMON_OPTS="$DAEMON_OPTS --chdir $CELERYD_CHDIR"
  100. fi
  101. # Are we running from init?
  102. run_by_init() {
  103. ([ "$previous" ] && [ "$runlevel" ]) || [ "$runlevel" = S ]
  104. }
  105. check_dev_null() {
  106. if [ ! -c /dev/null ]; then
  107. if [ "$1" = log_end_msg ]; then
  108. log_end_msg 1 || true
  109. fi
  110. if ! run_by_init; then
  111. log_action_msg "/dev/null is not a character device!"
  112. fi
  113. exit 1
  114. fi
  115. }
  116. export PATH="${PATH:+$PATH:}/usr/sbin:/sbin"
  117. stop_worker () {
  118. cmd="start-stop-daemon --stop \
  119. --quiet \
  120. $* \
  121. --pidfile $CELERYD_PID_FILE"
  122. if `$cmd`; then
  123. log_end_msg 0
  124. else
  125. log_end_msg 1
  126. fi
  127. }
  128. start_worker () {
  129. cmd="start-stop-daemon --start $DAEMON_OPTS \
  130. --quiet \
  131. --oknodo \
  132. --background \
  133. --make-pidfile \
  134. $* \
  135. --pidfile $CELERYD_PID_FILE
  136. --exec $CELERYD -- $CELERYD_OPTS"
  137. if `$cmd`; then
  138. log_end_msg 0
  139. else
  140. log_end_msg 1
  141. fi
  142. }
  143. case "$1" in
  144. start)
  145. check_dev_null
  146. log_daemon_msg "Starting celery task worker server" "celeryd"
  147. start_worker
  148. ;;
  149. stop)
  150. log_daemon_msg "Stopping celery task worker server" "celeryd"
  151. stop_worker --oknodo
  152. ;;
  153. reload|force-reload)
  154. echo "Use start+stop"
  155. ;;
  156. restart)
  157. log_daemon_msg "Restarting celery task worker server" "celeryd"
  158. stop_worker --oknodo --retry 30
  159. check_dev_null log_end_msg
  160. start_worker
  161. ;;
  162. try-restart)
  163. log_daemon_msg "Restarting celery task worker server" "celeryd"
  164. set +e
  165. stop_worker --retry 30
  166. RET="$?"
  167. set -e
  168. case $RET in
  169. 0)
  170. # old daemon stopped
  171. check_dev_null log_end_msg
  172. start_worker
  173. ;;
  174. 1)
  175. # daemon not running
  176. log_progress_msg "(not running)"
  177. log_end_msg 0
  178. ;;
  179. *)
  180. # failed to stop
  181. log_progress_msg "(failed to stop)"
  182. log_end_msg 1
  183. ;;
  184. esac
  185. ;;
  186. status)
  187. status_of_proc -p $CELERYD_PID_FILE $CELERYD celeryd && exit 0 || exit $?
  188. ;;
  189. *)
  190. log_action_msg "Usage: /etc/init.d/celeryd {start|stop|force-reload|restart|try-restart|status}"
  191. exit 1
  192. esac
  193. exit 0