celeryd 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. #!/bin/sh -e
  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. # # List of nodes to start
  20. # CELERYD_NODES="worker1 worker2 worker3"k
  21. # # ... can also be a number of workers
  22. # CELERYD_NODES=3
  23. #
  24. # # Where to chdir at start.
  25. # CELERYD_CHDIR="/opt/Myproject/"
  26. #
  27. # # Extra arguments to celeryd
  28. # CELERYD_OPTS="--time-limit 300"
  29. #
  30. # # Name of the celery config module.#
  31. # CELERY_CONFIG_MODULE="celeryconfig"
  32. #
  33. # EXAMPLE DJANGO CONFIGURATION
  34. # ============================
  35. #
  36. # # Where the Django project is.
  37. # CELERYD_CHDIR="/opt/Project/"
  38. #
  39. # # Name of the projects settings module.
  40. # DJANGO_SETTINGS_MODULE="settings"
  41. #
  42. # # Path to celeryd
  43. # CELERYD="/opt/Project/manage.py celeryd"
  44. #
  45. # AVAILABLE OPTIONS
  46. # =================
  47. #
  48. # * CELERYD_NODES
  49. #
  50. # A space separated list of nodes, or a number describing the number of
  51. # nodes, to start
  52. #
  53. # * CELERYD_OPTS
  54. # Additional arguments to celeryd-multi, see ``celeryd-multi --help``
  55. # and ``celeryd --help`` for help.
  56. #
  57. # * CELERYD_CHDIR
  58. # Path to chdir at start. Default is to stay in the current directory.
  59. #
  60. # * CELERYD_PIDFILE
  61. # Full path to the pidfile. Default is /var/run/celeryd.pid.
  62. #
  63. # * CELERYD_LOGFILE
  64. # Full path to the celeryd logfile. Default is /var/log/celeryd.log
  65. #
  66. # * CELERYD_LOG_LEVEL
  67. # Log level to use for celeryd. Default is INFO.
  68. #
  69. # * CELERYD
  70. # Path to the celeryd program. Default is ``celeryd``.
  71. # You can point this to an virtualenv, or even use manage.py for django.
  72. #
  73. # * CELERYD_USER
  74. # User to run celeryd as. Default is current user.
  75. #
  76. # * CELERYD_GROUP
  77. # Group to run celeryd as. Default is current user.
  78. # VARIABLE EXPANSION
  79. # ==================
  80. #
  81. # The following abbreviations will be expanded
  82. #
  83. # * %n -> node name
  84. # * %h -> host name
  85. ### BEGIN INIT INFO
  86. # Provides: celeryd
  87. # Required-Start: $network $local_fs $remote_fs
  88. # Required-Stop: $network $local_fs $remote_fs
  89. # Default-Start: 2 3 4 5
  90. # Default-Stop: 0 1 6
  91. # Short-Description: celery task worker daemon
  92. ### END INIT INFO
  93. # OS X Debug replacements to lsb-functions.
  94. log_action_msg () {
  95. echo $*
  96. }
  97. log_daemon_msg () {
  98. echo $*
  99. }
  100. log_end_msg () {
  101. if [ $1 -eq 0 ]; then
  102. echo "ok"
  103. else
  104. echo "failed!"
  105. fi
  106. }
  107. set -e
  108. CELERYD_PID_FILE="celeryd@%n.pid"
  109. CELERYD_LOG_FILE="celeryd@%n.log"
  110. CELERYD_LOG_LEVEL="INFO"
  111. DEFAULT_CELERYD="celeryd"
  112. # /etc/init.d/ssh: start and stop the celery task worker daemon.
  113. if test -f /etc/default/celeryd; then
  114. . /etc/default/celeryd
  115. fi
  116. CELERYD_MULTI=${CELERYD_MULTI:-"celeryd-multi"}
  117. CELERYD=${CELERYD:-$DEFAULT_CELERYD}
  118. CELERYD_NODES=${CELERYD_NODES:-"celery"}
  119. export CELERY_LOADER
  120. CELERYD_OPTS="$CELERYD_OPTS --logfile=$CELERYD_LOG_FILE \
  121. --loglevel=$CELERYD_LOG_LEVEL"
  122. if [ -n "$2" ]; then
  123. CELERYD_OPTS="$CELERYD_OPTS $2"
  124. fi
  125. # Extra start-stop-daemon options, like user/group.
  126. if [ -n "$CELERYD_USER" ]; then
  127. DAEMON_OPTS="$DAEMON_OPTS --uid=$CELERYD_USER"
  128. fi
  129. if [ -n "$CELERYD_GROUP" ]; then
  130. DAEMON_OPTS="$DAEMON_OPTS --gid=$CELERYD_GROUP"
  131. fi
  132. if [ -n "$CELERYD_CHDIR" ]; then
  133. DAEMON_OPTS="$DAEMON_OPTS --chdir=$CELERYD_CHDIR"
  134. fi
  135. # Are we running from init?
  136. run_by_init() {
  137. ([ "$previous" ] && [ "$runlevel" ]) || [ "$runlevel" = S ]
  138. }
  139. check_dev_null() {
  140. if [ ! -c /dev/null ]; then
  141. if [ "$1" = log_end_msg ]; then
  142. log_end_msg 1 || true
  143. fi
  144. if ! run_by_init; then
  145. log_action_msg "/dev/null is not a character device!"
  146. fi
  147. exit 1
  148. fi
  149. }
  150. export PATH="${PATH:+$PATH:}/usr/sbin:/sbin"
  151. stop_worker () {
  152. cmd="celeryd-multi stop $CELERYD_NODES --pidfile=$CELERYD_PID_FILE"
  153. if $cmd; then
  154. log_end_msg 0
  155. else
  156. log_end_msg 1
  157. fi
  158. }
  159. start_worker () {
  160. cmd="celeryd-multi start $CELERYD_NODES $DAEMON_OPTS \
  161. --pidfile=$CELERYD_PID_FILE \
  162. --cmd="$CELERYD" \
  163. $CELERYD_OPTS"
  164. if $cmd; then
  165. log_end_msg 0
  166. else
  167. log_end_msg 1
  168. fi
  169. }
  170. case "$1" in
  171. start)
  172. check_dev_null
  173. log_daemon_msg "Starting celery worker nodes" "celeryd-multi"
  174. start_worker
  175. ;;
  176. stop)
  177. log_daemon_msg "Stopping celery worker nodes" "celeryd-multi"
  178. stop_worker
  179. ;;
  180. reload|force-reload)
  181. echo "Use start+stop"
  182. ;;
  183. restart)
  184. log_daemon_msg "Restarting celery worker nodes" "celeryd-multi"
  185. stop_worker
  186. check_dev_null log_end_msg
  187. start_worker
  188. ;;
  189. try-restart)
  190. log_daemon_msg "Restarting celery worker nodes" "celeryd-multi"
  191. set +e
  192. stop_worker
  193. RET="$?"
  194. set -e
  195. case $RET in
  196. 0)
  197. # old daemon stopped
  198. check_dev_null log_end_msg
  199. start_worker
  200. ;;
  201. 1)
  202. # daemon not running
  203. log_progress_msg "(not running)"
  204. log_end_msg 0
  205. ;;
  206. *)
  207. # failed to stop
  208. log_progress_msg "(failed to stop)"
  209. log_end_msg 1
  210. ;;
  211. esac
  212. ;;
  213. *)
  214. log_action_msg "Usage: /etc/init.d/celeryd {start|stop|force-reload|restart|try-restart|status}"
  215. exit 1
  216. esac
  217. exit 0