events.py 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. # -*- coding: utf-8 -*-
  2. """The :program:`celery events` command.
  3. .. program:: celery events
  4. .. seealso::
  5. See :ref:`preload-options` and :ref:`daemon-options`.
  6. .. cmdoption:: -d, --dump
  7. Dump events to stdout.
  8. .. cmdoption:: -c, --camera
  9. Take snapshots of events using this camera.
  10. .. cmdoption:: --detach
  11. Camera: Detach and run in the background as a daemon.
  12. .. cmdoption:: -F, --freq, --frequency
  13. Camera: Shutter frequency. Default is every 1.0 seconds.
  14. .. cmdoption:: -r, --maxrate
  15. Camera: Optional shutter rate limit (e.g., 10/m).
  16. .. cmdoption:: -l, --loglevel
  17. Logging level, choose between `DEBUG`, `INFO`, `WARNING`,
  18. `ERROR`, `CRITICAL`, or `FATAL`. Default is INFO.
  19. .. cmdoption:: -f, --logfile
  20. Path to log file. If no logfile is specified, `stderr` is used.
  21. .. cmdoption:: --pidfile
  22. Optional file used to store the process pid.
  23. The program won't start if this file already exists
  24. and the pid is still alive.
  25. .. cmdoption:: --uid
  26. User id, or user name of the user to run as after detaching.
  27. .. cmdoption:: --gid
  28. Group id, or group name of the main group to change to after
  29. detaching.
  30. .. cmdoption:: --umask
  31. Effective umask (in octal) of the process after detaching. Inherits
  32. the umask of the parent process by default.
  33. .. cmdoption:: --workdir
  34. Optional directory to change to after detaching.
  35. .. cmdoption:: --executable
  36. Executable to use for the detached process.
  37. """
  38. from __future__ import absolute_import, unicode_literals
  39. import sys
  40. from functools import partial
  41. from celery.platforms import detached, set_process_title, strargv
  42. from celery.bin.base import Command, daemon_options
  43. __all__ = ['events']
  44. HELP = __doc__
  45. class events(Command):
  46. """Event-stream utilities.
  47. Notes:
  48. .. code-block:: console
  49. # - Start graphical monitor (requires curses)
  50. $ celery events --app=proj
  51. $ celery events -d --app=proj
  52. # - Dump events to screen.
  53. $ celery events -b amqp://
  54. # - Run snapshot camera.
  55. $ celery events -c <camera> [options]
  56. Examples:
  57. .. code-block:: console
  58. $ celery events
  59. $ celery events -d
  60. $ celery events -c mod.attr -F 1.0 --detach --maxrate=100/m -l info
  61. """
  62. doc = HELP
  63. supports_args = False
  64. def run(self, dump=False, camera=None, frequency=1.0, maxrate=None,
  65. loglevel='INFO', logfile=None, prog_name='celery events',
  66. pidfile=None, uid=None, gid=None, umask=None,
  67. workdir=None, detach=False, **kwargs):
  68. self.prog_name = prog_name
  69. if dump:
  70. return self.run_evdump()
  71. if camera:
  72. return self.run_evcam(camera, freq=frequency, maxrate=maxrate,
  73. loglevel=loglevel, logfile=logfile,
  74. pidfile=pidfile, uid=uid, gid=gid,
  75. umask=umask,
  76. workdir=workdir,
  77. detach=detach)
  78. return self.run_evtop()
  79. def run_evdump(self):
  80. from celery.events.dumper import evdump
  81. self.set_process_status('dump')
  82. return evdump(app=self.app)
  83. def run_evtop(self):
  84. from celery.events.cursesmon import evtop
  85. self.set_process_status('top')
  86. return evtop(app=self.app)
  87. def run_evcam(self, camera, logfile=None, pidfile=None, uid=None,
  88. gid=None, umask=None, workdir=None,
  89. detach=False, **kwargs):
  90. from celery.events.snapshot import evcam
  91. self.set_process_status('cam')
  92. kwargs['app'] = self.app
  93. cam = partial(evcam, camera,
  94. logfile=logfile, pidfile=pidfile, **kwargs)
  95. if detach:
  96. with detached(logfile, pidfile, uid, gid, umask, workdir):
  97. return cam()
  98. else:
  99. return cam()
  100. def set_process_status(self, prog, info=''):
  101. prog = '{0}:{1}'.format(self.prog_name, prog)
  102. info = '{0} {1}'.format(info, strargv(sys.argv))
  103. return set_process_title(prog, info=info)
  104. def add_arguments(self, parser):
  105. dopts = parser.add_argument_group('Dumper')
  106. dopts.add_argument('-d', '--dump', action='store_true', default=False)
  107. copts = parser.add_argument_group('Snapshot')
  108. copts.add_argument('-c', '--camera')
  109. copts.add_argument('--detach', action='store_true', default=False)
  110. copts.add_argument('-F', '--frequency', '--freq',
  111. type=float, default=1.0)
  112. copts.add_argument('-r', '--maxrate')
  113. copts.add_argument('-l', '--loglevel', default='INFO')
  114. daemon_options(parser, default_pidfile='celeryev.pid')
  115. user_options = self.app.user_options['events']
  116. if user_options:
  117. self.add_compat_options(
  118. parser.add_argument_group('User Options'),
  119. user_options)
  120. def main():
  121. ev = events()
  122. ev.execute_from_commandline()
  123. if __name__ == '__main__': # pragma: no cover
  124. main()