Mongo內(nèi)置角色解讀

Built-In Roles(內(nèi)置角色)

1. 數(shù)據(jù)庫用戶角色:read、readWrite;

2. 數(shù)據(jù)庫管理角色:dbAdmin、dbOwner、userAdmin;

3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;

4. 備份恢復(fù)角色:backup、restore;

5. 所有數(shù)據(jù)庫角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase

6. 超級用戶角色:root

// 這里還有幾個(gè)角色間接或直接提供了系統(tǒng)超級用戶的訪問(dbOwner 、userAdmin、userAdminAnyDatabase)

7. 內(nèi)部角色:__system

具體角色

Read:允許用戶讀取指定數(shù)據(jù)庫

readWrite:允許用戶讀寫指定數(shù)據(jù)庫

dbAdmin:允許用戶在指定數(shù)據(jù)庫中執(zhí)行管理函數(shù),如索引創(chuàng)建、刪除,查看統(tǒng)計(jì)或訪問system.profile

userAdmin:允許用戶向system.users集合寫入,可以找指定數(shù)據(jù)庫里創(chuàng)建、刪除和管理用戶

clusterAdmin:只在admin數(shù)據(jù)庫中可用,賦予用戶所有分片和復(fù)制集相關(guān)函數(shù)的管理權(quán)限。

readAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的讀權(quán)限

readWriteAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的讀寫權(quán)限

userAdminAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的userAdmin權(quán)限

dbAdminAnyDatabase:只在admin數(shù)據(jù)庫中可用,賦予用戶所有數(shù)據(jù)庫的dbAdmin權(quán)限。

root:只在admin數(shù)據(jù)庫中可用。超級賬號,超級權(quán)限

參考:https://docs.mongodb.com/manual/reference/built-in-roles/#built-in-roles

例:

root@zhoujinyi:/usr/local/mongo4# mongo --port=27020

MongoDB shell version: 3.0.4

connecting to: 127.0.0.1:27020/

test> show dbs;? ? ####沒有驗(yàn)證,導(dǎo)致沒權(quán)限。

2015-06-29T10:02:16.634-0400 E QUERY? ? Error: listDatabases failed:

{? ??

"ok" : 0,? ?

?"errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }",? ?

?"code" : 13

}? ??

at Error ()

at Mongo.getDBs (src/mongo/shell/mongo.js:47:15)

at shellHelper.show (src/mongo/shell/utils.js:630:33)

at shellHelper (src/mongo/shell/utils.js:524:36)

at (shellhelp2):1:1 at src/mongo/shell/mongo.js:47

> use admin? ? ? ? #驗(yàn)證,因?yàn)樵赼dmin下面添加的帳號,所以要到admin下面驗(yàn)證。

switched to db admin

> db.auth('dba','dba')

> show dbs;

admin? 0.078GB

local? 0.078GB

> use test? ? ? ? #在test庫里創(chuàng)建帳號

switched to db test

> db.createUser(

...? ? {

...? ? ? user: "zjyr",

...? ? ? pwd: "zjyr",

...? ? ? roles: [

...? ? ? ? ? { role: "read", db: "test" }? ? #只讀帳號

...? ? ? ]

...? ? }

... )

Successfully added user: {

"user" : "zjyr",

"roles" : [

{

"role" : "read",

"db" : "test"

}

]

}

> db.createUser(

...? ? {

...? ? ? user: "zjy",

...? ? ? pwd: "zjy",

...? ? ? roles: [

...? ? ? ? ? { role: "readWrite", db: "test" }? #讀寫帳號

...? ? ? ]

...? ? }

... )

Successfully added user: {

"user" : "zjy",

"roles" : [

{

"role" : "readWrite",? ? ? ? ? ? ? ? #讀寫賬號

"db" : "test"

}

]

}

> show users;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #查看當(dāng)前庫下的用戶

