MongoDB啟用身份驗(yàn)證

MongoDB支持各種認(rèn)證機(jī)制,以下啟用獨(dú)立 mongod 實(shí)例的訪問控制,并使用默認(rèn)身份驗(yàn)證機(jī)制。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括美蘭網(wǎng)站建設(shè)、美蘭網(wǎng)站制作、美蘭網(wǎng)頁(yè)制作以及美蘭網(wǎng)絡(luò)營(yíng)銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,美蘭網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到美蘭省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

用戶管理員
啟用訪問控制后,請(qǐng)確保在 admin 數(shù)據(jù)庫(kù)中擁有 userAdmin 或 userAdminAnyDatabase 角色的用戶。該用戶可以管理用戶和角色,例如:創(chuàng)建用戶,授予或撤銷用戶角色,以及創(chuàng)建或修改定義角色。 可以在啟用訪問控制之前或之后創(chuàng)建用戶。如果在創(chuàng)建任何用戶之前啟用訪問控制,MongoDB會(huì)提示本地主機(jī)異常,允許在管理數(shù)據(jù)庫(kù)中創(chuàng)建用戶管理員。創(chuàng)建后,必須作為用戶管理員進(jìn)行身份驗(yàn)證,以根據(jù)需要?jiǎng)?chuàng)建其他用戶。

以下過程首先將用戶管理員添加到運(yùn)行無(wú)訪問控制的 MongoDB 實(shí)例,然后啟用訪問控制。

  1. 創(chuàng)建用戶管理員
    在管理數(shù)據(jù)庫(kù)中,添加具有 userAdminAnyDatabase 角色的用戶。以下在 admin 數(shù)據(jù)庫(kù)中創(chuàng)建用戶justin:

注意:創(chuàng)建用戶的數(shù)據(jù)庫(kù)(在此示例中為admin)是用戶的身份驗(yàn)證數(shù)據(jù)庫(kù)。用戶將對(duì)該數(shù)據(jù)庫(kù)進(jìn)行身份驗(yàn)證,但用戶可以在其他數(shù)據(jù)庫(kù)中擔(dān)任角色; 即用戶的認(rèn)證數(shù)據(jù)庫(kù)不限制用戶的權(quán)限。

[root@localhost bin]# pwd
/opt/mongodb-3.4.6/bin
[root@localhost bin]# ./mongo --port 9981
MongoDB shell version v3.4.6
connecting to: mongodb://127.0.0.1:9981/
MongoDB server version: 3.4.6
Welcome to the MongoDB shell.
For interactive help, type "help".
For more comprehensive documentation, see
    http://docs.mongodb.org/
Questions? Try the support group
    http://groups.google.com/group/mongodb-user
Server has startup warnings: 
2017-12-20T00:45:44.490+0800 I CONTROL  [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
2017-12-20T00:45:44.490+0800 I CONTROL  [initandlisten] 
> use admin
switched to db admin
> db.createUser(               #回車
... {                                    #回車,下同
... user:"justin",
... pwd:"51cto",
... roles:[{role:"userAdminAnyDatabase",db:"admin"}]
... }
... )
Successfully added user: {
    "user" : "justin",
    "roles" : [
        {
            "role" : "userAdminAnyDatabase",
            "db" : "admin"
        }
    ]
}
> exit
bye
[root@localhost bin]# 

MongoDB啟用身份驗(yàn)證

  1. 修改mongodb配置文件,啟用認(rèn)證
    
    [root@localhost bin]# cat ../conf/mongodb.conf 
    bind_ip = 0.0.0.0
    port = 9981
    fork = true
    dbpath = /opt/mongodb-3.4.6/data
    pidfilepath = /var/run/mongod.pid
    logpath = /opt/mongodb-3.4.6/logs/mongod.log
    logappend = true
    auth = true
    [root@localhost bin]# systemctl restart mongodb.service
    [root@localhost bin]# 
3. 以用戶管理員身份進(jìn)行連接和驗(yàn)證
在連接期間進(jìn)行身份驗(yàn)證,使用-u <username>,-p <password>和--authenticationDatabase <database>
連接后驗(yàn)證,切換到身份驗(yàn)證數(shù)據(jù)庫(kù)(在這種情況下為admin),并使用db.auth(<username>,<pwd>)方法進(jìn)行身份驗(yàn)證

[root@localhost bin]# ./mongo --port 9981 -u "justin" -p "51cto" --authenticationDatabase "admin"
MongoDB shell version v3.4.6
connecting to: mongodb://127.0.0.1:9981/
MongoDB server version: 3.4.6

exit
bye
[root@localhost bin]# ./mongo --port 9981
MongoDB shell version v3.4.6
connecting to: mongodb://127.0.0.1:9981/
MongoDB server version: 3.4.6
use admin
switched to db admin
db.auth("justin","51cto")
1
exit
bye
[root@localhost bin]#


4. 根據(jù)需要?jiǎng)?chuàng)建其他用戶
當(dāng)管理員用戶進(jìn)行身份驗(yàn)證通過之后,可使用db.createUser()創(chuàng)建其他用戶??梢詾橛脩舴峙淙魏蝺?nèi)置角色或用戶定義的角色。

myUserAdmin用戶只具有管理用戶和角色的權(quán)限。如果使用myUserAdmin嘗試執(zhí)行任何其他操作,例如從ywbz數(shù)據(jù)庫(kù)中的foo集合讀取數(shù)據(jù),MongoDB將返回錯(cuò)誤。

以下操作將用戶 csdp添加到在ywbz數(shù)據(jù)庫(kù)中并給予ywbz數(shù)據(jù)庫(kù)的readWrite角色以及在reporting數(shù)據(jù)庫(kù)中讀取角色。

注意:創(chuàng)建用戶的數(shù)據(jù)庫(kù)(在本示例中為ywbz)是該用戶的身份驗(yàn)證數(shù)據(jù)庫(kù)。雖然用戶將對(duì)該數(shù)據(jù)庫(kù)進(jìn)行身份驗(yàn)證,但用戶可以在其他數(shù)據(jù)庫(kù)中擔(dān)任角色; 即用戶的認(rèn)證數(shù)據(jù)庫(kù)不會(huì)限制用戶的權(quán)限。

[root@localhost bin]# ./mongo --port 9981 -u "justin" -p "51cto" --authenticationDatabase "admin"
MongoDB shell version v3.4.6
connecting to: mongodb://127.0.0.1:9981/
MongoDB server version: 3.4.6
> use ywbz
switched to db ywbz
> db.createUser(
... {
... user:"csdp",
... pwd:"51cto",
... roles:[{role:"readWrite",db:"ywbz"},      #用戶csdp在數(shù)據(jù)庫(kù)ywbz中執(zhí)行讀寫操作權(quán)限
... {role:"read",db:"reporting"}]                 #用戶csdp在數(shù)據(jù)庫(kù)reporting中有讀操作權(quán)限
... }
... )
Successfully added user: {
    "user" : "csdp",
    "roles" : [
        {
            "role" : "readWrite",
            "db" : "ywbz"
        },
        {
            "role" : "read",
            "db" : "reporting"
        }
    ]
}
> exit
bye
[root@localhost bin]# 

MongoDB啟用身份驗(yàn)證

文章標(biāo)題:MongoDB啟用身份驗(yàn)證
分享URL:http://muchs.cn/article10/ppppgo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、企業(yè)網(wǎng)站制作網(wǎng)頁(yè)設(shè)計(jì)公司、響應(yīng)式網(wǎng)站、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)