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


Python pool.apply_async方法代碼示例

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


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

示例1: _queue_job

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def _queue_job(self, pool, key, data_file, data_file_size):
        pool.apply_async(
            _fetch_and_process_chunk,
            [],
            {
                "app_config": self.config,
                "debug": self.debug,
                "data_file": data_file,
                "data_file_size": data_file_size,
                "download_progress_per_file": self.download_progress_per_file,
                "site": self.site,
                "pgdata": self.pgdata,
                "tablespaces": self.tablespaces,
            },
            lambda *args: self.job_completed(key),
            lambda exception: self.job_failed(key, exception),
        ) 
開發者ID:aiven,項目名稱:pghoard,代碼行數:19,代碼來源:restore.py

示例2: get_container_id_mapping

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def get_container_id_mapping(pool, compose_cmd):
    service_names = subprocess.check_output(
        compose_cmd + ["config", "--services"]
    )
    service_names = service_names.strip().decode("utf-8").split("\n")
    id_mapping = {
        name: pool.apply_async(pool_container_id, (name, compose_cmd))
        for name in service_names
    }

    while not all(future.ready() for future in id_mapping.values()):
        time.sleep(0.1)
    for name, future in list(id_mapping.items()):
        if not future.successful():
            raise RuntimeError("Cannot get ID of service {0}".format(name))
        id_mapping[name] = future.get()

    return id_mapping 
開發者ID:Mirantis,項目名稱:ceph-lcm,代碼行數:20,代碼來源:debug_snapshot.py

示例3: show_progress

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def show_progress(a):
    """
    Callback for the run_calls function: print nb of calls that are done.

    Args:
        a: useless argument, but since this function is used as a callback by
           apply_async, it has to take one argument.
    """
    show_progress.counter += 1
    status = '{:{fill}{width}} / {}'.format(show_progress.counter,
                                            show_progress.total,
                                            fill='',
                                            width=len(str(show_progress.total)))
    if show_progress.counter < show_progress.total:
        status += chr(8) * len(status)
    else:
        status += '\n'
    sys.stdout.write(status)
    sys.stdout.flush() 
開發者ID:cmla,項目名稱:tsd,代碼行數:21,代碼來源:parallel.py

示例4: get_ec2_offerings

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def get_ec2_offerings(instances, region, profiles):
    with multiprocessing.pool.ThreadPool(processes=4) as pool:
        offerings = collections.defaultdict(int)
        tasks = []
        print('[global - {}] Getting offerings for all instances...'.format(region))
        for instance, count in instances.items():
            ec2 = boto_session_getter(instance.profile, region)
            tasks.append({
                'profile': [instance.profile],
                'remaining_profiles': [p for p in profiles if p != instance.profile],
                'instance_type': instance.instance_type,
                'instance_count': count,
                'task': pool.apply_async(get_ec2_type_offerings,
                                         [ec2, instance.instance_type]),
            })
        for i, task in zip(itertools.count(1), tasks):
            if len(task['profile']) == 1:
                print('[{} - {}] Getting offerings for instance {}/{}...'.format(
                    task['profile'][0], region, i, len(instances)))
            offering = task['task'].get()
            if offering:
                offerings[offering] += task['instance_count']
            elif len(task['remaining_profiles']):
                ec2 = boto_session_getter(task['remaining_profiles'][0], region)
                new_task = task.copy()
                new_task['task'] = pool.apply_async(get_ec2_type_offerings, [ec2, new_task['instance_type']])
                new_task['profile'].append(new_task['remaining_profiles'][0])
                new_task['remaining_profiles'].pop(0)
                tasks.append(new_task)
    return offerings 
開發者ID:trackit,項目名稱:aws-cost-report,代碼行數:32,代碼來源:get_ec2_data.py

示例5: scrape_with_timeout

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def scrape_with_timeout(page):
    pool = NDPool(processes=1)
    async_result = pool.apply_async(scrape_page, (page,))
    result = None
    try:
        result = async_result.get(timeout=600)
        pool.close()
    except TimeoutError:
        logger.info(u'page scrape timed out: {}'.format(page))
        pool.terminate()

    pool.join()
    return result 
