Docker-MongoDB
从docker出现到现在2024,服务的版本变化改动很大,今天在是使用的时候,结合以前和当前的版本进行整合
鸣谢:感谢每一位无私奉献的传道者,在此不一一具名!
1-学习目标
- 1)安装MongoDB
- 2)创建admin账户和密码
- 3)进行数据库的创建和查询
- 4)使用python连接MongoDB进行数据的写入和查询
2-参考网址
- 个人尝试代码仓库:XXXXXX
- XXXXXX
- XXXXXX
3-执行过程梳理
1-安装MongoDB
镜像的下载需要魔法,在此省略镜像下载过程
2-核心思路整理
MongoDB的安装可能比其他数据库麻烦一点
- 1)启动容器时-使用root账密
- 2)启动容器后-进入容器-创建admin账密
- 3)启动容器后-退出容器-验证admin账密
4-安装过程记录
以下是一个完整的脚本示例,用于从 Docker 镜像安装 MongoDB,并配置一个管理员用户 (admin
) 及相应的密码。这个脚本假设你已经在本地安装了 Docker,并且有权限执行 Docker 命令。
1. 拉取 MongoDB 镜像
首先,拉取最新的 MongoDB 镜像:
docker pull mongo:latest
2. 启动 MongoDB 容器
启动 MongoDB 容器,并将管理员用户的配置脚本挂载到容器中。我们将使用 docker-entrypoint-initdb.d
目录来初始化数据库。
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.创建新用户
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.验证用户创建
db.getUsers();
6.退出mongosh连接
exit
7. 验证admin用户
一旦容器启动并初始化完成,你可以使用 mongosh
或 mongo
命令验证管理员用户是否已创建。
docker exec -it mongodb mongosh -u admin -p admin123456 --authenticationDatabase admin
8.注意事项
- 安全性:在生产环境中,请确保使用强密码,并考虑使用环境变量或配置文件来管理敏感信息。
-
版本兼容性:
mongo
命令可能在较新的 MongoDB 版本中被弃用,建议使用mongosh
通过以上步骤,你可以从 Docker 镜像安装 MongoDB,并配置一个具有管理员权限的用户。
5-创建数据库用户和记录
1. 进入容器
docker exec -it mongodb mongosh -u admin -p admin123456 --authenticationDatabase admin
2.创建 用户、密码和数据库:
# 切换到指定数据库(数据库可以先不存在)
use mongo_new_db;
# 为该数据库创建指定的用户和权限(当前创建了一个mongo_new_usr针对mongo_new_db数据库有readWrite权限)
db.createUser({ user: 'mongo_new_usr', pwd: 'mongo_new_usr123456', roles: [ { role: "readWrite", db: "mongo_new_db" } ] });
3.测试mongo_new_usr权限
此时创建的用户只有读写权限,不能使用命令进行登录 docker exec -it mongodb mongosh -u mongo_new_usr -p mongo_new_usr123456
# 切换到指定数据库
use mongo_new_db;
# 校验有没有权限(有权限返回OK)
db.auth("mongo_new_usr","mongo_new_usr123456");
4.数据库增删改查
# 1-创建对应的表
db.createCollection("mongo_new_table");
# 2-查看有哪些表
show collections;
# 3-在表中进行数据写入
db.mongo_new_table.insertOne({"name" : "popyu"})
# 4-在表中进行数据查看
db.mongo_new_table.find({ name: "popyu" })
# 5-在表中进行数据修改-并新增属性
db.mongo_new_table.updateOne(
{ name: "popyu" }, { $set: { age: 31 } }
);
# 6-在表中进行数据删除
db.mongo_new_table.deleteOne({ name: "popyu" });
# 7-在表中验证数据删除
db.mongo_new_table.find({ name: "popyu" })