mongodb設置密碼

mongodb密碼和傳統數據如mysql等有些區別:mysql

  1. mongodb的用戶名和密碼是基於特定數據庫的,而不是基於整個系統的。全部全部數據庫db都須要設置密碼

mongodb設置管理用戶和密碼:git

  1. show dbs
    在mongodb新版本里並無admin數據庫,可是並不妨礙第2步操做。
  2. use admin 進入admin數據庫
  3. 建立管理員帳戶
    db.createUser({ user: "useradmin", pwd: "adminpassword", roles: [{ role: "userAdminAnyDatabase", db: "admin" }] })
    mongodb中的用戶是基於身份role的,該管理員帳戶的 role是 userAdminAnyDatabase。 ‘userAdmin’表明用戶管理身份,’AnyDatabase’ 表明能夠管理任何數據庫。
  4. 驗證第3步用戶添加是否成功
    db.auth("useradmin", "adminpassword") 若是返回1,則表示成功。
    exit退出系統
    db.auth()方法理解爲 用戶的驗證功能
  5. 修改配置
    sudo vi /etc/mongod.conf
    找到#security: 取消註釋,修改成:
    複製代碼
    1. security:
    2. authorization: enabled #注意縮進,縮進參照配置文件其餘配置。縮進錯誤可能第6步重啓不成功。
  6. 重啓mongodb sudo service mongod restart
  7. 進入mongodb,用第3步的 管理員帳戶登陸,用該帳戶建立其餘數據庫管理員帳號
    複製代碼
    1. use admin
    2. db.auth("useradmin", "adminpassword")
  8. 新建你須要管理的mongodb 數據的帳號密碼。github

    複製代碼
    1. use yourdatabase
    2. db.createUser({ user: "youruser", pwd: "yourpassword", roles: [{ role: "dbOwner", db:"yourdatabase" }] })

    rote:dbOwner 表明數據庫全部者角色,擁有最高該數據庫最高權限。好比新建索引等sql

  9. 新建數據庫讀寫帳戶mongodb

    複製代碼
    1. use yourdatabase
    2. db.createUser({ user: "youruser2", pwd: "yourpassword2", roles: [{ role: "readWrite",db: "yourdatabase" }] })

    該用戶用於該數據的讀寫,只擁有讀寫權限。數據庫

  10. 如今數據的用戶名和密碼就建好了。
    能夠使用:mongodb://youruser2:yourpassword2@localhost/yourdatabase來連接bash

相關文章
相關標籤/搜索