使用 Docker(Podman) 部署 MongoDB 数据库及使用详解

打印 上一主题 下一主题

主题 987|帖子 987|积分 2961

在现代开辟环境中,容器化技能(如 Docker 和 Podman)已成为部署和管理应用程序的标准方式。本文将详细介绍怎样使用 Podman/Docker 部署 MongoDB 数据库,并确保其他应用程序容器能够通过 Docker 网络乐成连接到 MongoDB。我们将逐步办理常见的题目,如权限设置和认证设置,应用容器怎样连接和使用容器中的MongoDB 数据库等。
  选择 Podman 而不是 Docker

为什么选择 Podman?


  • 无守护历程:Podman 不须要守护历程(daemon)即可运行容器,这使得它更安全和易于管理。
  • 根权限不是必须:Podman 允许非特权用户运行容器,而 Docker 须要 root 权限或通过 docker 组来管理容器。
  • 兼容性:Podman 可以与 Docker 镜像和容器无缝兼容,这意味着你可以使用现有的 Dockerfile 和设置文件。
  • 资源服从:Podman 更加轻量级,对资源的需求较低,恰当在资源受限的环境中运行。
1. 安装 Podman

起首,确保你已经安装了 Podman。如果尚未安装,可以按照以下步调进行安装:
在 Ubuntu 上安装 Podman


  • 更新包列表
    1. sudo apt-get update
    复制代码
  • 安装 Podman
    1. sudo apt-get install -y podman
    复制代码
  • 验证安装
    1. podman run hello-world
    复制代码
    这将检验 Podman 是否安装乐成。
2. 创建并运行 MongoDB 容器

2.1 创建目次并调整权限

确保数据目次和日记目次存在并且权限精确。MongoDB 容器内的 mongodb 用户(UID 999 和 GID 999)须要对这些目次有读写权限。
  1. mkdir -p ~/mongodb/data
  2. mkdir -p ~/mongodb/logs
  3. sudo chown -R 999:999 ~/mongodb/data
  4. sudo chown -R 999:999 ~/mongodb/logs
复制代码
2.2 创建立置文件 mongod.conf

创建一个 MongoDB 设置文件 mongod.conf,内容如下:
  1. systemLog:
  2.   destination: file
  3.   path: "/var/log/mongodb/mongod.log"
  4.   logAppend: true
  5. storage:
  6.   dbPath: "/data/db"
  7. net:
  8.   bindIp: "0.0.0.0"
  9.   port: 27017
  10. security:
  11.   authorization: "disabled"
复制代码
2.3 创建自定义 Docker 网络

创建一个自定义的 Docker 网络,以便其他容器可以连接到 MongoDB 容器。
  1. podman network create dco-net
复制代码
2.4 运行 MongoDB 容器

使用以下下令运行 MongoDB 容器,并确保设置文件精确挂载:
  1. podman run -d \
  2.   --name mongodb \
  3.   -v ~/mongodb/data:/data/db \
  4.   -v ~/mongodb/logs:/var/log/mongodb \
  5.   -v ~/mongodb/mongod.conf:/etc/mongod.conf \
  6.   --network dco-net \
  7.   docker.io/library/mongo:latest \
  8.   -f /etc/mongod.conf
复制代码


  • -d:后台运行容器。
  • -v ~/mongodb/data:/data/db:将主机上的数据目次挂载到容器内的 /data/db 目次,实现数据长期化。
  • -v ~/mongodb/logs:/var/log/mongodb:将主机上的日记目次挂载到容器内的 /var/log/mongodb 目次,实现日记长期化。
  • -v ~/mongodb/mongod.conf:/etc/mongod.conf:将主机上的设置文件挂载到容器内的 /etc/mongod.conf 目次,确保 MongoDB 使用指定的设置文件。
  • --network dco-net:将容器连接到自定义的 dco-net 网络。
  • --name mongodb:为容器指定名称。
  • docker.io/library/mongo:latest:使用的 Docker 镜像名称,从官方 Docker Hub 拉取。
  • -f /etc/mongod.conf:指定使用 /etc/mongod.conf 设置文件。
3. 创建 MongoDB 用户和权限

3.1 进入 MongoDB 容器并启动 MongoDB Shell

  1. podman exec -it mongodb /bin/bash
  2. mongo
复制代码
3.2 创建 admin 用户和权限

在 MongoDB Shell 中,创建 admin 数据库的用户并分配权限。比方:
  1. use admin
  2. db.createUser({
  3.   user: "admin",
  4.   pwd: "admin123",
  5.   roles: [{ role: "root", db: "admin" }]
  6. })
  7. exit
  8. exit
