mongodb安装与权限配置
mongodb下载地址:官方下载
IDE工具:Robo 3T:官方下载
windows系统要求64位,最低2g内存,推荐8g内存及以上
安装过程没有需要配置的地方,直接下一步到结束,如果想要方便可以在环境变量中Path追加mongodb安装文件的bin目录

在想要保存数据库的盘符新建文件夹mongodb 包含两个子文件夹 data和log及一个mongod.cfg文件,log文件夹新建文本改为mongo.log

其中mongod.cfg文件内容如下(本人用虚拟机只有一个C盘):
dbpath=C:\mongodb\data
logpath=C:\mongodb\log\mongo.log
logappend=true
directoryperdb=true
auth=false
#port=55600
#表示忽略该行,本示例没有使用自定义端口,将采用默认端口27017,如果设置了端口号 ,之后连接mongo都需要指定服务器和端口号
以管理员身份运行命令提示符,如果已经配置过环境变量,直接运行 mongod,否则需要移动到mongodb安装目录的bin文件夹再执行mongod
如果报以下异常

可去 https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=48145 下载vc_redist.x64.exe安装即可
执行以下命令创建并开启MongoDB服务(需要管理员权限)
sc create MongoDB binPath= "C:\Program Files\MongoDB\Server\3.4\bin\mongod.exe --config=C:\mongodb\mongod.cfg --service"
net start MongoDB

接下来打开MongoDB Shell工具:在命令提示符中输入 mongo 运行(如果已经设置端口12345,此处为 mongo --port 12345)

此时的数据库是没有权限控制的,任何人都可以登录到数据库
输入 show dbs; 显示所有数据库
输入 use admin; 使用admin数据库 分号是可选的
输入 show collections 显示所有文档(关系型数据库中表的概念)
输入 show users 显示所有用户,当前没有任何账户

接下来创建账户,确保是在use admin的情况下:
db.createUser({
user:"root",
pwd: "123456",
roles: [ { role: "root", db: "admin" }]
})
db.createUser({
user:"sa",
pwd: "123456",
roles: [ { role: "userAdminAnyDatabase", db: "admin" },{ role: "read", db: "clearimg" } ]
})
注册用户登录权限(这几个账号是在admin数据库下,连接服务器即使有其他数据库权限也必须连接到admin)
db.auth("root","123456")
db.auth("sa","123456")

添加一个新的数据库 mytest,只需要对mytest数据库进行文档操作,存在则调用,不存在则创建
在mytest数据库新建账号test,并注册权限
db.createUser({
user:"test",
pwd: "123456",
roles: [{ role: "read", db: "mytest" } ]
})
db.auth("test","123456")
切换到admin数据库添加test2用户使其只拥有mytest数据库的read权限
use mytest
db.createUser({
user:"test2",
pwd: "123456",
roles: [{ role: "read", db: "mytest" } ]
})
db.auth("test2","123456")
用show users 查看当前数据库拥有的账户
最后用exit或者ctrl + c退出MongoDB Shell 到此为止数据库已经拥有对应的账户,没有开启权限验证
接下来停用原有MongoDB服务(需要管理员权限)
net stop MongoDB

并更新mongod.cfg文件中的auth=true,执行启动服务的指令(需要管理员权限)
net start MongoDB
现在已经开启权限认证了,再次登录打开MongoDB Shell ,输入show dbs,发现报异常

exit退出MongoDB Shell,改用账号登录服务器
mongo -u sa -p 123456 localhost:27017/admin

尝试登录时不带数据库名,发现报权限错误
切换账号test2登录 分别尝试连接到admin 和mytest会发现test2可以登录admin而不是mytest,但test2只有mytest的读取权限,操作admin数据库也是非法的

尝试用test账号登录mytest数据库并尝试操作其他数据库

