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


Python futurist.GreenThreadPoolExecutor方法代碼示例

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


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

示例1: __init__

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def __init__(self, operation_manager, thread_count=None):
        super(ThreadPoolExecutor, self).__init__(operation_manager)

        if thread_count is None:
            thread_count = CONF.thread_count

        self._pool = futurist.GreenThreadPoolExecutor(thread_count)
        self._operation_to_run = defaultdict(int)
        self._operation_to_cancel = set()
        self._lock = RLock()

        self._check_functions = {
            self._CHECK_ITEMS['is_waiting']: lambda op_id: (
                op_id in self._operation_to_run),

            self._CHECK_ITEMS['is_canceled']: lambda op_id: (
                op_id in self._operation_to_cancel),
        } 
開發者ID:openstack,項目名稱:karbor,代碼行數:20,代碼來源:thread_pool_executor.py

示例2: get_engine

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def get_engine(self, flow, **kwargs):
        if flow is None:
            LOG.error("The flow is None, build it first")
            raise exception.InvalidTaskFlowObject(
                reason=_("The flow is None"))
        executor = kwargs.get('executor', None)
        engine = kwargs.get('engine', None)
        store = kwargs.get('store', None)
        if not executor:
            executor = futurist.GreenThreadPoolExecutor()
        if not engine:
            engine = 'parallel'
        flow_engine = engines.load(flow,
                                   executor=executor,
                                   engine=engine,
                                   store=store)
        return flow_engine 
開發者ID:openstack,項目名稱:karbor,代碼行數:19,代碼來源:workflow.py

示例3: get_engine

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def get_engine(self, flow, **kwargs):
        if flow is None:
            LOG.error("Flow is None, build it first")
            return
        executor = kwargs.get('executor', None)
        engine = kwargs.get('engine', None)
        store = kwargs.get('store', None)
        if not executor:
            executor = futurist.GreenThreadPoolExecutor()
        if not engine:
            engine = 'parallel'
        flow_engine = engines.load(flow,
                                   executor=executor,
                                   engine=engine,
                                   store=store)
        return flow_engine 
開發者ID:openstack,項目名稱:karbor,代碼行數:18,代碼來源:fakes.py

示例4: default_executor

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def default_executor():
    thread_count = 5
    try:
        thread_count = CONF['service:worker'].threads
    except Exception:
        pass

    # TODO(mugsie): if (when) we move away from eventlet this may have to
    # revert back to ThreadPoolExecutor - this is changing due to
    # https://bugs.launchpad.net/bugs/1782647 (eventlet + py37 issues)
    return futurist.GreenThreadPoolExecutor(thread_count) 
開發者ID:openstack,項目名稱:designate,代碼行數:13,代碼來源:processing.py

示例5: list_floatingips

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def list_floatingips(self, context, region=None):
        """
        Get floating ips based on the current context from Neutron
        """
        endpoints = self._endpoints(
            service_catalog=context.service_catalog,
            service_type='network',
            endpoint_type=CONF['network_api:neutron'].endpoint_type,
            config_section='network_api:neutron',
            region=region
        )

        floating_ips = []
        with futurist.GreenThreadPoolExecutor(max_workers=5) as executor:
            executors = [
                executor.submit(
                    self._get_floating_ips,
                    context,
                    endpoint,
                    region,
                    project_id=context.project_id
                ) for endpoint, region in endpoints
            ]
            for future in concurrent.futures.as_completed(executors):
                try:
                    floating_ips.extend(future.result())
                except Exception as e:
                    raise exceptions.NeutronCommunicationFailure(e)

        return floating_ips 
開發者ID:openstack,項目名稱:designate,代碼行數:32,代碼來源:neutron.py

示例6: __init__

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def __init__(self, applier_manager):
        self.applier_manager = applier_manager
        workers = CONF.watcher_applier.workers
        self.executor = futurist.GreenThreadPoolExecutor(max_workers=workers) 
開發者ID:openstack,項目名稱:watcher,代碼行數:6,代碼來源:trigger.py

示例7: __init__

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def __init__(self, messaging):
        self._messaging = messaging
        self._executor = futurist.GreenThreadPoolExecutor(
            max_workers=CONF.watcher_decision_engine.max_audit_workers)
        self._oneshot_handler = o_handler.OneShotAuditHandler()
        self._continuous_handler = c_handler.ContinuousAuditHandler().start()
        self._event_handler = e_handler.EventAuditHandler() 
