docker-compose安裝mongoDB全過程
拉取mongoDB鏡像
博主用的鏡像版本是5.0.10-focal
docker pull mongo:5.0.10-focal
啟動mongoDB容器
docker-compose安裝教程:
首先創(chuàng)建宿主機掛載目錄
#mongo數(shù)據(jù)目錄 mkdir /opt/dockerstore/mongo/data #mongo日志目錄 mkdir /opt/dockerstore/mongo/logs
然后新建docker-compose.yml文件
具體配置如下:
version: '3.1' services: mongodb: container_name: mongodb image: mongo:5.0.10-focal ports: - "27017:27017" restart: always command: - "--auth" environment: # MONGO_INITDB_ROOT_USERNAME: root # MONGO_INITDB_ROOT_PASSWORD: "x+s9zI&VA!s" wiredTigerCacheSizeGB: 2 volumes: - "/opt/dockerstore/mongo/data:/data/db" - "/opt/dockerstore/mongo/logs:/var/log/mongodb" - "/usr/share/zoneinfo/Asia/Shanghai:/etc/localtime" networks: docker: external: true
docker-compose啟動mongoDB
docker-compse up -d --build
創(chuàng)建用戶和庫
首先了解mongo角色權(quán)限
role | 作用 |
---|---|
read | 允許用戶讀取指定數(shù)據(jù)庫 |
readWrite | 允許用戶讀寫指定數(shù)據(jù)庫 |
dbAdmin | 允許用戶在指定數(shù)據(jù)庫中執(zhí)行管理函數(shù),如索引創(chuàng)建、刪除,查看統(tǒng)計或訪問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)限 |
注意:clusterAdmin、readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase、root角色只能用于admin數(shù)據(jù)庫
否則報以下錯誤(rad_app是非admin數(shù)據(jù)庫):
uncaught exception: Error: couldn’t add user: Could not find roles: userAdminAnyDatabase@rad_app, readWriteAnyDatabase@rad_app
執(zhí)行命令進(jìn)入mongo容器
docker exec -it mongodb /bin/bash
進(jìn)入容器后連接mongo客戶端
mongo admin
進(jìn)入客戶端后創(chuàng)建用戶
#使用rad_app庫,如果不存在會創(chuàng)建 use rad_app; #創(chuàng)建用戶并賦予角色權(quán)限 db.createUser({user:'rad_app_user',pwd:'123',roles:[{role:'userAdmin',db:'rad_app'},"readWrite"]});
至此,mongoDB安裝并配置完成
Navicat連接mongoDB
填寫連接主機和數(shù)據(jù)庫,輸入正確的用戶和密碼
點擊測試連接,彈窗“連接成功”后表示可正常使用
安裝遇到的問題
問題
因為啟動容器的時候加了–auth命令,如下
導(dǎo)致第一次創(chuàng)建用戶是沒有權(quán)限的,報以下錯誤:
uncaught exception: Error: couldn’t add user: not authorized on admin to execute command { createUser: “rad_app_user”, pwd: “xxx”, roles: [ { role: “userAdmin”, db: “rad_app” }, “readWrite” ], digestPassword: true, writeConcern: { w: “majority”, wtimeout: 600000.0 }, lsid: { id: UUID(“c87e48cc-9e2c-41e9-b03b-37455d751de8”) }, $db: “admin” } :
_getErrorWithCode@src/mongo/shell/utils.js:25:13
DB.prototype.createUser@src/mongo/shell/db.js:1367:11
解決方案
- 第一次啟動容器,配置文件去除–auth命令
- 執(zhí)行創(chuàng)建用戶命令,創(chuàng)建用戶和庫
- 修改配置文件,加上–auth命令
- 重新啟動容器,執(zhí)行授權(quán)命令后就可操作數(shù)據(jù)庫
db.auth('rad_app_user','123');
因為mongo的數(shù)據(jù)掛載到了宿主機,所以原來的創(chuàng)建的用戶數(shù)據(jù)并不會丟失
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
docker-compose快速搭建docker私有倉庫的步驟
這篇文章主要介紹了docker-compose快速搭建docker私有倉庫的步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12在docker環(huán)境中實現(xiàn)配置hosts
這篇文章主要介紹了在docker環(huán)境中實現(xiàn)配置hosts,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04Docker 使用nsenter工具進(jìn)入容器的操作
這篇文章主要介紹了Docker 使用nsenter工具進(jìn)入容器的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11docker-compose+nginx部署前后端分離的項目實踐
本文主要介紹了docker-compose?+?nginx部署前后端分離的項目,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03詳解ASP.NET Core 網(wǎng)站在Docker中運行
本篇文章主要介紹了詳解ASP.NET Core 網(wǎng)站在Docker中運行,非常具有實用價值,需要的朋友可以參考下2017-05-05docker離線部署docker,部署業(yè)務(wù)方式
這篇文章主要介紹了docker離線部署docker,部署業(yè)務(wù)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01