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


Python coordination.get_coordinator方法代碼示例

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


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

示例1: coordinator_setup

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def coordinator_setup(start_heart=True):
    """
    Sets up the client for the coordination service.

    URL examples for connection:
        zake://
        file:///tmp
        redis://username:password@host:port
        mysql://username:password@host:port/dbname
    """
    url = cfg.CONF.coordination.url
    lock_timeout = cfg.CONF.coordination.lock_timeout
    member_id = get_member_id()

    if url:
        coordinator = coordination.get_coordinator(url, member_id, lock_timeout=lock_timeout)
    else:
        # Use a no-op backend
        # Note: We don't use tooz to obtain a reference since for this to work we would need to
        # register a plugin inside setup.py entry_point and use python setup.py develop for tests
        # to work
        coordinator = NoOpDriver(member_id)

    coordinator.start(start_heart=start_heart)
    return coordinator 
開發者ID:StackStorm,項目名稱:st2,代碼行數:27,代碼來源:coordination.py

示例2: get_coordinator

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def get_coordinator(start_heart=True, use_cache=True):
    """
    :param start_heart: True to start heartbeating process.
    :type start_heart: ``bool``

    :param use_cache: True to use cached coordinator instance. False should only be used in tests.
    :type use_cache: ``bool``
    """
    global COORDINATOR

    if not configured():
        LOG.warn('Coordination backend is not configured. Code paths which use coordination '
                 'service will use best effort approach and race conditions are possible.')

    if not use_cache:
        return coordinator_setup(start_heart=start_heart)

    if not COORDINATOR:
        COORDINATOR = coordinator_setup(start_heart=start_heart)
        LOG.debug('Initializing and caching new coordinator instance: %s' % (str(COORDINATOR)))
    else:
        LOG.debug('Using cached coordinator instance: %s' % (str(COORDINATOR)))

    return COORDINATOR 
開發者ID:StackStorm,項目名稱:st2,代碼行數:26,代碼來源:coordination.py

示例3: start

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def start(self, heartbeat=True):
        """Start coordinator.

        :param heartbeat: Whether spawns a new thread to keep heartbeating with
                          the tooz backend. Unless there is periodic task to
                          do heartbeat manually, it should be always set to
                          True.
        """
        if self.started:
            return

        member_id = '.'.join([COORDINATION_PREFIX, self.prefix,
                             CONF.host]).encode('ascii')
        self.coordinator = coordination.get_coordinator(
            CONF.coordination.backend_url, member_id)
        self.coordinator.start(start_heart=heartbeat)
        self.started = True
        LOG.debug('Coordinator started successfully.') 
開發者ID:openstack,項目名稱:ironic-inspector,代碼行數:20,代碼來源:coordination.py

示例4: get_coordinator_and_start

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def get_coordinator_and_start(member_id, url):
    coord = coordination.get_coordinator(url, member_id)
    coord.start(start_heart=True)
    return coord 
開發者ID:gnocchixyz,項目名稱:gnocchi,代碼行數:6,代碼來源:metricd.py

示例5: start

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def start(self):
        if self.started:
            return

        # NOTE(bluex): Tooz expects member_id as a byte string.
        member_id = (self.prefix + self.agent_id).encode('ascii')
        self.coordinator = coordination.get_coordinator(
            cfg.CONF.coordination.backend_url, member_id)
        self.coordinator.start(start_heart=True)
        self.started = True 
開發者ID:openstack,項目名稱:compute-hyperv,代碼行數:12,代碼來源:coordination.py

示例6: __init__

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def __init__(self, device_cfg):
        super(NetmikoSwitch, self).__init__(device_cfg)
        device_type = self.config.get('device_type', '')
        # use part that is after 'netmiko_'
        device_type = device_type.partition('netmiko_')[2]
        if device_type not in netmiko.platforms:
            raise exc.GenericSwitchNetmikoNotSupported(
                device_type=device_type)
        self.config['device_type'] = device_type
        if CONF.ngs.session_log_file:
            self.config['session_log'] = CONF.ngs.session_log_file
            self.config['session_log_record_writes'] = True
            self.config['session_log_file_mode'] = 'append'

        self.locker = None
        if CONF.ngs_coordination.backend_url:
            self.locker = coordination.get_coordinator(
                CONF.ngs_coordination.backend_url,
                ('ngs-' + CONF.host).encode('ascii'))
            self.locker.start()
            atexit.register(self.locker.stop)

        self.lock_kwargs = {
            'locks_pool_size': int(self.ngs_config['ngs_max_connections']),
            'locks_prefix': self.config.get(
                'host', '') or self.config.get('ip', ''),
            'timeout': CONF.ngs_coordination.acquire_timeout} 
開發者ID:openstack,項目名稱:networking-generic-switch,代碼行數:29,代碼來源:__init__.py

示例7: start

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def start(self):
        """Connect to coordination back end."""
        if self.started:
            return

        # NOTE(gouthamr): Tooz expects member_id as a byte string.
        member_id = (self.prefix + self.agent_id).encode('ascii')
        self.coordinator = coordination.get_coordinator(
            cfg.CONF.coordination.backend_url, member_id)
        self.coordinator.start(start_heart=True)
        self.started = True 
開發者ID:openstack,項目名稱:manila,代碼行數:13,代碼來源:coordination.py

示例8: __init__

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def __init__(self):
        self._coord = coordination.get_coordinator(
            CONF.orchestrator.coordination_url,
            uuidutils.generate_uuid().encode('ascii'))
        self._state = state.StateManager()
        self._storage = storage.get_storage()
        self._coord.start(start_heart=True) 
開發者ID:openstack,項目名稱:cloudkitty,代碼行數:9,代碼來源:orchestrator.py

示例9: get_coordinator

# 需要導入模塊: from tooz import coordination [as 別名]
# 或者: from tooz.coordination import get_coordinator [as 別名]
def get_coordinator(prefix=None):
    global _COORDINATOR
    if _COORDINATOR is None:
        _COORDINATOR = Coordinator(prefix=prefix)
    return _COORDINATOR 
開發者ID:openstack,項目名稱:ironic-inspector,代碼行數:7,代碼來源:coordination.py


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