Windows下MongoDB安装及创建用户名和密码

  1. 云栖社区>
  2. 博客>
  3. 正文

Windows下MongoDB安装及创建用户名和密码

优惠券发放 2018-07-20 12:07:02 浏览2020
展开阅读全文

Windows下MongoDB安装及创建用户名和密码

下载MongoDB的安装文件https://www.mongodb.com/download-center#community,选择合适的版本(注:本人选择的是3.2.6)

下载完MongoDB.msi后点击Next一路安装下去(注:本人的mongodb的安装路径为D:\MongoDB\Server\)

将MongoDB服务器作为Windows服务运行
请注意,你必须有管理权限才能运行下面的命令。执行以下命令将MongoDB服务器作为Windows服务运行:

mongod.exe --bind_ip 127.0.0.1 --logpath "D:\MongoDB\Server\mglogs\mongodb.log" --logappend --dbpath "D:\MongoDB\Server\db" --serviceName "mongodb" --serviceDisplayName "mongodb" --auth --install    (注:加上--auth 这样以后就可以使用用户名和密码后才能进行MongoDB的相关操作)

上述命令运行成功后,开始—>运行—>输入services.msc 回车后就可以打开 windows 所有的服务项列表 ;在列表中就可以查看到mongodb的服务项,点击启动。

--------------------------------------------------------------------------------------------------------------------------

启动完MongoDB后,cmd命令下进入D:\MongoDB\Server\bin(即MongoDB的安装目录),执行mongo.exe;

上面提到过为了MongoDB的安全,我们必须通过用户名和密码登陆后才能操作MongoDB,现在增加一个管理员:

 

use admin  注:MongoDB安装好以后由默认的admin表和local表;其中admin存放的是用户信息

db.createUser({ user: "root",pwd: "root",customData:{name:"root"},roles:[{ role: "userAdminAnyDatabase",db: "admin" }]}) 注:创建一个用户名和密码为root的管理员

创建完后登陆

db.auth('root','root')

show collections


--------------------------------------------------------------------------------------------------------------------------

createUser 方法 db.createUser( { user: "accountAdmin01",
pwd: "changeMe",
customData: { employeeId: 12345 },
roles: [ { role: "clusterAdmin", db: "admin" },
{ role: "readAnyDatabase", db: "admin" },
"readWrite"] },
{ w: "majority" , wtimeout: 5000 } )

customData 用户信息备注

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

> 创建一般用户,也是用createUser

use db01db.createUser({user:"oneUser",pwd:"12345",roles:[{role:"read",db:"db01"},{role:"read",db:"db02"},{role:"read",db:"db03"}]})


> 创建一个不受访问限制的超级用户 use admindb.createUser({user:"superuser",pwd:"pwd",roles:["root"] })

--------------------------------------------------------------------------------------------------------------------------

修改用户密码

use admin
db.changeUserPassword("username", "xxx")


--------------------------------------------------------------------------------------------------------------------------

查看用户信息
db.runCommand({usersInfo:"userName"})

--------------------------------------------------------------------------------------------------------------------------

修改密码和用户信息
db.runCommand( { updateUser:"username", pwd:"xxx", customData:{title:"xxx"} })

注意:和用户管理相关的操作基本都要在admin数据库下运行,要先use admin;

原文链接:http://www.cnblogs.com/itxiongwei/p/5520690.html

网友评论

作者关闭了评论
优惠券发放
+ 关注