复制代码
3.3 创建 atomdco 用户和权限

在 MongoDB Shell 中,创建 atomdco 数据库的用户并分配权限。比方:
  1. podman exec -it mongodb /bin/bash
  2. mongo
  3. -u admin -p admin123 --authenticationDatabase adminuse atomdcodb.createUser({  user: "test1",  pwd: "111111",  roles: [{ role: "readWrite", db: "atomdco" }]})exitexit
复制代码
4. 启用 MongoDB 认证

4.1 停止并删除 MongoDB 容器

起首,停止并删除现有的 MongoDB 容器,以确保新的容器能够精确加载设置文件。
  1. podman stop mongodb
  2. podman rm mongodb
复制代码
4.2 修改设置文件 mongod.conf 以启用认证

编辑 mongod.conf 文件,启用 authorization:
  1. systemLog:
  2.   destination: file
  3.   path: "/var/log/mongodb/mongod.log"
  4.   logAppend: true
  5. storage:
  6.   dbPath: "/data/db"
  7. net:
  8.   bindIp: "0.0.0.0"
  9.   port: 27017
  10. security:
  11.   authorization: "enabled"
复制代码
4.3 重新运行 MongoDB 容器

使用修改后的设置文件重新运行 MongoDB 容器:
  1. podman run -d \
  2.   --name mongodb \
  3.   -v ~/mongodb/data:/data/db \
  4.   -v ~/mongodb/logs:/var/log/mongodb \
  5.   -v ~/mongodb/mongod.conf:/etc/mongod.conf \
  6.   --network dco-net \
  7.   docker.io/library/mongo:latest \
  8.   -f /etc/mongod.conf
复制代码
5. 验证 MongoDB 容器是否精确运行

5.1 查看容器状态

  1. podman ps -a
复制代码
你应该能看到类似以下的输出:
  1. CONTAINER ID  IMAGE                           COMMAND     CREATED        STATUS        PORTS       NAMES
  2. cd25ac473660  docker.io/library/mongo:latest  mongod      6 minutes ago  Up 6 minutes              mongodb
复制代码
5.2 查看日记文件

确保 MongoDB 容器精确加载了设置文件并启动了日记记录。
  1. podman logs mongodb
复制代码
大概实时查看日记文件:
  1. podman logs -f mongodb
复制代码
你应该能看到类似以下的日记信息,确认 MongoDB 精确加载了设置文件并监听了所有网络接口:
  1. {"t":{"$date":"2025-02-01T08:59:09.471Z"},"s":"I",  "c":"CONTROL",  "id":20568,   "ctx":"main","msg":"Waiting for connections","attr":{"port":27017,"ssl":"disabled"}}
复制代码
5.3 验证端口监听

进入 MongoDB 容器并查看端口是否精确监听。
  1. podman exec -it mongodb /bin/bash
  2. ss -tuln
复制代码
你应该能看到类似以下的输出:
  1. Netid  State   Recv-Q  Send-Q  Local Address:Port               Peer Address:Port
  2. tcp    LISTEN  0       0       0.0.0.0:27017                 0.0.0.0:*
复制代码
6. 应用所在的容器怎样连接到mongodb容器

假设有一godco的应用,有设置文件etc/godco-api.yaml,演示下该应用,怎样使用上述创建好的mongodb数据库。
修改 etc/godco-api.yaml 中的 MongoDB 连接字符串。
由于 godco 容器和 mongodb 容器在同一个自定义网络中,可以使用 mongodb 作为主机名。修改 etc/godco-api.yaml 文件中的 MongoDB 连接字符串如下:
  1. MonDB:
  2.   Url: "mongodb://test1:111111@mongodb:27017/?tls=false&authSource=atomdco"
  3.   DbName: "atomdco"
复制代码
在这个设置中:


  • mongodb 是 MongoDB 容器的名称。
  • test1 是 MongoDB 用户名。
  • 111111 是 MongoDB 密码。
  • authSource=atomdco 指定认证数据库为 atomdco。
7. 运行 godco 容器并连接到自定义网络

使用以下下令运行 godco 容器,并将其连接到自定义网络:
  1. podman run -d \
  2.   -p 8080:8080 \
  3.   -v /path/to/your/etc:/app/etc \
  4.   -v /path/to/your/static:/app/static \
  5.   --network dco-net \
  6.   --name dco-verification-app \
  7.   godco:latest
