ServerSelectionTimeoutError: ошибка тайм-аута при подключении к Atlas через pymongo - PullRequest
0 голосов
/ 16 мая 2019

Я пытаюсь подключиться к своей базе данных Atlas mongodb через pymongo.Я устанавливаю соединение и делаю простой запрос только для подсчета документов, и время ожидания истекает.

Я могу запустить ту же строку в моем личном Linux (и мне удалось заставить ее работать из чистого Docker),но мне не удалось заставить его работать на моем Mac, который я использую для работы (как и мои коллеги, и я не смог заставить его работать в чистом образе Docker).Если это имеет значение, я использую pymongo 3.8, который я установил с pip install pymongo[tls].Я также пытался понизить класс и pip install pymongo[tls,srv].

Личные догадки: возможно, что-то связано с прокси / брандмауэром, блокирующим соединение?Я проверил, открыт ли порт. На сервере я внес белый список в 0.0.0.0/0, так что это не должно быть проблемой.

import pymongo

client = pymongo.MongoClient("mongodb+srv://whatever:yep@cluster0-xxxxx.mongodb.net/test?retryWrites=true")
client.test.matches.count_documents({}) # this blocks and then errors

Я получаю следующую ошибку

/usr/local/lib/python3.7/site-packages/pymongo/collection.py in count_documents(self, filter, session, **kwargs)
   1693         collation = validate_collation_or_none(kwargs.pop('collation', None))
   1694         cmd.update(kwargs)
-> 1695         with self._socket_for_reads(session) as (sock_info, slave_ok):
   1696             result = self._aggregate_one_result(
   1697                 sock_info, slave_ok, cmd, collation, session)

/usr/local/Cellar/python/3.7.3/Frameworks/Python.framework/Versions/3.7/lib/python3.7/contextlib.py in __enter__(self)
    110         del self.args, self.kwds, self.func
    111         try:
--> 112             return next(self.gen)
    113         except StopIteration:
    114             raise RuntimeError("generator didn't yield") from None

/usr/local/lib/python3.7/site-packages/pymongo/mongo_client.py in _socket_for_reads(self, read_preference)
   1133         topology = self._get_topology()
   1134         single = topology.description.topology_type == TOPOLOGY_TYPE.Single
-> 1135         server = topology.select_server(read_preference)
   1136
   1137         with self._get_socket(server) as sock_info:

/usr/local/lib/python3.7/site-packages/pymongo/topology.py in select_server(self, selector, server_selection_timeout, address)
    224         return random.choice(self.select_servers(selector,
    225                                                  server_selection_timeout,
--> 226                                                  address))
    227
    228     def select_server_by_address(self, address,

/usr/local/lib/python3.7/site-packages/pymongo/topology.py in select_servers(self, selector, server_selection_timeout, address)
    182         with self._lock:
    183             server_descriptions = self._select_servers_loop(
--> 184                 selector, server_timeout, address)
    185
    186             return [self.get_server_by_address(sd.address)

/usr/local/lib/python3.7/site-packages/pymongo/topology.py in _select_servers_loop(self, selector, timeout, address)
    198             if timeout == 0 or now > end_time:
    199                 raise ServerSelectionTimeoutError(
--> 200                     self._error_message(selector))
    201
    202             self._ensure_opened()

ServerSelectionTimeoutError: cluster0-shard-00-01-eflth.mongodb.net:27017: timed out,cluster0-shard-00-00-eflth.mongodb.net:27017: timed out,cluster0-shard-00-02-eflth.mongodb.net:27017: timed out
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...