You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
rq/__init__.py

19 lines
538 B
Python

from rdb import conn
from pickle import loads, dumps
def queue_daemon(app, queue_keys, rv_ttl=500):
"""Naive implementation of a Redis queue worker, based on
http://flask.pocoo.org/snippets/73/
Will listen endlessly on the given queue keys.
"""
while True:
msg = conn.blpop(queue_keys)
func, key, args, kwargs = loads(msg[1])
try:
rv = func(*args, **kwargs)
except Exception, e:
rv = e
if rv is not None:
conn.setex(key, rv_ttl, dumps(rv))