MongoDB啟用身份驗證

MongoDB支持各種認證機制,以下啟用獨立 mongod 實例的訪問控制,并使用默認身份驗證機制。

創新互聯服務項目包括美蘭網站建設、美蘭網站制作、美蘭網頁制作以及美蘭網絡營銷策劃等。多年來,我們專注于互聯網行業,利用自身積累的技術優勢、行業經驗、深度合作伙伴關系等,向廣大中小型企業、政府機構等提供互聯網行業的解決方案,美蘭網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到美蘭省份的部分城市,未來相信會繼續擴大服務區域并繼續獲得客戶的支持與信任!

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

以下過程首先將用戶管理員添加到運行無訪問控制的 MongoDB 實例,然后啟用訪問控制。

  1. 創建用戶管理員
    在管理數據庫中,添加具有 userAdminAnyDatabase 角色的用戶。以下在 admin 數據庫中創建用戶justin:

注意:創建用戶的數據庫(在此示例中為admin)是用戶的身份驗證數據庫。用戶將對該數據庫進行身份驗證,但用戶可以在其他數據庫中擔任角色; 即用戶的認證數據庫不限制用戶的權限。

[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啟用身份驗證

  1. 修改mongodb配置文件,啟用認證
    
    [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. 以用戶管理員身份進行連接和驗證
在連接期間進行身份驗證,使用-u <username>,-p <password>和--authenticationDatabase <database>
連接后驗證,切換到身份驗證數據庫(在這種情況下為admin),并使用db.auth(<username>,<pwd>)方法進行身份驗證

[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. 根據需要創建其他用戶
當管理員用戶進行身份驗證通過之后,可使用db.createUser()創建其他用戶。可以為用戶分配任何內置角色或用戶定義的角色。

myUserAdmin用戶只具有管理用戶和角色的權限。如果使用myUserAdmin嘗試執行任何其他操作,例如從ywbz數據庫中的foo集合讀取數據,MongoDB將返回錯誤。

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

注意:創建用戶的數據庫(在本示例中為ywbz)是該用戶的身份驗證數據庫。雖然用戶將對該數據庫進行身份驗證,但用戶可以在其他數據庫中擔任角色; 即用戶的認證數據庫不會限制用戶的權限。

[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在數據庫ywbz中執行讀寫操作權限
... {role:"read",db:"reporting"}]                 #用戶csdp在數據庫reporting中有讀操作權限
... }
... )
Successfully added user: {
    "user" : "csdp",
    "roles" : [
        {
            "role" : "readWrite",
            "db" : "ywbz"
        },
        {
            "role" : "read",
            "db" : "reporting"
        }
    ]
}
> exit
bye
[root@localhost bin]# 

MongoDB啟用身份驗證

文章標題:MongoDB啟用身份驗證
分享URL:http://m.kartarina.com/article10/ppppgo.html

成都網站建設公司_創新互聯,為您提供外貿網站建設網站建設企業網站制作網頁設計公司響應式網站軟件開發

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

商城網站建設
主站蜘蛛池模板: a级毛片无码免费真人久久| 亚洲一区无码中文字幕乱码| 国产V片在线播放免费无码 | 日韩毛片无码永久免费看| 无码少妇一区二区浪潮免费| 最新国产精品无码| 亚洲AV色吊丝无码| 国产成人无码一区二区三区在线| 亚洲av无码专区在线电影| 亚洲精品无码久久千人斩| 无码日韩AV一区二区三区| 亚洲av午夜精品无码专区 | 无码人妻黑人中文字幕| 午夜无码视频一区二区三区 | 亚洲国产精品无码中文lv| 亚洲日韩激情无码一区| 无码激情做a爰片毛片AV片| 91精品国产综合久久四虎久久无码一级| 四虎成人精品国产永久免费无码 | 免费A级毛片无码久久版| 久久久久久久人妻无码中文字幕爆 | 亚洲熟妇无码八AV在线播放| 国产乱人伦中文无无码视频试看 | 精品无码国产污污污免费网站国产| 久久午夜福利无码1000合集| 亚洲精品无码永久中文字幕| 亚洲高清无码综合性爱视频| 国产精品无码久久久久久久久久| 亚洲熟妇无码爱v在线观看| 久久老子午夜精品无码怎么打| 中文字幕人妻无码一夲道| 无码欧精品亚洲日韩一区夜夜嗨| 无码人妻精品一区二区三区不卡 | 精品无码久久久久久尤物| 亚洲精品无码久久一线| 无码人妻一区二区三区免费n鬼沢 无码人妻一区二区三区免费看 | 日韩精品久久无码中文字幕| 无码成A毛片免费| 日韩亚洲AV无码一区二区不卡| 久久久久久久无码高潮| 少妇无码一区二区二三区|