国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MongoDB > 正文

基于Docker的MongoDB實現授權訪問的方法

2024-09-07 00:22:39
字體:
來源:轉載
供稿:網友

基于Docker部署一個數據庫實例通常比直接在服務器上安裝數據庫還要簡單,Gevin在開發環境中經常使用基于docker的數據庫服務,docker也漸漸成為Gevin在Linux上安裝MongoDB的首選方式,由于MongoDB默認是不用通過認證就能直接連接的,出于安全考慮,在公網上部署MongoDB時,務必設置authentication機制,以避免類似 "黑客贖金" 問題的發生。

那么,基于Docker拉起的MongoDB,如何實現通過用戶名密碼訪問指定數據庫呢?方法很簡單,但前提是要了解MongoDB授權訪問的機制,參考資料如下:

Enable Auth
Authentication
Role-Based Access Control

只要了解MongoDB授權訪問機制,直接按下面步驟一步步執行就可以了。

1、創建MongoDB實例

為了少寫幾個命令,Gevin使用Docker Compose來創建MongoDB實例:

version: '2'services: mongo:  # restart: always  image: mongo:3.2  command: [--auth]  ports:   - "37017:27017"  volumes:   - /data/db

運行如下命令:

docker-compose up -d#----------# Result:#----------# Creating mongodb_mongo_1docker-compose ps#----------# Result:#----------#   Name        Command     State      Ports# --------------------------------------------------------------------------# mongodb_mongo_1  /entrypoint.sh --auth  Up   0.0.0.0:37017->27017/tcp

2、創建用戶管理員

首先要進入MongoDB容器內部,連上MongoDB,并切換到 admin 數據庫,這步可以通過下面命令完成:

docker exec -it mongodb_mongo_1 mongo admin#----------# Result:#----------# MongoDB shell version: 3.2.12# connecting to: admin# 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

然后創建一個user administrator:

db.createUser({   user: 'mongo-admin',   pwd: 'admin-initial-password',   roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] });#----------# Result:#----------Successfully added user: {  "user" : "mongo-admin",  "roles" : [    {      "role" : "userAdminAnyDatabase",      "db" : "admin"    }  ]}

3、創建訪問指定數據庫的用戶

創建了user administrator后,需要退出mongodb,并重新連接,然后用user administrator 訪問admin數據庫,并為目標數據庫創建目標用戶,其具體步驟如下:

(1)重新連接MongoDB數據庫

退出容器,重新用下面命令進入容器即可:

docker exec -it mongodb_mongo_1 mongo admin#----------# Result:#----------MongoDB shell version: 3.2.12connecting to: admin

(2)授權登錄admin

db.auth("mongo-admin","admin-initial-password")

(3)創建訪問指定數據庫的用戶

# Step1: switch to the specified database:use octblog# Step2: create a userdb.createUser( {  user: "gevin",  pwd: "gevin",  roles: [ { role: "readWrite", db: "octblog" },       { role: "readWrite", db: "octblog-log" } ] })#----------# Result:#----------#Successfully added user: {#  "user" : "gevin",#  "roles" : [#    {#      "role" : "readWrite",#      "db" : "octblog"#    },#    {#      "role" : "readWrite",#      "db" : "octblog-log"#    }#  ]#}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 醴陵市| 黔江区| 永嘉县| 绥德县| 临澧县| 视频| 朝阳市| 林甸县| 遵化市| 平安县| 淮北市| 锡林浩特市| 荣昌县| 巴彦县| 田东县| 伊通| 海口市| 绿春县| 琼结县| 九寨沟县| 福泉市| 治县。| 富源县| 齐河县| 阜城县| 大化| 荥经县| 巴林右旗| 安图县| 林州市| 惠州市| 绥江县| 谢通门县| 吴旗县| 和龙市| 禄劝| 腾冲县| 手游| 怀集县| 六枝特区| 两当县|