2024-11-23Docker-MongoDB

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用户

一旦容器启动并初始化完成,你可以使用 mongoshmongo 命令验证管理员用户是否已创建。

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

8.注意事项

  1. 安全性:在生产环境中,请确保使用强密码,并考虑使用环境变量或配置文件来管理敏感信息。
  2. 版本兼容性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" })
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容