Windows下MongoDB设置用户、密码

在默认状况下,mongod是监听在127.0.0.1之上的,任何客户端均可以直接链接27017,且没有认证。mongodb

好处是,用户能够即时上手,不用担忧被一堆配置弄的心烦意乱。数据库

坏处是,公网服务器搭建MongoDB,那么全部人均可以直接访问并修改数据库数据了。服务器

默认状况下,mongod也是没有管理员帐户的。所以除非你在admin数据库中使用db.createUser()命令添加了管理员账号,且使用–auth参数启动mongod,不然在数据库中任何人均可以无需认证执行全部命令。工具

 

1、建立全部数据库管理员用户:spa

一、管理员身份运行cmd.exe,先cd到Mongodb安装目录的bin目录,3d

输入命令mongo.exe,进入mongodb命令界面:rest

 

二、建立数据库test1blog

插入一条数据,而后用命令:show dbs 才能看到cmd

能够看到test1。it

 

三、进入admin数据库:

命令:use admin

 

四、建立管理帐号:

首先看看mongodb内置角色:

    1. 数据库用户角色:read、readWrite;
    2. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
    3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
    4. 备份恢复角色:backup、restore;
    5. 全部数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
    6. 超级用户角色:root  
    7. 内部角色:__system

使用命令:db.createUser({user:"testAdmin",pwd:"123456",roles:[{role:"userAdminAnyDatabase",db:"admin"}]})

 

五、重启mongodb服务,

从新打开cmd,在mongodb路径的bin目录下,执行mongod --dbpath  d:\mongodb\data  --auth   (data是安装mongodb建立的数据库文件夹)

 

六、验证用户添加是否成功:

结果为1,说明成功。

 

七、使用Robomongo工具链接:

能够看到刚才建立的管理员用户testAdmin(角色userAdminAnyDatabase),有权限访问全部数据库。

 

2、下面对单个数据库设置用户、密码

 同上建立test1的方式,建立数据库test2

运行命令: db.createUser({user:'test2admin',pwd:'123456',roles:[{role:'readWrite',db:'test2'}]})

使用Robomongo工具链接:

用户test2admin只能看到数据库test2。

相关文章
相关标签/搜索