Docker Compose安装MongoDB,并向宿主机映射数据文件/配置文件/日志文件

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
日志服务 SLS,月写入数据量 50GB 1个月
简介: 本文为博主实践Docker Compose方式安装MongoDB记录,希望对大家有所帮助。

🍀配置docker-compose.yml

新建存放mongodb数据的文件夹

mkdir -p ~/mongodb

创建docker-compose.yml文件

vim docker-compose.yml
# 按 i 进入编辑模式,输入以下内容
version: '3.8'
services:
  mongo:
    image: mongo:5 # 选择mongodb版本
    restart: always  # 自启动
    ports:
     - 27017:27017 # 映射宿主机端口
    volumes:
     - /docker/mongodb/data/db:/data/db    # 挂载数据文件,根据实际路径修改 :前的路径
     - /docker/mongodb/data/log:/var/log/mongodb  # 挂载日志文件,根据实际路径修改 :前的路径
     - /docker/mongodb/data/config:/etc/mongo  # 挂载配置文件,根据实际路径修改 :前的路径
# 按 esc 键,再输入 :wq ,回车退出vim

启动mongodb

# 在docker-compose.yml文件路径下,该方式退出终端失效
docker-compose up

# 后台启动
docker-compose up -d

若使用mongodb默认配置,到此已经完成mongodb安装。若需要修改mongodb启动配置可继续参考下文。

🍀修改mongodb启动配置

创建存放配置文件的文件夹

mkdir -p ~/mongodb/conf

创建配置文件 mongod.conf

cd ~/mongodb/conf
vim mongod.conf

#按 i 进入编辑模式,输入以下内容

# for documentation of all options, see:
#   http://docs.mongodb.org/manual/reference/configuration-options/

# Where and how to store data.
storage:
  dbPath: /data/db
  journal:
    enabled: true
  directoryPerDB: true
  engine: wiredTiger
  wiredTiger:
    engineConfig:
      cacheSizeGB: 8
      directoryForIndexes: true

# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log

# network interfaces
net:
  port: 27017
  bindIp: 0.0.0.0

# how the process runs
processManagement:
  timeZoneInfo: /usr/share/zoneinfo

#replication:
replication:
   oplogSizeMB: 51200
   replSetName: rs0

在之前创建的docker-compose.yml文件增加一行配置


cd ~/mongodb
vim docker-compose.yml
# 按 i 进入编辑模式,输入以下内容
version: '3.8'
services:
  mongo:
    image: mongo:5 # 选择mongodb版本
    restart: always  # 自启动
    ports:
     - 27017:27017 # 映射宿主机端口
    volumes:
     - /docker/mongodb/data/db:/data/db    # 挂载数据文件,根据实际路径修改 :前的路径
     - /docker/mongodb/data/log:/var/log/mongodb  # 挂载日志文件,根据实际路径修改 :前的路径
     - /docker/mongodb/data/config:/etc/mongo  # 挂载配置文件,根据实际路径修改 :前的路径
    command: --config /docker/mongodb/mongod.conf # 配置文件
# 按 esc 键,再输入 :wq ,回车退出vim

再启动就可以啦

cd ~/mongodb
docker-compose up -d

🍀进入mongodb终端窗口

Docker Compose 启动时会使用目录名(mongodb)作为项目名称,Docker Compose 会将所有的资源名称中加上前缀 mongodb-。

docker exec -it mongodb-mongo-1 mongo
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
13天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
142 77
|
10天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
62 24
|
9天前
|
Docker 容器
Docker 镜像加速器配置指南
dockerhub加速器失败,使用第三方加速器
|
12天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
77 6
|
21天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
30 5
|
28天前
|
存储 安全 数据安全/隐私保护
Docker中配置TLS加密的步骤
我们可以在 Docker 中成功配置 TLS 加密,增强 Docker 环境的安全性,保护容器之间以及与外界的通信安全。需要注意的是,在实际应用中,应根据具体情况进行更细致的配置和调整,确保符合安全要求。同时,定期更新证书和私钥,以保障安全性。
51 1
|
1月前
|
运维 开发者 Docker
Docker Compose:简化容器化应用的部署与管理
Docker Compose:简化容器化应用的部署与管理
|
1月前
|
Docker 微服务 容器
使用Docker Compose实现微服务架构的快速部署
使用Docker Compose实现微服务架构的快速部署
58 1
|
1月前
|
NoSQL Redis Docker
【赵渝强老师】使用Docker Compose管理容器
Docker Compose 通过 YAML 文件管理多个容器,简化复杂系统的部署和管理。本文介绍了 Docker Compose 的基本概念,并通过一个包含 Redis DB 和 Python Web 模块的示例,展示了如何使用 Docker Compose 部署和管理多容器应用。手动部署和 Docker Compose 部署的对比突显了 Docker Compose 在系统复杂度增加时的优势。
下一篇
DataWorks