备份和恢复角色:bakcup restore
所有数据库角色:
read 指定数据库的只读权限,拥有以下权限:
readWrite 拥有指定数据库的读写权限,除了具有read权限,还拥有以下权限:
read和readWrite只要就是对库中表的操作权限
dbAdmin 指定数据库的管理权限
userAdmin 指定数据库的用户管理权限
clusterAdmin 集群管理权限
readAnyDatabase 任何数据库的只读权限(和read相似)
readWriteAnyDatabase 任何数据库的读写权限(和readWrite相似)
userAdminAnyDatabase 任何数据库用户的管理权限(和userAdmin相似)
dbAdminAnyDatabase 任何数据库的管理权限(dbAdmin相似)
创建用户 db.createUser({user:"username",pwd: "pwd",roles: [ { role: "rolename", db: "dbname" },{ role: "rolename2", db: "dbname2" } ]})
修改密码 db.changeUserPassword('usname','newpwd');
添加角色 db.grantRolesToUser("username", [{ role: "rolename",db:"dbname"}] )
删除权限 db.revokeRolesFromUser("username",[{ role: "rolename",db:"dbname"}])
删除用户 db.dropUser("username")
mongodb安装与权限配置的更多相关文章
- mongoDB在windows下基于配置文件的安装和权限配置方式
下载mongoDB http://www.mongodb.org/downloads 根据操作系统,选择需要下载的安装包 添加mongodb 安装目录 将解压的文件夹中内容拷贝,存放在想要安装的文件 ...
- Linux下Mongodb安装和启动配置 原
1.安装 略 2.配置 01.mkdir /usr/local/mongodb/data 0.touch /usr/local/mongodb/logs 03.cd /usr/local/mongod ...
- CentOS7 MongoDB安装及基本配置
一.安装包的获取 1.创建文件: vi /etc/yum.repos.d/mongodb-org-4.0.repo 2.在上一步创建的文件中,写入如下内容: [mongodb-org-4.0] nam ...
- ubuntu 中 mongodb 数据读写权限配置
首先,我们先对mongodb 数据库的权限做一点说明: 1 默认情况下,mongodb 没有管理员账号 2 只有在 admin 数据库中才能添加管理员账号并开启权限 3 用户只能在所在的数据库中登录, ...
- Linux下Mongodb安装和启动配置
1.下载安装包 wget http://fastdl.mongodb.org/linux/mongodb-linux-i686-1.8.2.tgz 下载完成后解压缩压缩包 tar zxf mongod ...
- Linux下Mongodb安装和启动配置 转载
原文地址:https://www.cnblogs.com/Jimmy104/p/6181899.html 以下文章为转载,感谢网友,原文链接 http://blog.csdn.net/yuwenrul ...
- python开发遇到的坑(2)mongodb安装路径权限问题
个人比较懒,Mac 电脑直接使用命令行安装,brew install mongodb,但是遇到两个问题,其一: Error: The following directories are not wri ...
- MongoDB安装及环境配置
一.什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供 ...
- Linux FTP的安装与权限配置
ftp安装部分,操作步骤如下: 1.切换到root用户 2.查看是否安装vsftp,我这个是已经安装的. [root@localhost vsftpd]# rpm -qa |grep vsftpd v ...
随机推荐
- kettle中的karaf设置
Spoon.sh设置-Dpentaho.karaf.root.copy.dest.folder=$PENTAHO_KARAF_ROOT -Dpentaho.karaf.root.transient=f ...
- 元类 metaclass
metaclass 类由Type创建 对象由创建 MetaClass作用 用来指定当前类由谁来创建(默认type创建). MetaClass 会被继承,如果父类指定了元类,那么子类也是由这个元类创建 ...
- iis 反向代理 组件 Application Request Route
安装后要重启服务器. 不然 IIS 不会生效.
- XDU 1022 (数论筛法+前缀和)
解法一:数论筛法+前缀和 //其实题目中f[n]的值可理解为存在多少个整数对使a*b<=n #include<cstdio> #define N 1007 #define maxn ...
- 跨域问题-cors
什么是跨域如大家所知,出于安全考虑,浏览器会限制脚本中发起的跨站请求.比如,使用 XMLHttpRequest 对象发起 HTTP 请求就必须遵守同源策略(same-origin policy). 具 ...
- rmp-st算法
struct RMQ { ]; void init(int n) { ; i <= n; i ++)log2[i] = (i == ? - : log2[i >> ] + ); ; ...
- Straight Master Gym-101775J (思维+差分)
题意:给出N种类的数量,求是否可以把N种牌按3-5张连续的顺子打出,顺子必须连续. 分析:相当于把这个序列分成若干长度为[3,5]的区间,当然其实分成若干段大于3的区间即可.因为大于5的区间又可以分拆 ...
- ThreadLocal的设计理念与作用
转自:http://www.iteye.com/topic/103804 首先,ThreadLocal 不是用来解决共享对象的多线程访问问题的,一般情况下,通过ThreadLocal.set() 到线 ...
- c++对txt文件的读取与写入
转自:http://blog.csdn.net/lh3325251325/article/details/4761575 #include <iostream> #include < ...
- 一篇关于cfDNA的综述
文章题目:A Field Guide for Cancer Diagnostics using cell-free DNA: from Principles to Practice and Clini ...