复制代码


  • -d:后台运行容器。
  • -p 8080:8080:将容器的 8080 端口映射到主机的 8080 端口。
  • -v /path/to/your/etc:/app/etc:将主机上的设置文件目次挂载到容器内的 /app/etc 目次。
  • -v /path/to/your/static:/app/static:将主机上的静态文件目次挂载到容器内的 /app/static 目次。
  • --network dco-net:将容器连接到自定义的 dco-net 网络。
  • --name dco-verification-app:为容器指定名称。
  • godco:latest:使用的 Docker 镜像名称。
8. 验证 godco 容器是否乐成连接到 MongoDB

查看 godco 容器的日记文件,以确认它是否乐成连接到 MongoDB 容器。
  1. podman logs dco-verification-app
复制代码
大概实时查看日记文件:
  1. podman logs -f dco-verification-app
复制代码
你应该能看到类似以下的日记信息,确认 godco 乐成连接到 MongoDB:
  1. [info] Connected to MongoDB server at mongodb:27017
  2. [info] MongoDB database atomdco is ready
复制代码
9. 使用 mongosh 连接到 MongoDB 并提供认证信息

9.1 获取 MongoDB 容器的 IP 地点

如果你的 MongoDB 容器已经映射了宿主机的端口(比方,使用 -p 27017:27017 参数),您可以直接使用宿主机的 IP 地点和映射的端口来连接。
  1. mongosh "mongodb://username:password@localhost:27017/?authSource=atomdco"
复制代码
由于上述我的测试没有启用该端口映射,所以须要以下方式连接:
使用 podman inspect 下令获取 MongoDB 容器的 IP 地点:
  1. podman inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' mongodb
复制代码
假设输出的 IP 地点为 10.89.0.5。
9.2 连接到 MongoDB 并提供认证信息

使用 mongosh 连接到 MongoDB 并提供认证信息。比方:
  1. mongosh "mongodb://test1:111111@10.89.0.5:27017/?authSource=atomdco"
复制代码
9.3 验证数据库

在 mongosh 中,你可以使用 show databases


下令来查看数据库。
  1. show databases
复制代码
你应该能看到类似以下的输出:
  1. admin   0.000GB
  2. config  0.000GB
  3. local   0.000GB
  4. atomdco 0.000GB
复制代码
10. 常见题目及办理方法

10.1 设置文件路径错误

确保设置文件路径精确,并且文件存在。
10.2 设置文件语法错误

检查 mongod.conf 文件是否有语法错误。可以使用 mongod --config /etc/mongod.conf 在主机上测试设置文件。
10.3 权限题目

确保数据目次和日记目次对 MongoDB 容器有精确的读写权限。使用 chown 下令调整权限。
10.4 镜像版本题目

确保你使用的 MongoDB 镜像版本精确,并且设置文件与该版本兼容。
11. 总结

通过上述步调,你可以乐成地使用 Podman 部署 MongoDB 数据库,并确保其他应用程序容器能够通过 Docker 网络乐成连接到 MongoDB。以下是完备的步调总结:
11.1 创建目次并调整权限

  1. mkdir -p ~/mongodb/data
  2. mkdir -p ~/mongodb/logs
  3. sudo chown -R 999:999 ~/mongodb/data
  4. sudo chown -R 999:999 ~/mongodb/logs
复制代码
11.2 创建立置文件 mongod.conf(禁用认证)

  1. systemLog:
  2.   destination: file
  3.   path: "/var/log/mongodb/mongod.log"
  4.   logAppend: true
  5. storage:
  6.   dbPath: "/data/db"
  7. net:
  8.   bindIp: "0.0.0.0"
  9.   port: 27017
  10. security:
  11.   authorization: "disabled"
复制代码
11.3 创建自定义 Docker 网络

  1. podman network create dco-net
复制代码
11.4 运行 MongoDB 容器(禁用认证)

  1. podman run -d \
  2.   --name mongodb \
  3.   -v ~/mongodb/data:/data/db \
  4.   -v ~/mongodb/logs:/var/log/mongodb \
  5.   -v ~/mongodb/mongod.conf:/etc/mongod.conf \
  6.   --network dco-net \
  7.   docker.io/library/mongo:latest \
  8.   -f /etc/mongod.conf
复制代码
11.5 创建 admin 用户和权限

  1. podman exec -it mongodb /bin/bash
  2. mongo
  3. use admin
  4. db.createUser({
  5.   user: "admin",
  6.   pwd: "admin123",
  7.   roles: [{ role: "root", db: "admin" }]
  8. })
  9. exit
  10. exit
