celerybeat.py 2.3 KB

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