2022-04-14 11:02:52 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2012-11-02 14:32:45 +00:00
|
|
|
from kombu.log import get_logger
|
2021-07-20 13:07:49 +00:00
|
|
|
from kombu.mixins import ConsumerMixin
|
2016-07-16 20:33:32 +00:00
|
|
|
from kombu.utils.functional import reprcall
|
2011-09-12 09:25:42 +00:00
|
|
|
|
2013-09-10 16:26:12 +00:00
|
|
|
from .queues import task_queues
|
2011-09-12 09:25:42 +00:00
|
|
|
|
2012-11-02 14:32:45 +00:00
|
|
|
logger = get_logger(__name__)
|
|
|
|
|
2011-09-12 09:47:22 +00:00
|
|
|
|
2011-09-12 09:25:42 +00:00
|
|
|
class Worker(ConsumerMixin):
|
|
|
|
|
2011-09-12 09:47:22 +00:00
|
|
|
def __init__(self, connection):
|
|
|
|
self.connection = connection
|
|
|
|
|
2011-09-12 09:25:42 +00:00
|
|
|
def get_consumers(self, Consumer, channel):
|
2011-09-12 09:47:22 +00:00
|
|
|
return [Consumer(queues=task_queues,
|
2013-05-01 17:17:51 +00:00
|
|
|
accept=['pickle', 'json'],
|
2011-09-12 09:47:22 +00:00
|
|
|
callbacks=[self.process_task])]
|
2011-09-12 09:25:42 +00:00
|
|
|
|
2011-09-12 09:47:22 +00:00
|
|
|
def process_task(self, body, message):
|
2012-06-24 15:32:17 +00:00
|
|
|
fun = body['fun']
|
|
|
|
args = body['args']
|
|
|
|
kwargs = body['kwargs']
|
2012-11-02 14:32:45 +00:00
|
|
|
logger.info('Got task: %s', reprcall(fun.__name__, args, kwargs))
|
2011-09-12 09:47:22 +00:00
|
|
|
try:
|
2014-05-19 21:27:36 +00:00
|
|
|
fun(*args, **kwargs)
|
2013-02-12 15:06:49 +00:00
|
|
|
except Exception as exc:
|
2012-11-02 14:32:45 +00:00
|
|
|
logger.error('task raised exception: %r', exc)
|
2011-09-12 09:25:42 +00:00
|
|
|
message.ack()
|
|
|
|
|
2021-07-20 13:07:49 +00:00
|
|
|
|
2012-06-24 15:32:17 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
from kombu import Connection
|
2011-10-18 10:36:14 +00:00
|
|
|
from kombu.utils.debug import setup_logging
|
2021-07-20 13:07:49 +00:00
|
|
|
|
2013-05-01 17:17:51 +00:00
|
|
|
# setup root logger
|
|
|
|
setup_logging(loglevel='INFO', loggers=[''])
|
2011-09-12 09:25:42 +00:00
|
|
|
|
2012-06-24 15:32:17 +00:00
|
|
|
with Connection('amqp://guest:guest@localhost:5672//') as conn:
|
2011-09-12 11:57:12 +00:00
|
|
|
try:
|
2013-05-01 17:17:51 +00:00
|
|
|
worker = Worker(conn)
|
|
|
|
worker.run()
|
2011-09-12 11:57:12 +00:00
|
|
|
except KeyboardInterrupt:
|
2012-06-24 15:32:17 +00:00
|
|
|
print('bye bye')
|