{

"_id" : "test.zjyr",

"user" : "zjyr",

"db" : "test",

"roles" : [

{

"role" : "read",

"db" : "test"

}

]

}

{

"_id" : "test.zjy",

"user" : "zjy",

"db" : "test",

"roles" : [

{

"role" : "readWrite",

"db" : "test"

}

]

}

驗(yàn)證:

> db.abc.insert({"a":1,"b":2})? ? ? ? ? ? ? #插入失敗,沒有權(quán)限,userAdminAnyDatabase 權(quán)限只是針對用戶管理的,對其他是沒有權(quán)限的。

WriteResult({

"writeError" : {

"code" : 13,

"errmsg" : "not authorized on test to execute command { insert: \"abc\", documents: [ { _id: ObjectId('55915185d629831d887ce2cb'), a: 1.0, b: 2.0 } ], ordered: true }"

}

})

>

bye

root@zhoujinyi:/usr/local/mongo4# mongo --port=27020

MongoDB shell version: 3.0.4

connecting to: 127.0.0.1:27020/test

> use test

switched to db test

> db.auth('zjy','zjy')? ? ? #用創(chuàng)建的readWrite帳號進(jìn)行寫入

> db.abc.insert({"a":1,"b":2})

WriteResult({ "nInserted" : 1 })

> db.abc.insert({"a":11,"b":22})

WriteResult({ "nInserted" : 1 })

> db.abc.insert({"a":111,"b":222})

WriteResult({ "nInserted" : 1 })

> db.abc.find()

{ "_id" : ObjectId("559151a1b78649ebd8316853"), "a" : 1, "b" : 2 }

{ "_id" : ObjectId("559151cab78649ebd8316854"), "a" : 11, "b" : 22 }

{ "_id" : ObjectId("559151ceb78649ebd8316855"), "a" : 111, "b" : 222 }

> db.auth('zjyr','zjyr')? ? ? #切換到只有read權(quán)限的帳號

> db.abc.insert({"a":1111,"b":2222})? #不能寫入

WriteResult({

"writeError" : {

"code" : 13,

"errmsg" : "not authorized on test to execute command { insert: \"abc\", documents: [ { _id: ObjectId('559151ebb78649ebd8316856'), a: 1111.0, b: 2222.0 } ], ordered: true }"

}

})

> db.abc.find()? ? ? ? #可以查看

{ "_id" : ObjectId("559151a1b78649ebd8316853"), "a" : 1, "b" : 2 }

{ "_id" : ObjectId("559151cab78649ebd8316854"), "a" : 11, "b" : 22 }

{ "_id" : ObjectId("559151ceb78649ebd8316855"), "a" : 111, "b" : 222 }

有沒有一個(gè)超級權(quán)限?不僅可以授權(quán),而且也可以對集合進(jìn)行任意操作?答案是肯定的,只是不建議使用。那就是role角色設(shè)置成root

> db.auth('dba','dba')

> db.createUser(

...? {

...? ? user: "zhoujinyi",

...? ? pwd: "zhoujinyi",

...? ? roles: [

...? ? ? { role: "root", db: "admin" }? ? ? #超級root帳號

...? ? ]

...? }

... )

Successfully added user: {

"user" : "zhoujinyi",

"roles" : [

{

"role" : "root",

"db" : "admin"

}

]

}

>

> show users;? ? ? ? ? ? ? #查看當(dāng)前庫下的用戶

{

"_id" : "admin.dba",

"user" : "dba",

"db" : "admin",

"roles" : [

{

"role" : "userAdminAnyDatabase",

"db" : "admin"

}

]

}

{

"_id" : "admin.zhoujinyi",

"user" : "zhoujinyi",

"db" : "admin",

"roles" : [

{

"role" : "root",

"db" : "admin"

}

]

}

> use admin

switched to db admin

> db.auth('zhoujinyi','zhoujinyi')

> use test

switched to db test