開發者ID:ourresearch,項目名稱:oadoi,代碼行數:15,代碼來源:queue_green_oa_scrape.py

示例6: timeout

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def timeout(timeout):
    """Timeout decorator, parameter in seconds."""
    def timeout_decorator(func):
        """Wrap the original function."""
        @functools.wraps(func)
        def func_wrapper(*args, **kwargs):
            """Closure for function."""
            pool = multiprocessing.pool.ThreadPool(processes=1)
            async_result = pool.apply_async(func, args, kwargs)
            # raises a TimeoutError if execution exceeds timeout
            return async_result.get(timeout)
        return func_wrapper
    return timeout_decorator 
開發者ID:avocado-framework,項目名稱:avocado-vt,代碼行數:15,代碼來源:utils_scheduling.py

示例7: fit_pixel_multiprocess_nonlinear

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def fit_pixel_multiprocess_nonlinear(data, x, param, reg_mat, use_snip=False):
    """
    Multiprocess fit of experiment data.

    Parameters
    ----------
    data : array
        3D data of experiment spectrum
    param : dict
        fitting parameters

    Returns
    -------
    dict :
        fitting values for all the elements
    """

    num_processors_to_use = multiprocessing.cpu_count()
    logger.info('cpu count: {}'.format(num_processors_to_use))
    pool = multiprocessing.Pool(num_processors_to_use)

    # fit_params = lmfit.Parameters()
    # for i in range(reg_mat.shape[1]):
    #     fit_params.add('a'+str(i), value=1.0, min=0, vary=True)

    result_pool = [pool.apply_async(fit_pixel_nonlinear_per_line,
                                    (n, data[n, :, :], x,
                                     param, reg_mat, use_snip))
                   for n in range(data.shape[0])]

    results = []
    for r in result_pool:
        results.append(r.get())

    pool.terminate()
    pool.join()

    return results 
開發者ID:NSLS-II,項目名稱:PyXRF,代碼行數:40,代碼來源:fit_spectrum.py

示例8: roi_sum_multi_files

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def roi_sum_multi_files(dir_path, file_prefix,
                        start_i, end_i, element_dict,
                        interpath='entry/instrument/detector/data'):
    """
    Fitting for multiple files with Multiprocessing.

    Parameters
    -----------
    dir_path : str
    file_prefix : str
    start_i : int
        start id of given file
    end_i: int
        end id of given file
    element_dict : dict
        dict of element with [low, high] bounds as values
    interpath : str
        path inside hdf5 file to fetch the data

    Returns
    -------
    result : list
        fitting result as list of dict
    """
    num_processors_to_use = multiprocessing.cpu_count()
    logger.info('cpu count: {}'.format(num_processors_to_use))
    pool = multiprocessing.Pool(num_processors_to_use)

    result_pool = [pool.apply_async(roi_sum_calculation,
                                    (dir_path, file_prefix,
                                     m, element_dict, interpath))
                   for m in range(start_i, end_i+1)]

    results = []
    for r in result_pool:
        results.append(r.get())

    pool.terminate()
    pool.join()
    return results 
開發者ID:NSLS-II,項目名稱:PyXRF,代碼行數:42,代碼來源:fit_spectrum.py

示例9: timeout

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def timeout(max_timeout):
    """Timeout decorator, parameter in seconds."""
    def timeout_decorator(f):
        """Wrap the original function."""
        @functools.wraps(f)
        def func_wrapper(self, *args, **kwargs):
            """Closure for function."""
            pool = multiprocessing.pool.ThreadPool(processes=1)
            async_result = pool.apply_async(f, (self,) + args, kwargs)
            timeout = kwargs.pop('timeout_max_timeout', max_timeout) or max_timeout
            # raises a TimeoutError if execution exceeds max_timeout
            return async_result.get(timeout)
        return func_wrapper
    return timeout_decorator 
