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


Python patcher.is_monkey_patched方法代碼示例

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


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

示例1: run

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def run(self, handler):
        from eventlet import wsgi, listen, patcher
        if not patcher.is_monkey_patched(os):
            msg = "Bottle requires eventlet.monkey_patch() (before import)"
            raise RuntimeError(msg)
        socket_args = {}
        for arg in ('backlog', 'family'):
            try:
                socket_args[arg] = self.options.pop(arg)
            except KeyError:
                pass
        address = (self.host, self.port)
        try:
            wsgi.server(listen(address, **socket_args), handler,
                        log_output=(not self.quiet))
        except TypeError:
            # Fallback, if we have old version of eventlet
            wsgi.server(listen(address), handler) 
開發者ID:brycesub,項目名稱:silvia-pi,代碼行數:20,代碼來源:bottle.py

示例2: threading_local_monkey_patched

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def threading_local_monkey_patched():
    # Returns True if thread locals have been patched by either gevent of
    # eventlet
    try:
        from gevent.monkey import is_object_patched
    except ImportError:
        pass
    else:
        if is_object_patched("threading", "local"):
            return True

    try:
        from eventlet.patcher import is_monkey_patched
    except ImportError:
        pass
    else:
        if is_monkey_patched("thread"):
            return True

    return False 
開發者ID:elastic,項目名稱:apm-agent-python,代碼行數:22,代碼來源:__init__.py

示例3: check_evenlet_monkey_patch

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def check_evenlet_monkey_patch(raise_exc=True):
    if not patcher.is_monkey_patched('socket'):  # 隨便選一個檢測標誌
        if raise_exc:
            warnings.warn(f'檢測到沒有打 evenlet 包的猴子補丁 ,請在起始腳本文件首行加上     import eventlet;eventlet.monkey_patch(all=True) ')
            raise Exception('檢測到沒有打 evenlet 包的猴子補丁 ,請在起始腳本文件首行加上    import eventlet;eventlet.monkey_patch(all=True)')
    else:
        return 1 
開發者ID:ydf0509,項目名稱:distributed_framework,代碼行數:9,代碼來源:custom_evenlet_pool_executor.py

示例4: test_eventlet_thread_monkeypatched

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def test_eventlet_thread_monkeypatched():
    eventlet.monkey_patch(thread=True)
    assert is_monkey_patched("thread")

    execution_context = elasticapm.context.init_execution_context()

    # Should always use ThreadLocalContext when eventlet has patched
    # threading.local
    assert isinstance(execution_context, ThreadLocalContext) 
開發者ID:elastic,項目名稱:apm-agent-python,代碼行數:11,代碼來源:eventlet_threading_tests.py

示例5: test_transaction_with_eventlet

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def test_transaction_with_eventlet(sending_elasticapm_client):
    assert is_monkey_patched(os)
    transaction = sending_elasticapm_client.begin_transaction("test")
    with elasticapm.capture_span("bla"):
        pass
    sending_elasticapm_client.end_transaction("test", "OK")
    sending_elasticapm_client.close()
    assert len(sending_elasticapm_client.httpserver.requests) == 1
    assert sending_elasticapm_client.httpserver.payloads[0][1][constants.SPAN]
    assert sending_elasticapm_client.httpserver.payloads[0][2][constants.TRANSACTION] 
開發者ID:elastic,項目名稱:apm-agent-python,代碼行數:12,代碼來源:test_eventlet.py

示例6: initialize

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def initialize(self):
        super(KombuManager, self).initialize()

        monkey_patched = True
        if self.server.async_mode == 'eventlet':
            from eventlet.patcher import is_monkey_patched
            monkey_patched = is_monkey_patched('socket')
        elif 'gevent' in self.server.async_mode:
            from gevent.monkey import is_module_patched
            monkey_patched = is_module_patched('socket')
        if not monkey_patched:
            raise RuntimeError(
                'Kombu requires a monkey patched socket library to work '
                'with ' + self.server.async_mode) 
開發者ID:miguelgrinberg,項目名稱:python-socketio,代碼行數:16,代碼來源:kombu_manager.py

示例7: initialize

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def initialize(self):
        super(RedisManager, self).initialize()

        monkey_patched = True
        if self.server.async_mode == 'eventlet':
            from eventlet.patcher import is_monkey_patched
            monkey_patched = is_monkey_patched('socket')
        elif 'gevent' in self.server.async_mode:
            from gevent.monkey import is_module_patched
            monkey_patched = is_module_patched('socket')
        if not monkey_patched:
            raise RuntimeError(
                'Redis requires a monkey patched socket library to work '
                'with ' + self.server.async_mode) 
開發者ID:miguelgrinberg,項目名稱:python-socketio,代碼行數:16,代碼來源:redis_manager.py

