2.MongoDB 用户管理

  • 注意:
    • 验证库,建立用户时use到的库,在使用用户时,要加上验证库才能登陆。
    • 对于管理员用户,必须在admin下创建.
    • 1. 建用户时,use到的库,就是此用户的验证库
    • 2. 登录时,必须明确指定验证库才能登录
    • 3. 通常,管理员用的验证库是admin,普通用户的验证库一般是所管理的库设置为验证库
    • 4. 如果直接登录到数据库,不进行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")
MongoDB 中,可以通过以下方式进行用户管理: 1. 创建用户: 使用 `db.createUser()` 方法创建新用户。例如,创建一个用户名为 "admin",密码为 "password",角色为 "userAdminAnyDatabase" 的用户可以执行以下命令: ``` db.createUser( { user: "admin", pwd: "password", roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] } ) ``` 2. 删除用户: 使用 `db.dropUser()` 方法删除现有用户。例如,删除名为 "admin" 的用户可以执行以下命令: ``` db.dropUser("admin") ``` 3. 修改用户密码: 使用 `db.changeUserPassword()` 方法修改现有用户密码。例如,将名为 "admin" 的用户密码修改为 "newpassword" 可以执行以下命令: ``` db.changeUserPassword("admin", "newpassword") ``` 4. 切换到其他数据库管理用户: 使用 `use <db>` 命令切换到其他数据库,然后使用上述命令进行用户管理。 5. 查看当前数据库用户: 使用 `db.getUsers()` 方法查看当前数据库用户列表。例如,查看当前数据库(如 "admin")的用户列表可以执行以下命令: ``` db.getUsers() ``` 6. 查看指定数据库用户: 使用 `db.getSiblingDB(<db>).getUsers()` 方法查看指定数据库用户列表。例如,查看数据库 "mydb" 的用户列表可以执行以下命令: ``` db.getSiblingDB("mydb").getUsers() ``` 7. 用户认证: 使用 `db.auth()` 方法对用户进行身份验证。例如,使用名为 "admin" 的用户密码 "password" 进行身份验证可以执行以下命令: ``` db.auth("admin", "password") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力转型的IT小王

希望获得您的认可!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值