當前位置: 首頁>>代碼示例>>Python>>正文


Python celery.shared_task方法代碼示例

本文整理匯總了Python中celery.shared_task方法的典型用法代碼示例。如果您正苦於以下問題:Python celery.shared_task方法的具體用法?Python celery.shared_task怎麽用?Python celery.shared_task使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在celery的用法示例。


在下文中一共展示了celery.shared_task方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def task(*d_args, **d_kwargs):
    # behaves like @task, but emails about exceptions.
    def real_decorator(f):
        @shared_task(*d_args, **d_kwargs)
        @wraps(f)
        def wrapper(*f_args, **f_kwargs):
            # try the task; email any exceptions we get
            try:
                res = f(*f_args, **f_kwargs)
            except Exception as e:
                # email admins and re-raise
                exc_type, exc_value, exc_traceback = sys.exc_info()
                subject = 'task failure in %s.%s' % (f.__module__, f.__name__)
                msg = 'The task %s.%s failed:\n\n%s' % (f.__module__, f.__name__,
                        '\n'.join(traceback.format_exception(exc_type, exc_value, exc_traceback)))
                mail_admins(subject=subject, message=msg, fail_silently=True)
                raise

            return res
        return wrapper
    return real_decorator 
開發者ID:sfu-fas,項目名稱:coursys,代碼行數:23,代碼來源:celerytasks.py

示例2: shared_task_conditional

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def shared_task_conditional(**kwargs):  # pragma: no cover
    """Decorator to optionally disable celery tests."""
    def decorator(func):
        if settings.NO_CELERY:
            setattr(func, 'delay', func)
            return func

        # Get the real decorator
        dec = shared_task(func, **kwargs)

        # Create a stub to apply a countdown and run
        def patched(*args, **kwargs):
            return dec.apply_async(
                args=args, kwargs=kwargs, countdown=settings.CELERY_DELAY)

        # Substitute the delay method
        dec.delay = patched
        return dec

    return decorator 
開發者ID:wncc,項目名稱:instiapp-api,代碼行數:22,代碼來源:celery.py

示例3: test_shared_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def test_shared_task(celery_app, memory_exporter):
    """Ensure Django Shared Task are supported"""

    @celery.shared_task
    def add(x, y):
        return x + y

    result = add.apply([2, 2])
    assert result.result == 4

    spans = memory_exporter.get_finished_spans()
    assert len(spans) == 1

    span = spans[0]

    assert span.status.is_ok is True
    assert span.name == "test_celery_functional.add"
    assert (
        span.attributes.get("celery.task_name") == "test_celery_functional.add"
    )
    assert span.attributes.get("celery.action") == "run"
    assert span.attributes.get("celery.state") == "SUCCESS"
    assert span.attributes.get("messaging.message_id") == result.task_id 
開發者ID:open-telemetry,項目名稱:opentelemetry-python,代碼行數:25,代碼來源:test_celery_functional.py

示例4: shared_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def shared_task(task):  # noqa: D103, pylint: disable=missing-docstring
        return task 
開發者ID:genialis,項目名稱:resolwe,代碼行數:4,代碼來源:tasks.py

示例5: task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def task(self):
        return shared_task(**self.config)(self._run_task)


# Define tasks so that Celery can discovery them 
開發者ID:desec-io,項目名稱:desec-stack,代碼行數:7,代碼來源:mail_backends.py

示例6: shared_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def shared_task(func):
        def wrapper(*args, **kwargs):
            return func(*args, **kwargs)
        return wrapper 
開發者ID:bitlabstudio,項目名稱:django-influxdb-metrics,代碼行數:6,代碼來源:tasks.py

示例7: _create_db_asset

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def _create_db_asset(fcn, model, args, key):
    if getattr(settings, 'LEDGER_SYNC_ENABLED', True):
        return __create_db_asset(model, fcn, args, key, sync=True)
    else:
        shared_task(__create_db_asset)(model, fcn, args, key, sync=False)
        return {'message': _MESSAGE} 
開發者ID:SubstraFoundation,項目名稱:substra-backend,代碼行數:8,代碼來源:ledger.py