開發者ID:AntreasAntoniou,項目名稱:DeepClassificationBot,代碼行數:16,代碼來源:decorators.py

示例10: process_main_files

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def process_main_files(pool, snapshot_dir, compose_cmd, container_ids):
    pool.apply_async(collect_backup, [snapshot_dir, compose_cmd])
    pool.apply_async(collect_docker_info, [snapshot_dir])
    pool.apply_async(collect_docker_version, [snapshot_dir])
    pool.apply_async(
        collect_docker_compose_config, [snapshot_dir, compose_cmd])
    pool.apply_async(collect_all_logs, [snapshot_dir, compose_cmd])
    pool.apply_async(collect_monitoring_results,
                     [snapshot_dir, container_ids["admin"]]) 
開發者ID:Mirantis,項目名稱:ceph-lcm,代碼行數:11,代碼來源:debug_snapshot.py

示例11: process_service_files

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def process_service_files(pool, name, container_id, snapshot_dir, compose_cmd):
    service_snapshot_dir = os.path.join(snapshot_dir, name)
    pool.apply_async(collect_service_log,
                     [service_snapshot_dir, name, compose_cmd])
    pool.apply_async(collect_service_date,
                     [service_snapshot_dir, name, compose_cmd])
    pool.apply_async(collect_service_unix_timestamp,
                     [service_snapshot_dir, name, compose_cmd])
    pool.apply_async(collect_service_packages_os,
                     [service_snapshot_dir, name, compose_cmd])
    pool.apply_async(collect_service_ps,
                     [service_snapshot_dir, name, compose_cmd])
    pool.apply_async(collect_service_docker_inspect,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_docker_stats,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_config,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_git_release,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_decapod_release,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_packages_npm,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_packages_python2,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_packages_python3,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_ansible_config,
                     [service_snapshot_dir, name, container_id])
    pool.apply_async(collect_service_private_key_sha1sum,
                     [service_snapshot_dir, name, compose_cmd]) 
開發者ID:Mirantis,項目名稱:ceph-lcm,代碼行數:34,代碼來源:debug_snapshot.py

示例12: run_calls

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import apply_async [as 別名]
def run_calls(fun, list_of_args, extra_args=(), pool_type='processes',
              nb_workers=multiprocessing.cpu_count(), timeout=60, verbose=True,
              initializer=None, initargs=None):
    """
    Run a function several times in parallel with different inputs.

    Args:
        fun: function to be called several times in parallel.
        list_of_args: list of (first positional) arguments passed to fun, one
            per call
        extra_args: tuple containing extra arguments to be passed to fun
            (same value for all calls)
        pool_type: either 'processes' or 'threads'
        nb_workers: number of calls run simultaneously
        timeout: number of seconds allowed per function call
        verbose: either True (show the amount of computed calls) or False
        initializer, initargs (optional): if initializer is not None then each
            worker process will call initializer(*initargs) when it starts

    Return:
        list of outputs
    """
    if pool_type == 'processes':
        pool = multiprocessing.Pool(nb_workers, initializer, initargs)
    elif pool_type == 'threads':
        pool = multiprocessing.pool.ThreadPool(nb_workers)
    else:
        print('ERROR: unknow pool_type "{}"'.format(pool_type))

    results = []
    outputs = []
    if verbose:
        show_progress.counter = 0
        show_progress.total = len(list_of_args)
    for x in list_of_args:
        if type(x) == tuple:
            args = x + extra_args
        else:
            args = (x,) + extra_args
        results.append(pool.apply_async(fun, args=args,
                                        callback=show_progress if verbose else None))

    for r in results:
        try:
            outputs.append(r.get(timeout))
        except KeyboardInterrupt:
            pool.terminate()
            sys.exit(1)

    pool.close()
    pool.join()
    return outputs 
開發者ID:cmla,項目名稱:tsd,代碼行數:54,代碼來源:parallel.py


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