Merge branch 'master' into 2.0
Conflicts: cassandra/pool.py
This commit is contained in:
		| @@ -13,6 +13,7 @@ Bug Fixes | ||||
| * Fix duplicate node-up handling, which could result in multiple reconnectors | ||||
|   being started as well as the executor threads becoming deadlocked, preventing | ||||
|   future node up or node down handling from being executed. | ||||
| * Handle exhausted ReconnectionPolicy schedule correctly | ||||
|  | ||||
| Other | ||||
| ----- | ||||
|   | ||||
| @@ -195,8 +195,19 @@ class _ReconnectionHandler(object): | ||||
|         try: | ||||
|             conn = self.try_reconnect() | ||||
|         except Exception as exc: | ||||
|             try: | ||||
|                 next_delay = next(self.schedule) | ||||
|             except StopIteration: | ||||
|                 # the schedule has been exhausted | ||||
|                 next_delay = None | ||||
|  | ||||
|             # call on_exception for logging purposes even if next_delay is None | ||||
|             if self.on_exception(exc, next_delay): | ||||
|                 if next_delay is None: | ||||
|                     log.warn( | ||||
|                         "Will not continue to retry reconnection attempts " | ||||
|                         "due to an exhausted retry schedule") | ||||
|                 else: | ||||
|                     self.scheduler.schedule(next_delay, self.run) | ||||
|         else: | ||||
|             if not self._cancelled: | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Tyler Hobbs
					Tyler Hobbs