本文整理匯總了Python中pymongo.errors.ExceededMaxWaiters方法的典型用法代碼示例。如果您正苦於以下問題:Python errors.ExceededMaxWaiters方法的具體用法?Python errors.ExceededMaxWaiters怎麽用?Python errors.ExceededMaxWaiters使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pymongo.errors
的用法示例。
在下文中一共展示了errors.ExceededMaxWaiters方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: acquire
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ExceededMaxWaiters [as 別名]
def acquire(self, blocking=True, timeout=None):
if not self.waiter_semaphore.acquire(False):
raise ExceededMaxWaiters()
try:
return self.semaphore.acquire(blocking, timeout)
finally:
self.waiter_semaphore.release()
示例2: run
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ExceededMaxWaiters [as 別名]
def run(self):
try:
logging.info("Tailing oplog on %s for changes" % self.uri)
self.timer.start(self.timer_name)
self.state.set('running', True)
self.connect()
oplog = self.oplog()
while not self.tail_stop.is_set() and not self.backup_stop.is_set():
try:
self._cursor = self.db.get_oplog_cursor_since(self.__class__, self.last_ts)
while self.check_cursor():
try:
# get the next oplog doc and write it
doc = self._cursor.next()
if self.last_ts and self.last_ts >= doc['ts']:
continue
oplog.add(doc)
# update states
self.count += 1
self.last_ts = doc['ts']
if self.first_ts is None:
self.first_ts = self.last_ts
update = {
'count': self.count,
'first_ts': self.first_ts,
'last_ts': self.last_ts
}
self.state.set(None, update, True)
# print status report every N seconds
self.status()
except NotMasterError:
# pymongo.errors.NotMasterError means a RECOVERING-state when connected to secondary (which should be true)
self.backup_stop.set()
logging.error("Node %s is in RECOVERING state! Stopping tailer thread" % self.uri)
raise OperationError("Node %s is in RECOVERING state! Stopping tailer thread" % self.uri)
except CursorNotFound:
self.backup_stop.set()
logging.error("Cursor disappeared on server %s! Stopping tailer thread" % self.uri)
raise OperationError("Cursor disappeared on server %s! Stopping tailer thread" % self.uri)
except (AutoReconnect, ConnectionFailure, ExceededMaxWaiters, ExecutionTimeout, NetworkTimeout), e:
logging.error("Tailer %s received %s exception: %s. Attempting retry" % (self.uri, type(e).__name__, e))
if self._tail_retry > self._tail_retry_max:
self.backup_stop.set()
logging.error("Reconnected to %s %i/%i times, stopping backup!" % (self.uri, self._tail_retry, self._tail_retry_max))
raise OperationError("Reconnected to %s %i/%i times, stopping backup!" % (self.uri, self._tail_retry, self._tail_retry_max))
self._tail_retry += 1
except StopIteration:
continue
sleep(1)
finally:
if self._cursor:
logging.debug("Stopping oplog cursor on %s" % self.uri)
self._cursor.close()