本文整理匯總了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
示例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
示例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.')
示例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
示例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
示例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}
示例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
示例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)
示例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