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

首頁 > 網站 > 建站經驗 > 正文

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

2019-11-02 16:06:00
字體:
來源:轉載
供稿:網友

基于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"#    }#  ]#}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 和顺县| 郁南县| 温泉县| 桦川县| 民权县| 镇安县| 大冶市| 牡丹江市| 五常市| 壤塘县| 格尔木市| 昔阳县| 乌鲁木齐县| 济南市| 卢氏县| 晋江市| 平远县| 杭锦旗| 巴林右旗| 山阳县| 康平县| 江津市| 北安市| 珠海市| 前郭尔| 邵阳县| 绥江县| 白河县| 当阳市| 吉安县| 平邑县| 井冈山市| 灌南县| 互助| 遵义县| 大同市| 阳信县| 荔波县| 融水| 宝兴县| 德钦县|