复制代码
11.6 创建 atomdco 用户和权限

  1. podman exec -it mongodb /bin/bash
  2. mongo
  3. -u admin -p admin123 --authenticationDatabase adminuse atomdcodb.createUser({  user: "test1",  pwd: "111111",  roles: [{ role: "readWrite", db: "atomdco" }]})exitexit
复制代码
11.7 停止并删除 MongoDB 容器

  1. podman stop mongodb
  2. podman rm mongodb
复制代码
11.8 修改设置文件 mongod.conf 以启用认证

编辑 mongod.conf 文件,启用 authorization:
  1. systemLog:
  2.   destination: file
  3.   path: "/var/log/mongodb/mongod.log"
  4.   logAppend: true
  5. storage:
  6.   dbPath: "/data/db"
  7. net:
  8.   bindIp: "0.0.0.0"
  9.   port: 27017
  10. security:
  11.   authorization: "enabled"
复制代码
11.9 重新运行 MongoDB 容器(启用认证)

  1. podman run -d \
  2.   --name mongodb \
  3.   -v ~/mongodb/data:/data/db \
  4.   -v ~/mongodb/logs:/var/log/mongodb \
  5.   -v ~/mongodb/mongod.conf:/etc/mongod.conf \
  6.   --network dco-net \
  7.   docker.io/library/mongo:latest \
  8.   -f /etc/mongod.conf
复制代码
11.10 验证 MongoDB 容器是否精确运行

  1. podman ps -a
复制代码
11.11 验证日记文件

  1. ls -l ~/mongodb/logs
复制代码
11.12 验证端口监听

  1. podman exec -it mongodb /bin/bash
  2. ss -tuln
复制代码
11.13 修改 etc/godco-api.yaml 中的 MongoDB 连接字符串

  1. MonDB:
  2.   Url: "mongodb://test1:111111@mongodb:27017/?tls=false&authSource=atomdco"
  3.   DbName: "atomdco"
复制代码
11.14 运行 godco 容器

  1. podman run -d \
  2.   -p 8080:8080 \
  3.   -v /path/to/your/etc:/app/etc \
  4.   -v /path/to/your/static:/app/static \
  5.   --network dco-net \
  6.   --name dco-verification-app \
  7.   godco:latest
复制代码
11.15 验证 godco 容器的日记

  1. podman logs dco-verification-app
复制代码
大概实时查看日记文件:
  1. podman logs -f dco-verification-app
复制代码
11.16 使用 mongosh 连接到 MongoDB 并提供认证信息


  • 获取 MongoDB 容器的 IP 地点
    1. podman inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' mongodb
    复制代码
    假设输出的 IP 地点为 10.89.0.5。
  • 连接到 MongoDB 并提供认证信息
    1. mongosh "mongodb://test1:111111@10.89.0.5:27017/?authSource=atomdco"
    复制代码
  • 验证数据库
    1. show databases
    复制代码
    你应该能看到类似以下的输出:
    1. admin   0.000GB
    2. config  0.000GB
    3. local   0.000GB
    4. atomdco 0.000GB
    复制代码
通过这些步调,确保 MongoDB 容器精确运行并加载设置文件,同时 godco 容器能够通过 Docker 网络乐成连接到 MongoDB 容器。
12. 参考资料



  • Podman 官方文档
  • MongoDB 官方文档
  • MongoDB Shell 官方文档
13. 作者信息

Author: csdn猫哥,转载请注明出处
Date: 2025-02-01

通过本文,你将掌握怎样使用 Podman 部署 MongoDB 数据库,并设置其他容器通过 Docker 网络连接到 MongoDB。确保在每一阶段都仔细检查设置文件和权限设置,以避免常见的启动题目。

详细步调和下令总结

以下是完备的步调和下令总结,确保 MongoDB 容器精确部署并启用认证:
1. 创建目次并调整权限

  1. mkdir -p ~/mongodb/data
  2. mkdir -p ~/mongodb/logs
  3. sudo chown -R 999:999 ~/mongodb/data
  4. sudo chown -R 999:999 ~/mongodb/logs
复制代码
2. 创建立置文件 mongod.conf(禁用认证)

在主机上创建 mongod.conf 文件,内容如下:
  1. systemLog:
  2.   destination: file
  3.   path: "/var/log/mongodb/mongod.log"
  4.   logAppend: true
  5. storage:
  6.   dbPath: "/data/db"
  7. net:
  8.   bindIp: "0.0.0.0"
  9.   port: 27017
  10. security:
  11.   authorization: "disabled"
