celeryevcam 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. #!/bin/bash -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. # # Where to chdir at start.
  20. # CELERYD_CHDIR="/opt/Myproject/"
  21. #
  22. # # Extra arguments to celeryev
  23. # CELERYEV_OPTS="-x"
  24. #
  25. # # Name of the celery config module.#
  26. # CELERY_CONFIG_MODULE="celeryconfig"
  27. #
  28. # # Camera class to use (required)
  29. # CELERYEV_CAM = "myapp.Camera"
  30. #
  31. # EXAMPLE DJANGO CONFIGURATION
  32. # ============================
  33. #
  34. # # Where the Django project is.
  35. # CELERYD_CHDIR="/opt/Project/"
  36. #
  37. # # Name of the projects settings module.
  38. # export DJANGO_SETTINGS_MODULE="settings"
  39. #
  40. # # Path to celeryd
  41. # CELERYEV="/opt/Project/manage.py"
  42. #
  43. # # Extra arguments to manage.py
  44. # CELERYEV_OPTS="celeryev"
  45. #
  46. # # Camera class to use (required)
  47. # CELERYEV_CAM = "djcelery.snapshot.Camera"
  48. #
  49. # AVAILABLE OPTIONS
  50. # =================
  51. #
  52. # * CELERYEV_OPTS
  53. # Additional arguments to celeryd, see `celeryd --help` for a list.
  54. #
  55. # * CELERYD_CHDIR
  56. # Path to chdir at start. Default is to stay in the current directory.
  57. #
  58. # * CELERYEV_PID_FILE
  59. # Full path to the pidfile. Default is /var/run/celeryd.pid.
  60. #
  61. # * CELERYEV_LOG_FILE
  62. # Full path to the celeryd logfile. Default is /var/log/celeryd.log
  63. #
  64. # * CELERYEV_LOG_LEVEL
  65. # Log level to use for celeryd. Default is INFO.
  66. #
  67. # * CELERYEV
  68. # Path to the celeryev program. Default is `celeryev`.
  69. # You can point this to an virtualenv, or even use manage.py for django.
  70. #
  71. # * CELERYEV_USER
  72. # User to run celeryev as. Default is current user.
  73. #
  74. # * CELERYEV_GROUP
  75. # Group to run celeryev as. Default is current user.
  76. #
  77. # * VIRTUALENV
  78. # Full path to the virtualenv environment to activate. Default is none.
  79. ### BEGIN INIT INFO
  80. # Provides: celeryev
  81. # Required-Start: $network $local_fs $remote_fs
  82. # Required-Stop: $network $local_fs $remote_fs
  83. # Default-Start: 2 3 4 5
  84. # Default-Stop: 0 1 6
  85. # Short-Description: celery event snapshots
  86. ### END INIT INFO
  87. set -e
  88. DEFAULT_PID_FILE="/var/run/celeryev.pid"
  89. DEFAULT_LOG_FILE="/var/log/celeryev.log"
  90. DEFAULT_LOG_LEVEL="INFO"
  91. DEFAULT_CELERYEV="/usr/bin/celeryev"
  92. if test -f /etc/default/celeryd; then
  93. . /etc/default/celeryd
  94. fi
  95. if test -f /etc/default/celeryev; then
  96. . /etc/default/celeryev
  97. fi
  98. CELERYEV=${CELERYEV:-$DEFAULT_CELERYEV}
  99. CELERYEV_PID_FILE=${CELERYEV_PID_FILE:-${CELERYEV_PIDFILE:-$DEFAULT_PID_FILE}}
  100. CELERYEV_LOG_FILE=${CELERYEV_LOG_FILE:-${CELERYEV_LOGFILE:-$DEFAULT_LOG_FILE}}
  101. CELERYEV_LOG_LEVEL=${CELERYEV_LOG_LEVEL:-${CELERYEV_LOG_LEVEL:-$DEFAULT_LOG_LEVEL}}
  102. export CELERY_LOADER
  103. . /lib/lsb/init-functions
  104. CELERYEV_OPTS="$CELERYEV_OPTS -f $CELERYEV_LOG_FILE -l $CELERYEV_LOG_LEVEL"
  105. if [ -z "$CELERYEV_CAM" ]; then
  106. echo "Missing CELERYEV_CAM variable" 1>&2
  107. exit
  108. fi
  109. CELERYEV_OPTS="$CELERYEV_OPTS -c $CELERYEV_CAM"
  110. if [ -n "$2" ]; then
  111. CELERYEV_OPTS="$CELERYEV_OPTS $2"
  112. fi
  113. # Extra start-stop-daemon options, like user/group.
  114. if [ -n "$CELERYEV_USER" ]; then
  115. DAEMON_OPTS="$DAEMON_OPTS --chuid $CELERYEV_USER"
  116. fi
  117. if [ -n "$CELERYEV_GROUP" ]; then
  118. DAEMON_OPTS="$DAEMON_OPTS --group $CELERYEV_GROUP"
  119. fi
  120. if [ -n "$CELERYEV_CHDIR" ]; then
  121. DAEMON_OPTS="$DAEMON_OPTS --chdir $CELERYEV_CHDIR"
  122. elif [ -n "$CELERYD_CHDIR" ]; then
  123. DAEMON_OPTS="$DAEMON_OPTS --chdir $CELERYD_CHDIR"
  124. fi
  125. # Are we running from init?
  126. run_by_init() {
  127. ([ "$previous" ] && [ "$runlevel" ]) || [ "$runlevel" = S ]
  128. }
  129. check_dev_null() {
  130. if [ ! -c /dev/null ]; then
  131. if [ "$1" = log_end_msg ]; then
  132. log_end_msg 1 || true
  133. fi
  134. if ! run_by_init; then
  135. log_action_msg "/dev/null is not a character device!"
  136. fi
  137. exit 1
  138. fi
  139. }
  140. export PATH="${PATH:+$PATH:}/usr/sbin:/sbin"
  141. stop_evcam () {
  142. cmd="start-stop-daemon --stop \
  143. --quiet \
  144. $* \
  145. --pidfile $CELERYEV_PID_FILE"
  146. if $cmd; then
  147. log_end_msg 0
  148. else
  149. log_end_msg 1
  150. fi
  151. }
  152. start_evcam () {
  153. cmd="start-stop-daemon --start $DAEMON_OPTS \
  154. --quiet \
  155. --oknodo \
  156. --background \
  157. --make-pidfile \
  158. $* \
  159. --pidfile $CELERYEV_PID_FILE
  160. --exec $CELERYEV -- $CELERYEV_OPTS"
  161. if [ -n "$VIRTUALENV" ]; then
  162. source $VIRTUALENV/bin/activate
  163. fi
  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 event snapshots" "celeryev"
  174. start_evcam
  175. ;;
  176. stop)
  177. log_daemon_msg "Stopping celery event snapshots" "celeryev"
  178. stop_evcam --oknodo
  179. ;;
  180. reload|force-reload)
  181. echo "Use start+stop"
  182. ;;
  183. restart)
  184. log_daemon_msg "Restarting celery event snapshots" "celeryev"
  185. stop_evcam --oknodo --retry 30
  186. check_dev_null log_end_msg
  187. start_evcam
  188. ;;
  189. try-restart)
  190. log_daemon_msg "Restarting celery event snapshots" "celeryev"
  191. set +e
  192. stop_evcam --retry 30
  193. RET="$?"
  194. set -e
  195. case $RET in
  196. 0)
  197. # old daemon stopped
  198. check_dev_null log_end_msg
  199. start_evcam
  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. status)
  214. status_of_proc -p $CELERYEV_PID_FILE $CELERYEV celeryev && exit 0 || exit $?
  215. ;;
  216. *)
  217. log_action_msg "Usage: /etc/init.d/celeryev {start|stop|force-reload|restart|try-restart|status}"
  218. exit 1
  219. esac
  220. exit 0