> db.abc.insert({"a":1,"b":2})

WriteResult({ "nInserted" : 1 })

> db.abc.insert({"a":1111,"b":2222})? ? ? ? ? #權(quán)限都有

WriteResult({ "nInserted" : 1 })

> db.abc.find()

{ "_id" : ObjectId("5591539bb78649ebd8316857"), "a" : 1, "b" : 2 }

{ "_id" : ObjectId("559153a0b78649ebd8316858"), "a" : 1111, "b" : 2222 }

> db.abc.remove({})

WriteResult({ "nRemoved" : 2 })

因?yàn)閹ぬ柖际窃诋?dāng)前需要授權(quán)的數(shù)據(jù)庫下授權(quán)的,那要是不在當(dāng)前數(shù)據(jù)庫下會怎么樣?

> db

admin

> db.createUser(

...? {

...? ? user: "dxy",

...? ? pwd: "dxy",

...? ? roles: [

...? ? ? { role: "readWrite", db: "test" },? ? #在當(dāng)前庫下創(chuàng)建其他庫的帳號,在admin庫下創(chuàng)建test、abc庫的帳號

...? ? ? { role: "readWrite", db: "abc" }

...? ? ]

...? }

... )

Successfully added user: {

"user" : "dxy",

"roles" : [

{

"role" : "readWrite",

"db" : "test"

},

{

"role" : "readWrite",

"db" : "abc"

}

]

}

>

> show users;

{

"_id" : "admin.dba",

"user" : "dba",

"db" : "admin",

"roles" : [

{

"role" : "userAdminAnyDatabase",

"db" : "admin"

}

]

}

{

"_id" : "admin.zhoujinyi",

"user" : "zhoujinyi",

"db" : "admin",

"roles" : [

{

"role" : "root",

"db" : "admin"

}

]

}

{

"_id" : "admin.dxy",

"user" : "dxy",

"db" : "admin",

"roles" : [

{

"role" : "readWrite",

"db" : "test"

},

{

"role" : "readWrite",

"db" : "abc"

}

]

}

> use test

switched to db test

> db.auth('dxy','dxy')? ? ? ? ? #在admin下創(chuàng)建的帳號,不能直接在其他庫驗(yàn)證,

Error: 18 Authentication failed.

> use admin

switched to db admin? ? ? ? ? ? #只能在帳號創(chuàng)建庫下認(rèn)證,再去其他庫進(jìn)行操作。

> db.auth('dxy','dxy')

> use test

switched to db test

> db.abc.insert({"a":1111,"b":2222})

WriteResult({ "nInserted" : 1 })

> use abc

switched to db abc

> db.abc.insert({"a":1111,"b":2222})

WriteResult({ "nInserted" : 1 })

上面更加進(jìn)一步說明數(shù)據(jù)庫帳號是跟著數(shù)據(jù)庫來走的,哪里創(chuàng)建哪里認(rèn)證。

創(chuàng)建了這么多帳號,怎么查看所有帳號

>? use admin

switched to db admin

> db.auth('dba','dba')

> db.system.users.find().pretty()

{

"_id" : "admin.dba",

"user" : "dba",

"db" : "admin",

"credentials" : {

"SCRAM-SHA-1" : {

"iterationCount" : 10000,

"salt" : "KfDUzCOIUo7WVjFr64ZOcQ==",

"storedKey" : "t4sPsKG2dXnZztVYj5EgdUzT9sc=",

"serverKey" : "2vCGiq9NIc1zKqeEL6VvO4rP26A="

}

},

"roles" : [

{

"role" : "userAdminAnyDatabase",

"db" : "admin"

}

]

}

{

"_id" : "test.zjyr",

"user" : "zjyr",

"db" : "test",

"credentials" : {

"SCRAM-SHA-1" : {

"iterationCount" : 10000,

"salt" : "h1gOW3J7wzJuTqgmmQgJKQ==",

"storedKey" : "7lkoANdxM2py0qiDBzFaZYPp1cM=",

"serverKey" : "Qyu6IRNyaKLUvqJ2CAa/tQYY36c="

}

},

"roles" : [

{

"role" : "read",

"db" : "test"

}

]

}