開發者ID:openstack,項目名稱:watcher,代碼行數:9,代碼來源:audit_endpoint.py

示例8: __init__

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def __init__(self):
        self.amount_workers = CONF.watcher_decision_engine.max_general_workers
        self._threadpool = futurist.GreenThreadPoolExecutor(
            max_workers=self.amount_workers) 
開發者ID:openstack,項目名稱:watcher,代碼行數:6,代碼來源:threading.py

示例9: __init__

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def __init__(self, max_workers=10):
        pool = futurist.GreenThreadPoolExecutor(int(max_workers))
        super(GreenThreadPoolExecutor, self).__init__(pool) 
開發者ID:openstack,項目名稱:watcher,代碼行數:5,代碼來源:scheduling.py

示例10: _create_executor

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def _create_executor(self, max_workers=None):
        if max_workers is None:
            max_workers = self.DEFAULT_WORKERS
        return futurist.GreenThreadPoolExecutor(max_workers=max_workers) 
開發者ID:openstack,項目名稱:taskflow,代碼行數:6,代碼來源:executor.py

示例11: _make_engine

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def _make_engine(self, flow, flow_detail=None, executor=None):
        if executor is None:
            executor = futurist.GreenThreadPoolExecutor()
            self.addCleanup(executor.shutdown)
        return taskflow.engines.load(flow,
                                     flow_detail=flow_detail,
                                     backend=self.backend,
                                     engine='parallel',
                                     executor=executor) 
開發者ID:openstack,項目名稱:taskflow,代碼行數:11,代碼來源:test_arguments_passing.py

示例12: test_green_executor_creation

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def test_green_executor_creation(self):
        with futurist.GreenThreadPoolExecutor(1) as e:
            eng = self._create_engine(executor=e)
            self.assertIsInstance(eng._task_executor,
                                  executor.ParallelThreadTaskExecutor) 
開發者ID:openstack,項目名稱:taskflow,代碼行數:7,代碼來源:test_creation.py

示例13: _make_engine

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def _make_engine(self, flow, flow_detail=None, executor=None):
        if executor is None:
            executor = futurist.GreenThreadPoolExecutor()
            self.addCleanup(executor.shutdown)
        return taskflow.engines.load(flow, flow_detail=flow_detail,
                                     backend=self.backend, engine='parallel',
                                     executor=executor) 
開發者ID:openstack,項目名稱:taskflow,代碼行數:9,代碼來源:test_suspend.py

示例14: executor

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def executor():
    """Return the current futures executor."""
    global _EXECUTOR
    if _EXECUTOR is None:
        _EXECUTOR = futurist.GreenThreadPoolExecutor(
            max_workers=CONF.max_concurrency)
    return _EXECUTOR 
開發者ID:openstack,項目名稱:ironic-inspector,代碼行數:9,代碼來源:utils.py

示例15: main

# 需要導入模塊: import futurist [as 別名]
# 或者: from futurist import GreenThreadPoolExecutor [as 別名]
def main():
    if len(sys.argv) == 2:
        tbl = []
        with open(sys.argv[1], 'rb') as fh:
            reader = csv.reader(fh)
            for row in reader:
                tbl.append([float(r) if r else 0.0 for r in row])
    else:
        # Make some random table out of thin air...
        tbl = []
        cols = random.randint(1, 100)
        rows = random.randint(1, 100)
        for _i in compat_range(0, rows):
            row = []
            for _j in compat_range(0, cols):
                row.append(random.random())
            tbl.append(row)

    # Generate the work to be done.
    f = make_flow(tbl)

    # Now run it (using the specified executor)...
    try:
        executor = futurist.GreenThreadPoolExecutor(max_workers=5)
    except RuntimeError:
        # No eventlet currently active, use real threads instead.
        executor = futurist.ThreadPoolExecutor(max_workers=5)
    try:
        e = engines.load(f, engine='parallel', executor=executor)
        for st in e.run_iter():
            print(st)
    finally:
        executor.shutdown()

    # Find the old rows and put them into place...
    #
    # TODO(harlowja): probably easier just to sort instead of search...
    computed_tbl = []
    for i in compat_range(0, len(tbl)):
        for t in f:
            if t.index == i:
                computed_tbl.append(e.storage.get(t.name))

    # Do some basic validation (which causes the return code of this process
    # to be different if things were not as expected...)
    if len(computed_tbl) != len(tbl):
        return 1
    else:
        return 0 
開發者ID:openstack,項目名稱:taskflow,代碼行數:51,代碼來源:parallel_table_multiply.py


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