mongodb用户权限
mongodb用户权限
mongodb用户权限一、mongodb用户的特性
1、mongodb系统中,数据库是由超级用户来创建的,一个数据库可以包含多个用户,一个用户只能在一个数据库下,不同数据库中的用户可以同名。
2、当admin.system.users一个用户都没有时,即使mongod启动时添加了--auth参数,如果没有在admin数据库中添加用户,此时不进行任何认证还是可以做任何操作(不管是否是以--auth 参数启动),直到在admin.system.users中添加了一个用户。
3、特定数据库比如DB1下的用户User1,不能够访问其他数据库DB2,但是可以访问本数据库下其他用户创建的数据!
4、不同数据库中同名的用户不能够登录其他数据库!比如DB1,DB2都有user1,以user1登录DB1后,不能够登录到DB2进行数据库操作!
5、在admin数据库创建的用户具有超级权限,可以对mongodb系统内的任何数据库的数据对象进行操作!二
二、mongodb用户权限实例
1、启动一个MongoDB实例,然后通过MongoDB shell建立两个数据库test1,test2,并且插入一些测试数据
mongod.exe --dbpath="c:\mongodb\db\mtest"
> use test1
switched to db test1
> for(var i=0;i<10;i++){
... var randAge = parseInt(5*Math.random()) + 20;
... var gender = (randAge%2)?"Male":"Female";
... db.student.insert({"sid":i, "name":"Will"+i, "gender": gender, "age": randAge});
... }
> use test2
switched to db test2
> for(var i=0;i<10;i++){
... var randAge = parseInt(5*Math.random()) + 20;
... var gender = (randAge%2)?"Male":"Female";
... db.student.insert({"sid":i, "name":"Will"+i, "gender": gender, "age": randAge});
... }
> show dbs
local 0.078125GB
test1 0.203125GB
test2 0.203125GB
>
2、通过下面命令给各个数据库添加用户,其中addUser()的第三个参数表示,是否只有只读权限
use test1
db.addUser("Wilber1", "Wilber1", true)
db.addUser("Will1", "Will1")
use test2
db.addUser("Wilber2", "Wilber2", true)
db.addUser("Will2", "Will2")
3、接下来,重新启动MongoDB实例,这次需要加上"—auth"选项
mongod.exe --dbpath="c:\mongodb\db\mtest" –auth
4、通过下面一系列操作就可以验证上面新添加用户的权限了
C:\mongodb\bin>mongo.exe
MongoDB shell version: 2.4.6
connecting to: test
> use test1
switched to db test1
> db.student.find()
error: { "$err" : "not authorized for query on test1.student", "code" : 16550 }
> db.auth("Wilber1","Wilber1")
> db.student.find()
{ "_id" : ObjectId("548d74a241393de780336eb5"), "sid" : 0, "name" : "Will0", "gender" : "Female", "age" : 22 }
{ "_id" : ObjectId("548d74a241393de780336eb6"), "sid" : 1, "name" : "Will1", "gender" : "Male", "age" : 21 }
{ "_id" : ObjectId("548d74a241393de780336eb7"), "sid" : 2, "name" : "Will2", "gender" : "Male", "age" : 23 }
{ "_id" : ObjectId("548d74a241393de780336eb8"), "sid" : 3, "name" : "Will3", "gender" : "Female", "age" : 20 }
{ "_id" : ObjectId("548d74a241393de780336eb9"), "sid" : 4, "name" : "Will4", "gender" : "Female", "age" : 20 }
{ "_id" : ObjectId("548d74a241393de780336eba"), "sid" : 5, "name" : "Will5", "gender" : "Female", "age" : 24 }
{ "_id" : ObjectId("548d74a241393de780336ebb"), "sid" : 6, "name" : "Will6", "gender" : "Male", "age" : 23 }
{ "_id" : ObjectId("548d74a241393de780336ebc"), "sid" : 7, "name" : "Will7", "gender" : "Female", "age" : 24 }
{ "_id" : ObjectId("548d74a241393de780336ebd"), "sid" : 8, "name" : "Will8", "gender" : "Male", "age" : 21 }
{ "_id" : ObjectId("548d74a241393de780336ebe"), "sid" : 9, "name" : "Will9", "gender" : "Male", "age" : 21 }
> db.student.insert({"name":"July"})
not authorized for insert on test1.student
> db.auth("Will1","Will1")
> db.student.insert({"name":"July"})
> db.auth("Will2","Will2")
Error: 18 { code: 18, ok: 0.0, errmsg: "auth fails" }
> use test2
switched to db test2
> db.student.find()
error: { "$err" : "not authorized for query on test2.student", "code" : 16550 }
>
5、上面只是给各个数据库添加用户,我们也可以给这个MongoDB实例添加一个管理员。这个管理员对所有的数据库都有读写权限,并且可以管理各个数据库的用户。
use admin
db.addUser("root","root")
db.auth("root","root")
- 什么是mongodb 固定集合
- mongodb连接池
- mongodb insert操作
- MongoDB聚合函数
- MongoDB的连接字符串
- mongodb eval 执行服务器端脚本
- MongoDB 日志文件太大
- mongodb中mapreduce实例
- python直接查询mongodb(pymongo中聚合查询的使用方法)
- mongodb objectid类型
- docker怎么装mongodb(Docker 搭建集群MongoDB的实现步骤)
- MongoDB命令与SQL语法对比
- mongodb 分页查询
- python mongodb 基本操作(Python使用pymongo库操作MongoDB数据库的方法实例)
- java连接mongodb(Docker连接mongodb实现过程及代码案例)
- mongodb查询
- 王牌部队,你看的剧情我看的时尚(你看的剧情我看的时尚)
- 被鉴定的古董价值300万 当心,你可能遇到诈骗了(被鉴定的古董价值300万)
- 英语难学吗(初中英语难学吗)
- 如何追女孩子(如何追女孩子的技巧和方法)
- 是不是快乐全被你拿走了(而是你得到的)
- 世界上只有妈妈好(世界上只有妈妈好的歌词)
热门推荐
- css不显示滚动条设置(css隐藏移动端滚动条并且ios上平滑滚动的方法)
- centos7 apache配置(CentOSLinux下的apache服务器配置与管理方法分享)
- JavaScript中==和===的区别
- docker怎么使用supervisor(supervisor下的Dockerfile的多服务镜像封装操作)
- SQLite数据类型
- 网站服务器不稳定(如何保证网站服务器长期稳定正常运行)
- dede网站地图模块(Dedecms中百度网站地图制作的方法图文教程)
- nginx反向代理spring boot(Nginx+SpringBoot实现负载均衡的示例)
- sql server性能调优(SQL Server性能调优之缓存)
- linux系统登录mysql数据库(Linux手动部署远程的mysql数据库的方法详解)