{

"_id" : "test.zjy",

"user" : "zjy",

"db" : "test",

"credentials" : {

"SCRAM-SHA-1" : {

"iterationCount" : 10000,

"salt" : "afwaKuTYPWwbDBduQ4Hm7g==",

"storedKey" : "ebb2LYLn4hiOVlZqgrAKBdStfn8=",

"serverKey" : "LG2qWwuuV+FNMmr9lWs+Rb3DIhQ="

}

},

"roles" : [

{

"role" : "readWrite",

"db" : "test"

}

]

}

{

"_id" : "admin.zhoujinyi",

"user" : "zhoujinyi",

"db" : "admin",

"credentials" : {

"SCRAM-SHA-1" : {

"iterationCount" : 10000,

"salt" : "pE2cSOYtBOYevk8tqrwbSQ==",

"storedKey" : "TwMxdnlB5Eiaqg4tNh9ByNuUp9A=",

"serverKey" : "Mofr9ohVlFfR6/md4LMRkOhXouc="

}

},

"roles" : [

{

"role" : "root",

"db" : "admin"

}

]

}

{

"_id" : "admin.dxy",

"user" : "dxy",

"db" : "admin",

"credentials" : {

"SCRAM-SHA-1" : {

"iterationCount" : 10000,

"salt" : "XD6smcWX4tdg/ZJPoLxxRg==",

"storedKey" : "F4uiayykHDp/r9krAKZjdr+gqjM=",

"serverKey" : "Kf51IU9J3RIrB8CFn5Z5hEKMSkw="

}

},

"roles" : [

{

"role" : "readWrite",

"db" : "test"

},

{

"role" : "readWrite",

"db" : "abc"

}

]

}

> db.system.users.find().count()

備份還原使用那個(gè)角色的帳號?之前創(chuàng)建的帳號zjy:test庫讀寫權(quán)限;zjyr:test庫讀權(quán)限

root@zhoujinyi:~# mongodump --port=27020 -uzjyr -pzjyr --db=test -o backup? #只要讀權(quán)限就可以備份

2015-06-29T11:20:04.864-0400? ? writing test.abc to backup/test/abc.bson

2015-06-29T11:20:04.865-0400? ? writing test.abc metadata to backup/test/abc.metadata.json

2015-06-29T11:20:04.866-0400? ? done dumping test.abc

2015-06-29T11:20:04.867-0400? ? writing test.system.indexes to backup/test/system.indexes.bson

root@zhoujinyi:~# mongorestore --port=27020 -uzjy -pzjy --db=test backup/test/? #讀寫權(quán)限可以進(jìn)行還原

2015-06-29T11:20:26.607-0400? ? building a list of collections to restore from backup/test/ dir

2015-06-29T11:20:26.609-0400? ? reading metadata file from backup/test/abc.metadata.json

2015-06-29T11:20:26.609-0400? ? restoring test.abc from file backup/test/abc.bson

2015-06-29T11:20:26.611-0400? ? error: E11000 duplicate key error index: test.abc.$_id_ dup key: { : ObjectId('559154efb78649ebd831685a') }

2015-06-29T11:20:26.611-0400? ? restoring indexes for collection test.abc from metadata

2015-06-29T11:20:26.612-0400? ? finished restoring test.abc

2015-06-29T11:20:26.612-0400? ? done

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,732評論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,214評論 3 426
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,781評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,588評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,315評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,699評論 1 327
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,698評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,882評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,441評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,189評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,388評論 1 372
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,933評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,613評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,023評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,310評論 1 293
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,112評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,334評論 2 377

推薦閱讀更多精彩內(nèi)容