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


Python task.task方法代碼示例

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


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

示例1: get_worker_versions

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def get_worker_versions():
    """ Search and return the versions of Oasis components
    """
    ktool_ver_str = subprocess.getoutput('fmcalc -v')
    plat_ver_file = '/home/worker/VERSION'

    if os.path.isfile(plat_ver_file):
        with open(plat_ver_file, 'r') as f:
            plat_ver_str = f.read().strip()
    else:
        plat_ver_str = ""

    return {
        "oasislmf": mdk_version,
        "ktools": ktool_ver_str,
        "platform": plat_ver_str
    }


# When a worker connects send a task to the worker-monitor to register a new model 
開發者ID:OasisLMF,項目名稱:OasisPlatform,代碼行數:22,代碼來源:tasks.py

示例2: get_oasislmf_config_path

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def get_oasislmf_config_path(model_id=None):
    conf_var = settings.get('worker', 'oasislmf_config', fallback=None)
    if not model_id:
        model_id = settings.get('worker', 'model_id', fallback=None)

    if conf_var:
        return conf_var

    if model_id:
        model_root = settings.get('worker', 'model_data_directory', fallback='/var/oasis/')
        model_specific_conf = Path(model_root, '{}-oasislmf.json'.format(model_id))
        if model_specific_conf.exists():
            return str(model_specific_conf)

    return str(Path(model_root, 'oasislmf.json'))


# Send notification back to the API Once task is read from Queue 
開發者ID:OasisLMF,項目名稱:OasisPlatform,代碼行數:20,代碼來源:tasks.py

示例3: copy_setup_pages_task

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def copy_setup_pages_task(copy_from_slug, copy_to_slug):
    """
    Call copy_setup_pages as a task (since it can be slow with many pages).
    """
    course_copy_from = CourseOffering.objects.get(slug=copy_from_slug)
    course_copy_to = CourseOffering.objects.get(slug=copy_to_slug)
    copy_setup_pages(course_copy_from, course_copy_to) 
開發者ID:sfu-fas,項目名稱:coursys,代碼行數:9,代碼來源:tasks.py

示例4: task

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def task(*args, **kwargs):
        def decorator(*args, **kwargs):
            return None
        return decorator 
開發者ID:sfu-fas,項目名稱:coursys,代碼行數:6,代碼來源:tasks.py

示例5: start_analysis_task

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def start_analysis_task(self, analysis_pk, input_location, analysis_settings, complex_data_files=None):
    """Task wrapper for running an analysis.

    Args:
        self: Celery task instance.
        analysis_settings (str): Path or URL to the analysis settings.
        input_location (str): Path to the input tar file.
        complex_data_files (list of complex_model_data_file): List of dicts containing
            on-disk and original filenames for required complex model data files.

    Returns:
        (string) The location of the outputs.
    """

    logging.info("LOCK_FILE: {}".format(settings.get('worker', 'LOCK_FILE')))
    logging.info("LOCK_RETRY_COUNTDOWN_IN_SECS: {}".format(
        settings.get('worker', 'LOCK_RETRY_COUNTDOWN_IN_SECS')))

    with get_lock() as gotten:
        if not gotten:
            logging.info("Failed to get resource lock - retry task")
            raise self.retry(
                max_retries=None,
                countdown=settings.getint('worker', 'LOCK_RETRY_COUNTDOWN_IN_SECS'))

        logging.info("Acquired resource lock")

        try:
            notify_api_status(analysis_pk, 'RUN_STARTED')
            self.update_state(state=RUNNING_TASK_STATUS)
            output_location, traceback_location, log_location, return_code = start_analysis(
                analysis_settings,
                input_location,
                complex_data_files=complex_data_files
            )
        except Exception:
            logging.exception("Model execution task failed.")
            raise

        return output_location, traceback_location, log_location, return_code 
開發者ID:OasisLMF,項目名稱:OasisPlatform,代碼行數:42,代碼來源:tasks.py

示例6: on_error

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def on_error(request, ex, traceback, record_task_name, analysis_pk, initiator_pk):
    """
    Because of how celery works we need to include a celery task registered in the
    current app to pass to the `link_error` function on a chain.

    This function takes the error and passes it on back to the server so that it can store
    the info on the analysis.
    """
    signature(
        record_task_name,
        args=(analysis_pk, initiator_pk, traceback),
        queue='celery'
    ).delay() 
開發者ID:OasisLMF,項目名稱:OasisPlatform,代碼行數:15,代碼來源:tasks.py

示例7: mltshp_task

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def mltshp_task(*args, **options):
    # This is how celery's periodic_task decorator customizes the class, so try it here too.
    return task(**dict({"base": MltshpTask}, **options)) 
開發者ID:MLTSHP,項目名稱:mltshp,代碼行數:5,代碼來源:__init__.py

示例8: rerun_course

# 需要導入模塊: from celery import task [as 別名]
# 或者: from celery.task import task [as 別名]
def rerun_course(source_course_key_string, destination_course_key_string, user_id, fields=None):
    """
    Reruns a course in a new celery task.
    """
    try:
        # deserialize the payload
        source_course_key = CourseKey.from_string(source_course_key_string)
        destination_course_key = CourseKey.from_string(destination_course_key_string)
        fields = deserialize_fields(fields) if fields else None

        # use the split modulestore as the store for the rerun course,
        # as the Mongo modulestore doesn't support multiple runs of the same course.
        store = modulestore()
        with store.default_store('split'):
            store.clone_course(source_course_key, destination_course_key, user_id, fields=fields)

        # set initial permissions for the user to access the course.
        initialize_permissions(destination_course_key, User.objects.get(id=user_id))

        # update state: Succeeded
        CourseRerunState.objects.succeeded(course_key=destination_course_key)
        return "succeeded"

    except DuplicateCourseError as exc:
        # do NOT delete the original course, only update the status
        CourseRerunState.objects.failed(course_key=destination_course_key)
        logging.exception(u'Course Rerun Error')
        return "duplicate course"

    # catch all exceptions so we can update the state and properly cleanup the course.
    except Exception as exc:  # pylint: disable=broad-except
        # update state: Failed
        CourseRerunState.objects.failed(course_key=destination_course_key)
        logging.exception(u'Course Rerun Error')

        try:
            # cleanup any remnants of the course
            modulestore().delete_course(destination_course_key, user_id)
        except ItemNotFoundError:
            # it's possible there was an error even before the course module was created
            pass

        return "exception: " + unicode(exc) 
開發者ID:jruiperezv,項目名稱:ANALYSE,代碼行數:45,代碼來源:tasks.py


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