python连接MongoDB踩过的坑

勤能补拙

  • 无密码无认证下连接
from pymongo import MongoClient
host = '10.90.10.9'   # 你的ip地址
client = MongoClient(host, 27017)  # 建立客户端对象
db = conn.mydb  # 连接mydb数据库,没有则自动创建
myset = db.testset   # 使用test_set集合,没有则自动创建
myset.insert({"name":"zhangsan","age":18})   # 插入一条数据,如果没出错那么说明连接成功
# 下面是遍历查询数据
for i in myset.find():
    print(i)          
  • 有密码连接
from pymongo import MongoClient
host = '10.90.10.9'
client = MongoClient(host, 27017)
#连接mydb数据库,账号密码认证
db = client.mydb    # mydb数据库,同上解释
db.authenticate("用户名", "密码")
collection = db.myset   # myset集合,同上解释
collection.insert({"name":"zhangsan","age":18})   # 插入一条数据,如果没出错那么说明连接成功

如果上例发生错误,如 pymongo.errors.OperationFailure: auth failed

from pymongo import MongoClient
host = '10.90.10.9'
client = MongoClient(host, 27017)
#连接mydb数据库,账号密码认证
db = client.mydb    # mydb数据库,同上解释
db.authenticate("用户名", "密码",mechanism='MONGODB-CR') # 增加了mechanism参数,mongoDB有不同的认证机制,3.0版本以后采用的是'SCRAM-SHA-1', 之前的版本采用的是'MONGODB-CR'
collection = db.myset   # myset集合,同上解释
collection.insert({"name":"zhangsan","age":18})   # 插入一条数据,如果没出错那么说明连接成功

好吧,如果还报错,还没有解决,还有一条路可走【继续看】

from pymongo import MongoClient
host = '10.90.10.9'
client = MongoClient(host, 27017)
#连接mydb数据库,账号密码认证
db = client.admin    # 先连接系统默认数据库admin
# 下面一条更改是关键,我竟然尝试成功了,不知道为啥,先记录下踩的坑吧
db.authenticate("用户名", "密码",mechanism='MONGODB-CR') # 让admin数据库去认证密码登录,好吧,既然成功了,
my_db = client.mydb  # 再连接自己的数据库mydb
collection = my_db.myset   # myset集合,同上解释
collection.insert({"name":"zhangsan","age":18})   # 插入一条数据,如果没出错那么说明连接成功

如果你根据上面几种方法还没解决,我也不知道了,误导误撞,有人看到能解释下为啥嘛,个人启发是通过客户端连接设置,之前客户端连接不上,更改了一下设置才连上的,如下图:

《python连接MongoDB踩过的坑》 image.png

好吧,就是上面标红框的地方,才这样做就成功了。
成功实例如下:

《python连接MongoDB踩过的坑》 image.png

以下参考资料:
https://www.cnblogs.com/melonjiang/p/6536876.html
https://www.cnblogs.com/dplearning/p/5127869.html

    原文作者:克里斯托弗的梦想
    原文地址: https://www.jianshu.com/p/7437666f93e5
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