windows下mongodb设置用户名密码&用python连接
本文博客链接:,作者:jdh,转载请注明.
环境:
主机:WIN10
python版本:3.5
mongodb版本:3.4.2
开发环境:pyCharm
- 编写mongodb配置文件mongodb.conf
dbpath=F:\test\db1logpath=F:\test\log\mongodb.loglogappend=truebind_ip=port=27019#fork=truemaster=trueauth=false
注意:设置用户名密码前将auth参数设置为false
输入命令:mongod -f f:/test/mongodb.conf
注意:直接输入mongo连接数据库默认ip是127.0.01,端口是270717
输入命令:mongo.exe mongodb://localhost:27019
- 在shell界面配置账号管理员root,利用此账号可以增加其他账号
输入命令:db.createUser({user:"root",pwd:"root",roles:[{"role":"userAdminAnyDatabase","db":"admin"}]})
- 在shell界面给数据库db1增加账号jdh11:
输入命令登陆账号管理员:db.auth("root", "root")
输入命令:db.createUser({user:"jdh11",pwd:"123456",roles:[{"role":"readWrite","db":"db1"}]})
userAdminAnyDatabase 有分配角色和用户的权限,没有读写的权限
root 超级管理员
readWrite 有读写权限
read 有读权限
将mongodb.conf中的auth设置为true
输入命令:mongod -f f:/test/mongodb.conf
输入命令:mongo.exe mongodb://localhost:27019
> show collections
2017-02-11T13:18:46.524+0800 E QUERY [thread1] Error: listCollections failed: {
"ok" : 0,
"errmsg" : "not authorized on db1 to execute command { listCollections: 1.0, filter: {} }",
"code" : 13,
"codeName" : "Unauthorized"
} :
_getErrorWithCode@src/mongo/shell/utils.js:25:13
DB.prototype._getCollectionInfosCommand@src/mongo/shell/db.js:805:1
DB.prototype.getCollectionInfos@src/mongo/shell/db.js:817:19
DB.prototype.getCollectionNames@src/mongo/shell/db.js:828:16
shellHelper.show@src/mongo/shell/utils.js:748:9
shellHelper@src/mongo/shell/utils.js:645:15
@(shellhelp2):1:1
注意:要切换到admin数据库登陆,完整登陆流程:
> use admin
switched to db admin
> db.auth("jdh11", "123456")
1
> use db1
switched to db db1
> show collections
col
>
HOST = '0.0.0.0'PORT = 12800DATABASE_IP = '127.0.0.1'DATABASE_PORT = 27019DATABASE_NAME = 'db1'
连接代码:
from pymongo import MongoClientfrom config import *client = MongoClient(DATABASE_IP, DATABASE_PORT)db_auth = client.admindb_auth.authenticate("jdh11", "123456")db = client[DATABASE_NAME]collection = db.colprint(list(collection.find({ 'name': 'jdh11'})))