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用戶
一旦容器啟動并初始化完成,你可以使用 mongosh 或 mongo 命令驗證管理員用戶是否已創(chuàng)建。
docker exec -it mongodb mongosh -u admin -p admin123456 --authenticationDatabase admin
8.注意事項
- 安全性:在生產(chǎn)環(huán)境中,請確保使用強密碼,并考慮使用環(huán)境變量或配置文件來管理敏感信息。
-
版本兼容性:
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" })
