2024-11-23Docker-MongoDB

Docker-MongoDB

從docker出現(xiàn)到現(xiàn)在2024,服務(wù)的版本變化改動很大,今天在是使用的時候,結(jié)合以前和當前的版本進行整合

鳴謝:感謝每一位無私奉獻的傳道者,在此不一一具名!


1-學(xué)習(xí)目標

  • 1)安裝MongoDB
  • 2)創(chuàng)建admin賬戶和密碼
  • 3)進行數(shù)據(jù)庫的創(chuàng)建和查詢
  • 4)使用python連接MongoDB進行數(shù)據(jù)的寫入和查詢

2-參考網(wǎng)址

  • 個人嘗試代碼倉庫:XXXXXX
  • XXXXXX
  • XXXXXX

3-執(zhí)行過程梳理

1-安裝MongoDB

鏡像的下載需要魔法,在此省略鏡像下載過程


2-核心思路整理

MongoDB的安裝可能比其他數(shù)據(jù)庫麻煩一點

  • 1)啟動容器時-使用root賬密
  • 2)啟動容器后-進入容器-創(chuàng)建admin賬密
  • 3)啟動容器后-退出容器-驗證admin賬密

4-安裝過程記錄

以下是一個完整的腳本示例,用于從 Docker 鏡像安裝 MongoDB,并配置一個管理員用戶 (admin) 及相應(yīng)的密碼。這個腳本假設(shè)你已經(jīng)在本地安裝了 Docker,并且有權(quán)限執(zhí)行 Docker 命令。

1. 拉取 MongoDB 鏡像

首先,拉取最新的 MongoDB 鏡像:

docker pull mongo:latest

2. 啟動 MongoDB 容器

啟動 MongoDB 容器,并將管理員用戶的配置腳本掛載到容器中。我們將使用 docker-entrypoint-initdb.d 目錄來初始化數(shù)據(jù)庫。

docker run -d --name mongodb -p 27017:27017 \
  -e MONGO_INITDB_ROOT_USERNAME=root \
  -e MONGO_INITDB_ROOT_PASSWORD=root_password \
  mongo:latest

3.root用戶進入 MongoDB 容器并連接到 MongoDB

# root用戶進入 MongoDB
docker exec -it mongodb bash

# 連接到 MongoDB
mongosh -u root -p root_password --authenticationDatabase admin

4.創(chuàng)建新用戶

use admin
db.createUser({
  user: 'admin',
  pwd: 'admin123456',
  roles: [
    { role: "userAdminAnyDatabase", db: "admin" }
    { role: "readWriteAnyDatabase", db: "admin" },
    { role: "dbAdminAnyDatabase", db: "admin" },
    { role: "clusterAdmin", db: "admin" }
  ]
});

5.驗證用戶創(chuàng)建

db.getUsers();

6.退出mongosh連接

exit

7. 驗證admin用戶

一旦容器啟動并初始化完成,你可以使用 mongoshmongo 命令驗證管理員用戶是否已創(chuàng)建。

docker exec -it mongodb mongosh -u admin -p admin123456 --authenticationDatabase admin

8.注意事項

  1. 安全性:在生產(chǎn)環(huán)境中,請確保使用強密碼,并考慮使用環(huán)境變量或配置文件來管理敏感信息。
  2. 版本兼容性mongo 命令可能在較新的 MongoDB 版本中被棄用,建議使用 mongosh

通過以上步驟,你可以從 Docker 鏡像安裝 MongoDB,并配置一個具有管理員權(quán)限的用戶。


5-創(chuàng)建數(shù)據(jù)庫用戶和記錄

1. 進入容器

docker exec -it mongodb mongosh -u admin -p admin123456 --authenticationDatabase admin

2.創(chuàng)建 用戶、密碼和數(shù)據(jù)庫:

# 切換到指定數(shù)據(jù)庫(數(shù)據(jù)庫可以先不存在)
use mongo_new_db; 

# 為該數(shù)據(jù)庫創(chuàng)建指定的用戶和權(quán)限(當前創(chuàng)建了一個mongo_new_usr針對mongo_new_db數(shù)據(jù)庫有readWrite權(quán)限)
db.createUser({ user: 'mongo_new_usr', pwd: 'mongo_new_usr123456', roles: [ { role: "readWrite", db: "mongo_new_db" } ] });

3.測試mongo_new_usr權(quán)限

此時創(chuàng)建的用戶只有讀寫權(quán)限,不能使用命令進行登錄 docker exec -it mongodb mongosh -u mongo_new_usr -p mongo_new_usr123456

# 切換到指定數(shù)據(jù)庫
use mongo_new_db;

# 校驗有沒有權(quán)限(有權(quán)限返回OK)
db.auth("mongo_new_usr","mongo_new_usr123456");

4.數(shù)據(jù)庫增刪改查

# 1-創(chuàng)建對應(yīng)的表
db.createCollection("mongo_new_table");

# 2-查看有哪些表
show collections;

# 3-在表中進行數(shù)據(jù)寫入
db.mongo_new_table.insertOne({"name" : "popyu"})

# 4-在表中進行數(shù)據(jù)查看
db.mongo_new_table.find({ name: "popyu" })

# 5-在表中進行數(shù)據(jù)修改-并新增屬性
db.mongo_new_table.updateOne(
  { name: "popyu" }, { $set: { age: 31 } }
);

# 6-在表中進行數(shù)據(jù)刪除
db.mongo_new_table.deleteOne({ name: "popyu" });

# 7-在表中驗證數(shù)據(jù)刪除
db.mongo_new_table.find({ name: "popyu" })
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容