安装部署mongodb

 

MongoDB 预编译二进制包下载地址:https://www.mongodb.com/download-center/community

命令行下运行 MongoDB 服务器

为了从命令提示符下运行 MongoDB 服务器,你必须从 MongoDB 目录的 bin 目录中执行 mongod.exe 文件。

C:\mongodb\bin\mongod --dbpath c:\data\db

连接MongoDB

我们可以在命令窗口中运行 mongo.exe 命令即可连接上 MongoDB,执行如下命令:

C:\mongodb\bin\mongo.exe

将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;


上一篇:mongDB进阶


下一篇:使用Java操作MongoDB的小demo