真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

【Mongo】mongodb的用戶認證

1.創(chuàng)建超級賬號

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設,廣饒企業(yè)網(wǎng)站建設,廣饒品牌網(wǎng)站建設,網(wǎng)站定制,廣饒網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,廣饒網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

  1. > use admin ;
  2. > db . createUser ( { user : "admin" , pwd : "123456" , roles : [ { role : "root" , db : "admin" } ] } )
  3. Successfully added user : {
  4.          "user" : "admin" ,
  5.          "roles" : [
  6.                 {
  7.                          "role" : "root" ,
  8.                          "db" : "admin"
  9.                 }
  10.          ]
  11. }

user:用戶名

pwd:密碼

roles :指定用戶的角色,可以用一個空數(shù)組給新用戶設定空角色;在roles字段,可以指定內(nèi)置角色和用戶定義的角色。 role里的角色 可以選:

  1. Built - In Roles(內(nèi)置角色):
  2.     1 . 數(shù)據(jù)庫用戶角色:read、readWrite ;
  3.     2 . 數(shù)據(jù)庫管理角色:dbAdmin、dbOwner、userAdmin;
  4.     3 . 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
  5.     4 . 備份恢復角色:backup、restore;
  6.     5 . 所有數(shù)據(jù)庫角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
  7.     6 . 超級用戶角色:root
  8.     // 這里還有幾個角色間接或直接提供了系統(tǒng)超級用戶的訪問(dbOwner 、userAdmin、userAdminAnyDatabase)
  9.     7 . 內(nèi)部角色:__system

具體角色:
  1. Read:允許用戶讀取指定數(shù)據(jù)庫
  2. readWrite:允許用戶讀寫指定數(shù)據(jù)庫
  3. dbAdmin:允許用戶在指定數(shù)據(jù)庫中執(zhí)行管理函數(shù),如索引創(chuàng)建、刪除,查看統(tǒng)計或訪問system . profile
  4. userAdmin:允許用戶向system . users集合寫入,可以找指定數(shù)據(jù)庫里創(chuàng)建、刪除和管理用戶
  5. clusterAdmin:只在admin數(shù)據(jù)庫中可用,賦予用戶所有分片和復制集相關(guān)函數(shù)的管理權(quán)限。
  6. readAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的讀權(quán)限
  7. readWriteAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的讀寫權(quán)限
  8. userAdminAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的userAdmin權(quán)限
  9. dbAdminAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的dbAdmin權(quán)限。
  10. root:只在admin數(shù)據(jù)庫中可用。超級賬號,超級權(quán)限



2.開啟權(quán)限認證

  1. 配置文件添加
  2. [ dbaadmin@ ip - 172 - 31 - 36 - 77 ~ ] $ more /usr/ local / MongoDB/conf/mongod . conf
  3. auth = true


3.重啟后認證超級賬號

  1. [ root@iZ2ze66bhrbxkc31nljgjnZ mongodb ] # /usr/ local / mongodb/bin/mongo
  2. MongoDB shell version : 3 . . 6
  3. connecting to : test
  4. > show dbs ;    --沒權(quán)限查看
  5. 2018 - 05 - 07T14 : 29 : 25 . 847 + 0800 E QUERY    Error : listDatabases failed : {
  6.          "ok" : 0 ,
  7.          "errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }" ,
  8.          "code" : 13
  9. }
  10.     at Error ( < anonymous > )
  11.     at Mongo . getDBs ( src/mongo/shell/mongo . js : 47 : 15 )
  12.     at shellHelper . show ( src/mongo/shell/utils . js : 630 : 33 )
  13.     at shellHelper ( src/mongo/shell/utils . js : 524 : 36 )
  14.     at ( shellhelp2 ) : 1 : 1 at src/mongo/shell/mongo . js : 47
  15. > use admin ;
  16. switched to db admin
  17. > db . auth ( 'admin' , '123456' ) ; -admin下認證超級賬號, 數(shù)據(jù)庫帳號是跟著數(shù)據(jù)庫來走的,哪里創(chuàng)建哪里認證。
  18. 1
  19. > show dbs ;
  20. admin   0 . 078GB
  21. local 0 . 078GB
  22. rundb   0 . 078GB
  23. rundb2  0 . 078GB


4.添加普通賬號

  1. > use rundb2 ;
  2. switched to db rundb2
  3. > db . createUser ( { user : 'runuser2' , pwd : '123456' , roles : [ { role : "dbOwner" , db : " rundb2 " } ] } )
  4. Successfully added user : {
  5.          "user" : "runuser2" ,
  6.          "roles" : [
  7.                 {
  8.                          "role" : "dbOwner" ,
  9.                          "db" : "rundb2"
  10.                 }
  11.          ]
  12. }
  13. > show users ;   <1pre style="margin-top:0px;margin-bottom:0px;white-space:pre-wrap;text-align:justify;font-family:;" "=""> #查看當前庫下的用戶
  14. {
  15.          "_id" : "rundb2.runuser" ,
  16.          "user" : "runuser" ,
  17.          "db" : "rundb2" ,
  18.          "roles" : [
  19.                 {
  20.                          "role" : "readWrite" ,
  21.                          "db" : "rundb2"
  22.                 }
  23.          ]
  24. }
  25. {
  26.          "_id" : "rundb2.runuser2" ,
  27.          "user" : "runuser2" ,
  28.          "db" : "rundb2" ,
  29.          "roles" : [
  30.                 {
  31.                          "role" : "dbOwner" ,
  32.                          "db" : "rundb2"
  33.                 }
  34.          ]
  35. }



