__init__.py
74 lines
| 1.9 KiB
| text/x-python
|
PythonLexer
r776 | import os | |||
import sys | ||||
import socket | ||||
import traceback | ||||
import logging | ||||
r547 | from rhodecode.lib.pidlock import DaemonLock, LockHeld | |||
from vcs.utils.lazy import LazyProperty | ||||
from decorator import decorator | ||||
from hashlib import md5 | ||||
r776 | from pylons import config | |||
r547 | log = logging.getLogger(__name__) | |||
r776 | def str2bool(v): | |||
return v.lower() in ["yes", "true", "t", "1"] if v else None | ||||
CELERY_ON = str2bool(config['app_conf'].get('use_celery')) | ||||
r547 | class ResultWrapper(object): | |||
def __init__(self, task): | ||||
self.task = task | ||||
r776 | ||||
r547 | @LazyProperty | |||
def result(self): | ||||
return self.task | ||||
def run_task(task, *args, **kwargs): | ||||
r776 | if CELERY_ON: | |||
try: | ||||
t = task.delay(*args, **kwargs) | ||||
log.info('running task %s:%s', t.task_id, task) | ||||
return t | ||||
except socket.error, e: | ||||
if e.errno == 111: | ||||
log.debug('Unable to connect to celeryd. Sync execution') | ||||
else: | ||||
log.error(traceback.format_exc()) | ||||
except KeyError, e: | ||||
log.debug('Unable to connect to celeryd. Sync execution') | ||||
except Exception, e: | ||||
log.error(traceback.format_exc()) | ||||
log.debug('executing task %s in sync mode', task) | ||||
r558 | return ResultWrapper(task(*args, **kwargs)) | |||
r547 | ||||
def locked_task(func): | ||||
def __wrapper(func, *fargs, **fkwargs): | ||||
params = list(fargs) | ||||
params.extend(['%s-%s' % ar for ar in fkwargs.items()]) | ||||
r776 | ||||
r547 | lockkey = 'task_%s' % \ | |||
md5(str(func.__name__) + '-' + \ | ||||
'-'.join(map(str, params))).hexdigest() | ||||
log.info('running task with lockkey %s', lockkey) | ||||
try: | ||||
l = DaemonLock(lockkey) | ||||
ret = func(*fargs, **fkwargs) | ||||
l.release() | ||||
return ret | ||||
except LockHeld: | ||||
log.info('LockHeld') | ||||
r776 | return 'Task with key %s already running' % lockkey | |||
r547 | ||||
r776 | return decorator(__wrapper, func) | |||
r547 | ||||
r776 | ||||