示例8: _create_db_assets

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def _create_db_assets(fcn, model, args, keys):
    if getattr(settings, 'LEDGER_SYNC_ENABLED', True):
        return __create_db_assets(model, fcn, args, keys, sync=True)
    else:
        shared_task(__create_db_asset)(model, fcn, args, keys, sync=False)
        return {'message': _MESSAGE} 
開發者ID:SubstraFoundation,項目名稱:substra-backend,代碼行數:8,代碼來源:ledger.py

示例9: __create_asset

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def __create_asset(fcn, args, sync=False, **extra_kwargs):
    # create a wrapper as it seems the shared_task decorator from celery is not
    # compatible with our retry decorator on the invoke_ledger function
    return invoke_ledger(fcn=fcn, args=args, sync=sync, **extra_kwargs) 
開發者ID:SubstraFoundation,項目名稱:substra-backend,代碼行數:6,代碼來源:ledger.py

示例10: _create_asset

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def _create_asset(fcn, args, **extra_kwargs):
    if getattr(settings, 'LEDGER_SYNC_ENABLED', True):
        return __create_asset(fcn, args=args, sync=True, **extra_kwargs)
    else:
        shared_task(__create_asset)(fcn, args=args, sync=False, **extra_kwargs)
        return {'message': _MESSAGE} 
開發者ID:SubstraFoundation,項目名稱:substra-backend,代碼行數:8,代碼來源:ledger.py

示例11: configure_worker

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def configure_worker(options={}, **kwargs):

    if 'queues' not in options:
        return
    if CORRESPONDING_QUEUE not in options['queues'].split(','):
        return
    print('### STARTING UP A TREE BUILDER WORKER ###')

    global retroTransformer
    # Instantiate and load retro transformer
    retroTransformer = RetroTransformer(celery=True)
    retroTransformer.load(chiral=False)

    print('### TREE BUILDER WORKER STARTED UP ###')


# ONLY ONE WORKER TYPE HAS THIS FUNCTION EXPOSED - MAKE IT THE CHIRAL ONE
# @shared_task
# def fast_filter_check(*args, **kwargs):
#     '''Wrapper for fast filter check, since these workers will 
#     have it initialized. Best way to allow independent queries'''
#     global retroTransformer
#     if not retroTransformer.fast_filter:
#         from makeit.synthetic.evaluation.fast_filter import FastFilterScorer
#         retroTransformer.fast_filter = FastFilterScorer()
#         retroTransformer.fast_filter.load(model_path=gc.FAST_FILTER_MODEL['trained_model_path'])
#     return retroTransformer.fast_filter.evaluate(*args, **kwargs) 
開發者ID:connorcoley,項目名稱:ASKCOS,代碼行數:29,代碼來源:tb_worker.py

示例12: shared_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def shared_task(func):
        # Dummy decorator so that we can use the decorator wether celery is installed or not

        # We do not yet need this, but might come in handy in the future:
        #func.delay = lambda *a, **kw: func(*a, **kw)
        #func.apply_async = lambda *a, **kw: func(*a, **kw)
        return func 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:9,代碼來源:tasks.py

示例13: mutex_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import shared_task [as 別名]
def mutex_task(task_id_template=None, **shared_task_kwargs):
    """ Wraps a task that must be executed only once.

    :param task_id_template: String that makes unique task IDs from passed args
        (If omitted, we just use the function name)
    :param shared_task_kwargs: Passed through to `shared_task`
    """

    def decorator(func):
        signature = inspect.signature(func)

        @shared_task(**shared_task_kwargs, bind=True)
        @wraps(func)
        def wrapped_task(self, *task_args, **task_kwargs):
            if task_id_template:
                passed_args = signature.bind(*task_args, **task_kwargs)
                passed_args.apply_defaults()
                task_identifier = task_id_template.format_map(passed_args.arguments)
            else:
                task_identifier = func.__name__

            with exclusive_lock(task_identifier) as has_lock:
                if has_lock:
                    return func(*task_args, **task_kwargs)
                logger.debug("Other worker already processing %s", task_identifier)
            return None

        return wrapped_task

    return decorator 
開發者ID:DavidCain,項目名稱:mitoc-trips,代碼行數:32,代碼來源:tasks.py


注:本文中的celery.shared_task方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。