本文整理自网络,侵删。
1、启动没有访问控制的MongoDB服务
sudo service mongod start
2、连接到实例
mongo --port 27017
指定额外的命令行选项来连接Mongo shell到部署Mongodb服务器, 如--host
3、创建的用户管理员
use admin
db.createUser(
{
user: "myUserAdmin",
pwd: "abc123",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
4、重新启动MongoDB实例,并启用访问控制
1、重新启动mongod实例,如果使用配置文件的设置,security.authorization:
vi /etc/mongod.conf
修改内容:
security:
authorization: enabled
2、注意:keys and values之间一定要加空格, 否则解析会报错
重启服务:
sudo service mongod start
5、用户管理员身份验证
1、创建连接mongo shell 时进行授权,指定-u <username>, -p <password>, and the --authenticationDatabase <database>
mongo --port 27017 -u "myUserAdmin" -p "abc123" --authenticationDatabase "admin"
2、mongo shell连接时不认证,使用db.auth()授权
use admin
db.auth("myUserAdmin", "abc123" )
--------------------服务器以开启认证后,如何添加用户--------------------
1、启动MongoDB实例的访问控制
启动mongod实例 AUTH命令行选项,如果使用配置文件的设置,security.authorization。
sudo service mongod start
2、通过localhost exception 连接MongoDB实例
添加第一个用户, 使用Localhost Exception,连接一个mongod实例。运行Mongo shell和mongod实例必须来自同一主机
3、同上创建用户方式相同
--------------------普通用户安全访问权限--------------------
1、启动MongoDB
service mongod start
2、再次打开MongoDB shell
1、mongo --port 27017 -u "myUserAdmin" -p "abc123" --authenticationDatabase "admin"
2、mongo
use admin
db.auth("myUserAdmin","abc123")
3、show collections:报错
因为用户myUserAdmin只用用户的管理权限
3、创建用户,用户都跟着数据库走
为myuseradmin创建用户myUserAdmin在admin 数据库
use admin
db.createUser(
{
user: "myUserAdmin",
pwd: "abc123",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
4、查看刚刚创建的用户
show users
相关阅读 >>
更多相关阅读请进入《mongodb》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。