5.普通賬號認證

  1. 認證方式一
  2. [ root@iZ2ze66bhrbxkc31nljgjnZ mongodb ] # /usr/ local / mongodb/bin/mongo - u runuser - p 123456  rundb2
  3. MongoDB shell version : 3 . . 6
  4. connecting to : rundb2
  5. > show collections ;
  6. system . indexes
  7. testcoll
  8. testcoll2

 
  認證方式二
  1. [ root@iZ2ze66bhrbxkc31nljgjnZ mongodb ] # /usr/ local / mongodb/bin/mongo
  2. MongoDB shell version : 3 . . 6
  3. connecting to : test
  4. > use rundb2 ;
  5. switched to db rundb2
  6. > show dbs ;
  7. 2018 - 05 - 07T14 : 36 : 46 . 809 + 0800 E QUERY    Error : listDatabases failed : {
  8.          "ok" : 0 ,
  9.          "errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }" ,
  10.          "code" : 13
  11. }
  12.     at Error ( < anonymous > )
  13.     at Mongo . getDBs ( src/mongo/shell/mongo . js : 47 : 15 )
  14.     at shellHelper . show ( src/mongo/shell/utils . js : 630 : 33 )
  15.     at shellHelper ( src/mongo/shell/utils . js : 524 : 36 )
  16.     at ( shellhelp2 ) : 1 : 1 at src/mongo/shell/mongo . js : 47

  17. > db . auth ( 'runuser2' , '123456' )
  18. 1
  19. > show collections ;
  20. system . indexes
  21. testcoll
  22. testcoll2

5賬號管理

  1. 修改密碼
  2. MongoDB 修改帳號的密碼有兩種方式: 1 . 使用 changeUserPassword 方法 2 . 使用 updateUser 方法里面的 pwd 參數(shù)
  3. / / 驗證帳號密碼
  4. > db . auth ( "biadmin" , "biadmin" )
  5. 1
  6. //修改帳號密碼
  7. > db . changeUserPassword ( "biadmin" , "123" )
  8. //使用原密碼驗證失敗返回0
  9. > db . auth ( "biadmin" , "biadmin" )
  10. Error : Authentication failed .
  11. 0
  12. //使用修改后密碼驗證成功返回1
  13. > db . auth ( "biadmin" , "123" )
  14. 1
  15. //使用updateUser 修改密碼
  16. > db . updateUser (
  17.   "biadmin" ,
  18.   {pwd : "biadmin" } )
  19. //驗證密碼成功返回1
  20. > db . auth ( "biadmin" , "biadmin" )
  21. 1

  22. 刪除帳號
  23. MongoDB 刪除帳號有兩種方式: 
  24. 1 . 使用 dropUser ( "username" ) 刪除當前數(shù)據(jù)庫下指定帳號 
  25. 2 . 使用 dropAllUsers ( ) 刪除數(shù)據(jù)庫下所有帳號
  26. / / 已經(jīng)創(chuàng)建兩個測試帳號
  27. > db . getUser ( "test1" )
  28. {
  29.          "_id" : "bitest.test1" ,
  30.          "user" : "test1" ,
  31.          "db" : "bitest" ,
  32.          "roles" : [
  33.                 {
  34.                          "role" : "dbAdmin" ,
  35.                          "db" : "bitest"
  36.                 }
  37.          ]
  38. }
  39. > db . getUser ( "test2" )
  40. {
  41.          "_id" : "bitest.test2" ,
  42.          "user" : "test2" ,
  43.          "db" : "bitest" ,
  44.          "roles" : [
  45.                 {
  46.                          "role" : "dbAdmin" ,
  47.                          "db" : "bitest"
  48.                 }
  49.          ]
  50. }
  51. //使用dropUser刪除帳號test1成功返回true
  52. > db . dropUser ( "test1" )
  53. true
  54. //查詢帳號test1已不存在
  55. > db . getUser ( "test1" )
  56. null
  57. //使用dropAllUsers刪除所有帳號
  58. > db . dropAllUsers ( )
  59. 2
  60. //查詢帳號 test2,biadmin 都已不存在
  61. > db . getUser ( "test2" )
  62. null
  63. > db . getUser ( "biadmin" )
  64. null
  65. //查詢數(shù)據(jù)庫下所有帳號返回空數(shù)組
  66. > db . getUsers ( )
  67. [ ]

6 更改用戶信息

更改role,密碼都行
db.updateUser(
    "test",{
        roles:[ { role: "readWrite", db: "welike_mongo" } ],
        pwd:"123456"
    }
)

更多的操作查看參照文檔:
https://www.cnblogs.com/shiyiwen/p/5552750.html

https://www.cnblogs.com/damingge/p/6507605.html


網(wǎng)站名稱:【Mongo】mongodb的用戶認證
標題URL:http://weahome.cn/article/jjpgoj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部