示例8: _monitor_vm_failover

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def _monitor_vm_failover(self, watcher, callback,
                             event_timeout_ms=_WMI_EVENT_TIMEOUT_MS):
        """Creates a monitor to check for new WMI MSCluster_Resource

        events.

        This method will poll the last _WMI_EVENT_CHECK_INTERVAL + 1
        seconds for new events and listens for _WMI_EVENT_TIMEOUT_MS
        milliseconds, since listening is a thread blocking action.

        Any event object caught will then be processed.
        """

        vm_name = None
        new_host = None
        try:
            # wait for new event for _WMI_EVENT_TIMEOUT_MS milliseconds.
            if patcher.is_monkey_patched('thread'):
                wmi_object = tpool.execute(watcher,
                                           event_timeout_ms)
            else:
                wmi_object = watcher(event_timeout_ms)

            old_host = wmi_object.previous.OwnerNode
            new_host = wmi_object.OwnerNode
            # wmi_object.Name field is of the form:
            # 'Virtual Machine nova-instance-template'
            # wmi_object.Name filed is a key and as such is not affected
            # by locale, so it will always be 'Virtual Machine'
            match = self._instance_name_regex.search(wmi_object.Name)
            if match:
                vm_name = match.group(1)

            if vm_name:
                try:
                    callback(vm_name, old_host, new_host)
                except Exception:
                    LOG.exception(
                        "Exception during failover callback.")
        except exceptions.x_wmi_timed_out:
            pass 
開發者ID:openstack,項目名稱:os-win,代碼行數:43,代碼來源:clusterutils.py

示例9: get_vnic_event_listener

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def get_vnic_event_listener(self, event_type):
        query = self._get_event_wql_query(cls=self._VNIC_SET_DATA,
                                          event_type=event_type,
                                          timeframe=2)
        listener = self._conn.Msvm_SyntheticEthernetPortSettingData.watch_for(
            query)

        def _poll_events(callback):
            if patcher.is_monkey_patched('thread'):
                listen = functools.partial(tpool.execute, listener,
                                           self._VNIC_LISTENER_TIMEOUT_MS)
            else:
                listen = functools.partial(listener,
                                           self._VNIC_LISTENER_TIMEOUT_MS)

            while True:
                # Retrieve one by one all the events that occurred in
                # the checked interval.
                try:
                    event = listen()
                    if event.ElementName:
                        callback(event.ElementName)
                    else:
                        LOG.warning("Ignoring port event. "
                                    "The port name is missing.")
                except exceptions.x_wmi_timed_out:
                    # no new event published.
                    pass

        return _poll_events 
開發者ID:openstack,項目名稱:os-win,代碼行數:32,代碼來源:networkutils.py

示例10: get_vm_power_state_change_listener

# 需要導入模塊: from eventlet import patcher [as 別名]
# 或者: from eventlet.patcher import is_monkey_patched [as 別名]
def get_vm_power_state_change_listener(
            self, timeframe=_DEFAULT_EVENT_CHECK_TIMEFRAME,
            event_timeout=constants.DEFAULT_WMI_EVENT_TIMEOUT_MS,
            filtered_states=None, get_handler=False):
        field = self._VM_ENABLED_STATE_PROP
        query = self._get_event_wql_query(cls=self._COMPUTER_SYSTEM_CLASS,
                                          field=field,
                                          timeframe=timeframe,
                                          filtered_states=filtered_states)
        listener = self._conn.Msvm_ComputerSystem.watch_for(raw_wql=query,
                                                            fields=[field])

        def _handle_events(callback):
            if patcher.is_monkey_patched('thread'):
                # Retrieve one by one all the events that occurred in
                # the checked interval.
                #
                # We use eventlet.tpool for retrieving the events in
                # order to avoid issues caused by greenthread/thread
                # communication. Note that PyMI must use the unpatched
                # threading module.
                listen = functools.partial(tpool.execute, listener,
                                           event_timeout)
            else:
                listen = functools.partial(listener, event_timeout)

            while True:
                try:
                    event = listen()

                    vm_name = event.ElementName
                    vm_state = event.EnabledState
                    vm_power_state = self.get_vm_power_state(vm_state)

                    try:
                        callback(vm_name, vm_power_state)
                    except Exception:
                        err_msg = ("Executing VM power state change "
                                   "event callback failed. "
                                   "VM name: %(vm_name)s, "
                                   "VM power state: %(vm_power_state)s.")
                        LOG.exception(err_msg,
                                      dict(vm_name=vm_name,
                                           vm_power_state=vm_power_state))
                except exceptions.x_wmi_timed_out:
                    pass
                except Exception:
                    LOG.exception(
                        "The VM power state change event listener "
                        "encountered an unexpected exception.")
                    time.sleep(event_timeout / 1000)

        return _handle_events if get_handler else listener 
開發者ID:openstack,項目名稱:os-win,代碼行數:55,代碼來源:vmutils.py


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