复制代码
3. 创建自定义 Docker 网络

  1. podman network create dco-net
复制代码
4. 运行 MongoDB 容器(禁用认证)

  1. podman run -d \
  2.   --name mongodb \
  3.   -v ~/mongodb/data:/data/db \
  4.   -v ~/mongodb/logs:/var/log/mongodb \
  5.   -v ~/mongodb/mongod.conf:/etc/mongod.conf \
  6.   --network dco-net \
  7.   docker.io/library/mongo:latest \
  8.   -f /etc/mongod.conf
复制代码
5. 创建 admin 用户和权限

  1. podman exec -it mongodb /bin/bash
  2. mongo
  3. use admin
  4. db.createUser({
  5.   user: "admin",
  6.   pwd: "admin123",
  7.   roles: [{ role: "root", db: "admin" }]
  8. })
  9. exit
  10. exit
复制代码
6. 创建 atomdco 用户和权限

  1. podman exec -it mongodb /bin/bash
  2. mongo
  3. -u admin -p admin123 --authenticationDatabase adminuse atomdcodb.createUser({  user: "test1",  pwd: "111111",  roles: [{ role: "readWrite", db: "atomdco" }]})exitexit
复制代码
7. 停止并删除 MongoDB 容器

  1. podman stop mongodb
  2. podman rm mongodb
复制代码
8. 修改设置文件 mongod.conf 以启用认证

编辑 mongod.conf 文件,启用 authorization:
  1. systemLog:
  2.   destination: file
  3.   path: "/var/log/mongodb/mongod.log"
  4.   logAppend: true
  5. storage:
  6.   dbPath: "/data/db"
  7. net:
  8.   bindIp: "0.0.0.0"
  9.   port: 27017
  10. security:
  11.   authorization: "enabled"
复制代码
9. 重新运行 MongoDB 容器(启用认证)

  1. podman run -d \
  2.   --name mongodb \
  3.   -v ~/mongodb/data:/data/db \
  4.   -v ~/mongodb/logs:/var/log/mongodb \
  5.   -v ~/mongodb/mongod.conf:/etc/mongod.conf \
  6.   --network dco-net \
  7.   docker.io/library/mongo:latest \
  8.   -f /etc/mongod.conf
复制代码
10. 验证 MongoDB 容器是否精确运行

  1. podman ps -a
复制代码
11. 验证日记文件

  1. ls -l ~/mongodb/logs
复制代码
12. 验证端口监听

  1. podman exec -it mongodb /bin/bash
  2. ss -tuln
复制代码
13. 修改 etc/godco-api.yaml 中的 MongoDB 连接字符串

  1. MonDB:
  2.   Url: "mongodb://test1:111111@mongodb:27017/?tls=false&authSource=atomdco"
  3.   DbName: "atomdco"
复制代码
14. 运行 godco 容器

  1. podman run -d \
  2.   -p 8080:8080 \
  3.   -v /path/to/your/etc:/app/etc \
  4.   -v /path/to/your/static:/app/static \
  5.   --network dco-net \
  6.   --name dco-verification-app \
  7.   godco:latest
复制代码
15. 验证 godco 容器的日记

  1. podman logs dco-verification-app
复制代码
大概实时查看日记文件:
  1. podman logs -f dco-verification-app
复制代码
16. 使用 mongosh 连接到 MongoDB 并提供认证信息


  • 获取 MongoDB 容器的 IP 地点
    1. podman inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' mongodb
    复制代码
    假设输出的 IP 地点为 10.89.0.5。
  • 连接到 MongoDB 并提供认证信息
    1. mongosh "mongodb://test1:111111@10.89.0.5:27017/?authSource=atomdco"
    复制代码
  • 验证数据库
    1. show databases
    复制代码
    你应该能看到类似以下的输出:
    1. admin   0.000GB
    2. config  0.000GB
    3. local   0.000GB
    4. atomdco 0.000GB
    复制代码
通过这些步调,确保 MongoDB 容器精确运行并加载设置文件,同时 godco 容器能够通过 Docker 网络乐成连接到 MongoDB 容器。

盼望这篇博文能资助你顺遂使用 Docker/Podman 部署 MongoDB 数据库,并办理常见的部署和使用题目。如果你有任何疑问或遇到其他题目,请随时留言提问。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王柳

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表