1.了解 mongodb的权限管理
刚安装完毕的mongodb默认不使用权限认证方式启动,与MySQL不同,mongodb在安装的时候并没有设置权限,然而公网运行系统需要设置权限以保证数据安全,所以我们要学习mongodb的权限管理
MongoDB是没有默认管理员账号,所以要先添加管理员账号,并且mongodb服务器需要在运行的时候开启验证模式
进入mongo shell
sudo mongod
使用admin数据库(超级管理员账号必须创建在该数据库上)
xxxxxxxxxxuse admin
创建超级用户
xxxxxxxxxxdb.createUser({"user":"python","pwd":"python","roles":["root"]})
创建成功会显示如下信息
xxxxxxxxxxSuccessfully added user: { "user" : "python", "roles" : [ "root" ] }
退出mongo shell
xxxxxxxxxxexit
xxxxxxxxxxsudo mongod --auth
启动之后在启动信息中会有如下信息,说明mongodb以权限认证的方式启动成功
xxxxxxxxxx[initandlisten] options: { security: { authorization: "enabled" } }
此时再使用数据库各命令的时候会报权限错误,需要认证才能执行相应操作、
xxxxxxxxxxuse admindb.auth('python','python')
1.选择需要创建用户的数据库
xxxxxxxxxxuse test1
xxxxxxxxxxdb.createUser("user":"user1", "pwd":"pwd1", roles:["read"])创建普通用户user1,该用户在test1上的权限是只读db.createUser("user":"user1", "pwd":"pwd1", roles:["readWrite"])创建普通用户user1,该用户在test1上的权限是读写
xxxxxxxxxxuse admindb.createUser({"user":"python1", "pwd":"python1", roles:[{"role":"read","db":"dbname1"},{"role":"readWrite","db":"dbname2"}]})
在admin上创建python1用户,python1用户的权限有两个,一个再dbname1上的只读,另一个是在dbname2上的读写
xxxxxxxxxxshow users{"_id" : "admin.python","user" : "python","db" : "admin","roles" : [{"role" : "root","db" : "admin"}]}
xxxxxxxxxxuse db_name
xxxxxxxxxxdb.dropUser('python')