2.MongoDB 用户管理

  • 注意:

    • 验证库,建立用户时use到的库,在使用用户时,要加上验证库才能登陆。
    • 对于管理员用户,必须在admin下创建.
      1. 建用户时,use到的库,就是此用户的验证库
      1. 登录时,必须明确指定验证库才能登录
      1. 通常,管理员用的验证库是admin,普通用户的验证库一般是所管理的库设置为验证库
      1. 如果直接登录到数据库,不进行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")
相关推荐
爱奥尼欧6 分钟前
【Linux 系统】基础IO——Linux中对文件的理解
linux·服务器·microsoft
戒不掉的伤怀33 分钟前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
超喜欢下雨天34 分钟前
服务器安装 ros2时遇到底层库依赖冲突的问题
linux·运维·服务器·ros2
cv高级工程师YKY39 分钟前
服务器 - - QPS与TPS介绍
数据库
nbsaas-boot1 小时前
高可扩展属性建模设计:架构师的全局思考与落地方案
数据库
爱上语文1 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
tan77º1 小时前
【Linux网络编程】网络基础
linux·服务器·网络
陈敬雷-充电了么-CEO兼CTO2 小时前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
MeshddY2 小时前
(超详细)数据库项目初体验:使用C语言连接数据库完成短地址服务(本地运行版)
c语言·数据库·单片机
wuxinyan1232 小时前
Java面试题033:一文深入了解MySQL(5)
java·数据库·mysql·面试