使用Docker部署MongoDB

使用Docker部署MongoDB

使用Docker部署MongoDB是一种快速、便捷的方式,以下是详细步骤:

1. 基本部署

拉取MongoDB镜像

bash 复制代码
docker pull mongo:latest

运行MongoDB容器(最简单方式)

bash 复制代码
docker run --name mongodb -d -p 27017:27017 mongo

2. 带持久化存储的部署

bash 复制代码
docker run --name mongodb \
  -v /path/on/host:/data/db \
  -d -p 27017:27017 \
  mongo

3. 带认证的部署

首次运行(无认证)创建管理员用户

bash 复制代码
docker run --name mongodb \
  -d -p 27017:27017 \
  mongo --auth

进入容器创建用户

bash 复制代码
docker exec -it mongodb mongosh admin

# 在MongoDB shell中创建用户
db.createUser({ 
  user: 'admin', 
  pwd: 'yourpassword', 
  roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] 
})

带认证的完整部署命令

bash 复制代码
docker run --name mongodb \
  -e MONGO_INITDB_ROOT_USERNAME=admin \
  -e MONGO_INITDB_ROOT_PASSWORD=yourpassword \
  -d -p 27017:27017 \
  mongo --auth

4. 使用Docker Compose部署

创建docker-compose.yml文件:

yaml 复制代码
version: '3.8'

services:
  mongodb:
    image: mongo:latest
    container_name: mongodb
    environment:
      - MONGO_INITDB_ROOT_USERNAME=admin
      - MONGO_INITDB_ROOT_PASSWORD=yourpassword
    ports:
      - "27017:27017"
    volumes:
      - mongodb_data:/data/db
    restart: unless-stopped

volumes:
  mongodb_data:

然后运行:

bash 复制代码
docker-compose up -d

5. 高级配置

自定义配置文件

bash 复制代码
# 创建配置文件目录
mkdir -p /path/to/mongodb/config

# 创建配置文件
echo "storage:
  journal:
    enabled: true
security:
  authorization: enabled" > /path/to/mongodb/config/mongod.conf

# 运行容器
docker run --name mongodb \
  -v /path/to/mongodb/config:/etc/mongo \
  -v /path/to/mongodb/data:/data/db \
  -d -p 27017:27017 \
  mongo --config /etc/mongo/mongod.conf

副本集部署(开发环境)

bash 复制代码
# 启动三个MongoDB实例
docker run --name mongo1 -d -p 27017:27017 mongo --replSet rs0 --bind_ip_all
docker run --name mongo2 -d -p 27018:27017 mongo --replSet rs0 --bind_ip_all
docker run --name mongo3 -d -p 27019:27017 mongo --replSet rs0 --bind_ip_all

# 配置副本集
docker exec -it mongo1 mongosh --eval "rs.initiate({
  _id: 'rs0',
  members: [
    {_id: 0, host: 'mongo1:27017'},
    {_id: 1, host: 'mongo2:27017'},
    {_id: 2, host: 'mongo3:27017'}
  ]
})"

6. 常用管理命令

查看运行中的容器

bash 复制代码
docker ps

查看MongoDB日志

bash 复制代码
docker logs mongodb

进入MongoDB shell

bash 复制代码
docker exec -it mongodb mongosh -u admin -p yourpassword

停止和启动容器

bash 复制代码
docker stop mongodb
docker start mongodb

删除容器

bash 复制代码
docker rm -f mongodb

7. 安全建议

  1. 生产环境务必启用认证

  2. 不要将MongoDB直接暴露在公网上

  3. 定期备份数据

  4. 考虑使用网络隔离

    bash 复制代码
    docker network create mongo-network
    docker run --name mongodb --network mongo-network -d mongo
  5. 限制资源使用

    bash 复制代码
    docker run --name mongodb --memory="2g" --cpus="1.0" -d mongo

通过Docker部署MongoDB可以快速搭建开发、测试环境,生产环境建议考虑更全面的配置和监控方案。

相关推荐
丈剑走天涯1 小时前
kubernetes 源码编译(ubuntu) kubernetes-1.34.1
java·容器·kubernetes·1024程序员节
..Move...1 小时前
基于VMware和Cent OS的Docker Engine安装与配置
运维·docker·容器
AL流云。1 小时前
学习Docker前提:多环境安装Docker
学习·docker·eureka·1024程序员节
路漫漫其修远兮sjw1 小时前
常用docker命令速查表
运维·docker·容器·模型部署
FinTech老王9 小时前
国产数据库MongoDB兼容性技术分析与实践对比
mongodb·1024程序员节
java_logo11 小时前
Docker 部署 WordPress 全流程
运维·docker·容器·word·php·1024程序员节
武子康14 小时前
Java-159 MongoDB 副本集容器化 10 分钟速查卡|keyfile + –auth + 幂等 init 附 docker-compose
java·数据库·mongodb·docker·性能优化·nosql·1024程序员节
wodongx12315 小时前
从一开始部署Android项目Sonarqube的自动化扫码+通知+增量扫描功能(Win环境、Docker,基于Jenkins)
运维·docker·jenkins·1024程序员节
java_logo16 小时前
Docker 部署 Elasticsearch 全流程手册
大数据·运维·mongodb·elasticsearch·docker·容器
Stay Passion16 小时前
Docker 组件:Docker Swarm
运维·docker·容器