尝试使用 python 连接到 mongodb atlas 时连接超时

connection times out when trying to connect to mongodb atlas with python

我正在尝试连接到我的 mongodb atlas 集群,但是当我尝试对我的数据库执行某些操作时,我总是超时。

我使用的数据库是在 mongoshell 中创建的,也是我在 mongodb compass

中检查它们存在的集合

错误

pymongo.errors.ServerSelectionTimeoutError: projekt-shard-00-01-rk7ft.mongodb.net:27017: timed out,projekt-shard-00-00-rk7ft.mongodb.net:27017: timed out,projekt-shard-00-02-rk7ft.mongodb.net:27017: timed out

代码

client = MongoClient("""mongodb://user:password@projekt-shard-00-00-rk7ft.mongodb.net:27017,projekt-shard-00-01-rk7ft.mongodb.net:27017,projekt-shard-00-02-rk7ft.mongodb.net:27017/projekt?ssl=true&replicaSet=projekt-shard-0&authSource=admin""")

    client.projekt.category.insert_one({type : "pants"}).inserted_id

这个问题困扰我好几个小时了。奇怪的是,这似乎是一个连接问题,但它并没有抛出错误的身份验证或任何东西,只是这个超时。客户端对象似乎是实际创建的(我可以打印它的属性)。我一直在玩,这不知何故奏效了:

  • 在 MongoDB GUI 中,导航到数据库访问
  • 添加一个测试用户,该用户与设置时创建的初始用户具有相同的 read/write 权限
  • 将Python中的连接字符串更改为新用户的用户名+密码
  • 运行代码

对我来说,它终于连接并成功插入了。在此之后,原始用户的连接字符串现在可以使用了,所以我删除了测试用户。

我无法确定此问题的根本原因,但似乎数据库用户 table 只是需要对其执行某种操作以刷新并开始接受用户连接。

任何寻求解决方案的人,如果您试图从野外访问 Atlas 实例,请检查“网络访问”选项卡,因为我认为您必须将所有或特定 IP 地址列入白名单