celerybeat.py 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. # -*- coding: utf-8 -*-
  2. """celerybeat
  3. .. program:: celerybeat
  4. .. seealso::
  5. See :ref:`preload-options` and :ref:`daemon-options`.
  6. .. cmdoption:: --detach
  7. Detach and run in the background as a daemon.
  8. .. cmdoption:: -s, --schedule
  9. Path to the schedule database. Defaults to `celerybeat-schedule`.
  10. The extension ".db" may be appended to the filename.
  11. Default is %(default)s.
  12. .. cmdoption:: -S, --scheduler
  13. Scheduler class to use.
  14. Default is :class:`celery.beat.PersistentScheduler`.
  15. .. cmdoption:: max-interval
  16. Max seconds to sleep between schedule iterations.
  17. .. cmdoption:: -f, --logfile
  18. Path to log file. If no logfile is specified, `stderr` is used.
  19. .. cmdoption:: -l, --loglevel
  20. Logging level, choose between `DEBUG`, `INFO`, `WARNING`,
  21. `ERROR`, `CRITICAL`, or `FATAL`.
  22. """
  23. from __future__ import with_statement
  24. from __future__ import absolute_import
  25. import os
  26. from functools import partial
  27. from celery.platforms import detached
  28. from celery.bin.base import Command, Option, daemon_options
  29. class BeatCommand(Command):
  30. doc = __doc__
  31. enable_config_from_cmdline = True
  32. supports_args = False
  33. preload_options = (Command.preload_options
  34. + daemon_options(default_pidfile="celerybeat.pid"))
  35. def run(self, detach=False, logfile=None, pidfile=None, uid=None,
  36. gid=None, umask=None, working_directory=None, **kwargs):
  37. workdir = working_directory
  38. kwargs.pop("app", None)
  39. beat = partial(self.app.Beat,
  40. logfile=logfile, pidfile=pidfile, **kwargs)
  41. if detach:
  42. with detached(logfile, pidfile, uid, gid, umask, workdir):
  43. return beat().run()
  44. else:
  45. return beat().run()
  46. def prepare_preload_options(self, options):
  47. workdir = options.get("working_directory")
  48. if workdir:
  49. os.chdir(workdir)
  50. def get_options(self):
  51. c = self.app.conf
  52. return (
  53. Option('--detach', action="store_true"),
  54. Option('-s', '--schedule', default=c.CELERYBEAT_SCHEDULE_FILENAME),
  55. Option('--max-interval', type="float"),
  56. Option('-S', '--scheduler', dest="scheduler_cls"),
  57. Option('-l', '--loglevel', default=c.CELERYBEAT_LOG_LEVEL),
  58. )
  59. def main():
  60. beat = BeatCommand()
  61. beat.execute_from_commandline()
  62. if __name__ == "__main__": # pragma: no cover
  63. main()