-
注意:
- 验证库,建立用户时use到的库,在使用用户时,要加上验证库才能登陆。
- 对于管理员用户,必须在admin下创建.
-
- 建用户时,use到的库,就是此用户的验证库
-
- 登录时,必须明确指定验证库才能登录
-
- 通常,管理员用的验证库是admin,普通用户的验证库一般是所管理的库设置为验证库
-
- 如果直接登录到数据库,不进行use,默认的验证库是test,不是我们生产建议的.
-
创建用户的语法:
- db.createUser
- {
- user: "<name>",
- pwd: "<cleartext password>",
- roles: [
- { role: "<role>",
- db: "<database>" } | "<role>",
- ...
- ]
- }
-
语法说明:
- user:用户名
- pwd:密码
- roles:
- role:角色名
- db:作用对象
- role:root, readWrite,read
-
实例1:
- 创建超级管理员,管理所有数据库(必须在admin库中创建)
-
登录mongodb:
- mongo
- use admin
- db.createUser(
- {
- user: "root",
- pwd: "root123",
- roles: [ { role: "root", db: "admin" } ]
- }
- )
- 登录验证用户创建是否成功:
- mongo -uroot -proot123 192.168.8.5/admin
-
禁止mongo无用户密码登录:
- vim /mongodb/conf/mongo.conf
-
添加:
- security:
- authorization: enabled
-
重启mongodb
- mongod -f /mongodb/conf/mongo.conf --shutdown
- mongod -f /mongodb/conf/mongo.conf
- 再次使用mongo登录 发现可以登录 但看不到任何数据库
- 查看所有用户:
- db.system.users.find().pretty()
-
实例2;
-
创建库管理用户:
- 登录数据库:mongo -uroot -proot123 admin
- use app (针对于app库创建管理用户)
- db.createUser(
- {
- user: "adminapp",
- pwd: "app123",
- roles: [ { role: "dbAdmin", db: "app" } ]
- }
- )
- 登录测试:mongo -uadminapp -papp123 192.168.8.10/app
-
-
实例3:
-
针对于app库创建app01用户,赋予读写权限:
- use app
- 单库完全控制账户
- db.createUser(
- {
- user: "app01",
- pwd: "app01",
- roles: [ { role: "readWrite" , db: "app" } ]
- }
- )
- 登录测试:mongo -uapp01 -papp01 192.168.8.10/app
-
单库只读账户:
- use app
- db.createUser(
- {
- user: "app02",
- pwd: "app02",
- roles: [ { role: "read" , db: "app" } ]
- }
- )
- mongo -uapp02 -papp02 192.168.8.10/app
-
-
-
实例4:创建app数据库读写权限的用户并对test数据库具有读写权限:
-
创建多库管理账户:
- 用户app03针对于app具有读写权限,针对于test库同样具备读写权限
- mongo -uroot -proot123 192.168.8.10/admin
- use app
- db.createUser(
- {
- user: "app03",
- pwd: "app03",
- roles: [ { role: "readWrite", db: "app" },
- { role: "readWrite", db: "test" }]})
- mongo -uapp03 -papp03 192.168.8.10/app
-
-
实例5:
-
查询mongodb中的用户信息:
- mongo -uroot -proot123 192.168.8.10/admin
- db.system.users.find().pretty()
-
删除用户(需要以root用户登录到验证库)
- mongo -uroot -proot123 192.168.8.10/admin
- use app
- db.dropUser("adminapp")
-
2.MongoDB 用户管理
努力转型的IT小王2024-06-12 13:46
相关推荐
WeiQ_28 分钟前
解决phpstudy 8.x软件中php8.2.9没有redis扩展的问题DashVector5 小时前
向量检索服务 DashVector产品计费KYGALYX6 小时前
在Linux中备份msyql数据库和表的详细操作檀越剑指大厂6 小时前
金仓KReplay:定义数据库平滑迁移新标准余—笙6 小时前
Linux(docker)安装搭建CuteHttpFileServer/chfs文件共享服务器lang201509286 小时前
Linux高效备份:tar与gzip完全指南努力成为一个程序猿.6 小时前
【Flink】FlinkSQL-动态表和持续查询概念IDOlaoluo6 小时前
OceanBase all-in-one 4.2.0.0 安装教程(CentOS 7/EL7 一键部署详细步骤)毕设十刻7 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末catoop7 小时前
在 WSL 的 Ubuntu 中安装和配置 SSH 服务