在网上查了一些 python 链接 MongoDB的博客,拿来主义直接用。 结果 发现连接有问题。
比如这个博客上说的 https://www.oschina.net/code/snippet_2463131_52778
#coding=utf-8
#导入模块
import pymongo
#建立连接
client=pymongo.MongoClient("localhost",27017)
#数据库名admin
db=client.admin
#认证用户密码
db.authenticate('root','123456')
#创建集合和数据
db.test.insert({"name":"this is test"})
col=db.test
#打印数据输出
for item in col.find():
print item
#关闭连接
client.close()
运行后发现 认证有问题
OperationFailure: Authentication failed.
上stackoverflow 上看到 可以这样链接 DB
https://stackoverflow.com/questions/40346767/pymongo-auth-failed-in-python-script
client = MongoClient('mongodb://user_name:user_password@localhost:27017/prod-db')
db = client['prod-db']
这样是可以连接上的。
之后查找了一下上一个代码不能链接的原因,结果发现是这个admin,因为我们配置 MongoDB的时候没有给admin 账户,所以出现了,认证失败的问题。
所以上述代码可以改成如下
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient[""]
mydb.authenticate('root','123456')
print(mydb.list_collection_names())
这样连接 就是成功的。