Don't retry forever when a provider is stopped
When we stop a provider, it does not accept any new tasks. In that case, we should raise a specific exception so that loops that retry for a very long time can exit early since the "error" will never recover. Change-Id: I7387849ffdb96c487bae4c31ca7cbdd07b8afd8a
This commit is contained in:
parent
ed29412ed2
commit
df5049f2e2
@ -29,7 +29,7 @@ import keystoneclient.v2_0.client as ksclient
|
|||||||
import time
|
import time
|
||||||
|
|
||||||
import fakeprovider
|
import fakeprovider
|
||||||
from task_manager import Task, TaskManager
|
from task_manager import Task, TaskManager, ManagerStoppedException
|
||||||
|
|
||||||
|
|
||||||
SERVER_LIST_AGE = 5 # How long to keep a cached copy of the server list
|
SERVER_LIST_AGE = 5 # How long to keep a cached copy of the server list
|
||||||
@ -423,6 +423,8 @@ class ProviderManager(TaskManager):
|
|||||||
resource = self.getImage(resource_id)
|
resource = self.getImage(resource_id)
|
||||||
except NotFound:
|
except NotFound:
|
||||||
continue
|
continue
|
||||||
|
except ManagerStoppedException:
|
||||||
|
raise
|
||||||
except Exception:
|
except Exception:
|
||||||
self.log.exception('Unable to list %ss while waiting for '
|
self.log.exception('Unable to list %ss while waiting for '
|
||||||
'%s will retry' % (resource_type,
|
'%s will retry' % (resource_type,
|
||||||
@ -474,6 +476,8 @@ class ProviderManager(TaskManager):
|
|||||||
(server_id, self.provider.name)):
|
(server_id, self.provider.name)):
|
||||||
try:
|
try:
|
||||||
newip = self.getFloatingIP(ip['id'])
|
newip = self.getFloatingIP(ip['id'])
|
||||||
|
except ManagerStoppedException:
|
||||||
|
raise
|
||||||
except Exception:
|
except Exception:
|
||||||
self.log.exception('Unable to get IP details for server %s, '
|
self.log.exception('Unable to get IP details for server %s, '
|
||||||
'will retry' % (server_id))
|
'will retry' % (server_id))
|
||||||
|
@ -23,6 +23,10 @@ import logging
|
|||||||
import time
|
import time
|
||||||
|
|
||||||
|
|
||||||
|
class ManagerStoppedException(Exception):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
class Task(object):
|
class Task(object):
|
||||||
def __init__(self, **kw):
|
def __init__(self, **kw):
|
||||||
self._wait_event = threading.Event()
|
self._wait_event = threading.Event()
|
||||||
@ -93,6 +97,7 @@ class TaskManager(threading.Thread):
|
|||||||
|
|
||||||
def submitTask(self, task):
|
def submitTask(self, task):
|
||||||
if not self._running:
|
if not self._running:
|
||||||
raise Exception("Manager %s is no longer running" % self.name)
|
raise ManagerStoppedException(
|
||||||
|
"Manager %s is no longer running" % self.name)
|
||||||
self.queue.put(task)
|
self.queue.put(task)
|
||||||
return task.wait()
|
return task.wait()
|
||||||
|
Loading…
Reference in New Issue
Block a user