当前位置: 首页 > news >正文

docker安装mongodb

一、前期准备

1.在服务器上面创建三个目录做为挂载到docker (/mongo/data,/mongo/logs,/mongo/conf )

由于我们要把宿主的配置文件同步容器中,所以要在/mogo/conf创建mogodb的配置文件

mongod.conf ,内容如下:

# 系统日志 systemLog: destination: file # 输出到文件 path: /var/log/mongodb/mongod.log # 必须与挂载卷对应 logAppend: true # 重启时追加,不截断 verbosity: 0 # 日志级别 0-5,数字越大越详细 # 数据存储 storage: dbPath: /data/db # 数据目录,必须与挂载卷对应 # 64 位系统默认开,崩溃可恢复 wiredTiger: # 3.2+ 默认引擎 engineConfig: cacheSizeGB: 2 # WT 缓存,≈(物理内存-1GB)/2,最小 256M directoryForIndexes: false # 索引与数据放同目录 collectionConfig: blockCompressor: snappy # 集合压缩算法 snappy/zstd/zlib indexConfig: prefixCompression: true # 索引前缀压缩 # 进程管理 processManagement: fork: false # 容器里必须 false,前台运行 pidFilePath: /tmp/mongod.pid # 容器内路径即可 # 网络 net: port: 27017 bindIp: 0.0.0.0 # 允许所有网卡访问,配合 -p 27017:27017 maxIncomingConnections: 65536 # 最大并发连接,默认 65536 # 安全(第一次建完管理员后再开) security: authorization: disabled # 开启鉴权,第一次启动前可先 disabled 建用户 # keyFile: /data/mongodb-keyfile # 副本集/分片时再加 # 复制集(单节点可省略) # replication: # replSetName: rs0 # 分片(单节点可省略) # sharding: # clusterRole: shardsvr # 审计、SNMP、setParameter 等按需再补

注意点:由于我们新建mongodb没有账号所以在配置时,为disabled ,如果创建的用户可以改为【enabled】

# 安全(第一次建完管理员后再开)
security:
authorization: disabled

2.容器里 MongoDB 进程以UID 999(mongodb)身份运行,往/var/log/mongodb/mongod.log写文件时没有写权限,所以依旧报FileNotOpen

# 方案 B:生产环境推荐(把属主直接给容器内的 mongodb 用户) chown -R 999:999 /mongo/logs

二、使用命令

docker run -d --name mongo-prod --restart=unless-stopped -p 27017:27017 -v /mongo/data:/data/db -v /mongo/logs:/var/log/mongodb -v /mongo/conf/mongod.conf:/etc/mongod.conf:ro mongo:7.0.14 mongod --config /etc/mongod.conf

解读说明:

  1. docker run -d
    -d= detached,容器在后台运行。

  2. --name mongo-prod
    给容器起个名字叫mongo-prod,方便后续docker stop/start/logs直接引用。

  3. --restart=unless-stopped
    只要 Docker 服务活着,容器退出就自动重启;手动 stop才不重启。

  4. -p 27017:27017
    把宿主机的 27017端口映射到容器内的27017(MongoDB 默认端口)。
    外部连接串写mongodb://宿主机IP:16017

  5. 三个-v挂载(核心)
    a)-v /mongo/data:/data/db
    宿主机真实数据目录 → 容器内 MongoDB 数据路径。
    容器删了数据也在。
    b)-v /mongo/logs:/var/log/mongodb
    宿主机日志目录 → 容器内日志路径。
    保证mongod.log落在宿主机,方便查日志。
    c)-v /mongo/conf/mongod.conf:/etc/mongod.conf:ro
    宿主机配置文件 → 容器内/etc/mongod.conf只读(:ro),防止容器内误改。

  6. mongo:7.0.14
    使用的镜像版本号,固定 7.0.14,不会自动升级。

  7. mongod --config /etc/mongod.conf
    容器启动后执行的命令:
    用刚才挂进去的配置文件启动mongod进程。

http://www.cnnetsun.cn/news/161209.html

相关文章:

  • 前后端分离MVC自习室管理和预约系统系统|SpringBoot+Vue+MyBatis+MySQL完整源码+部署教程
  • 【必收藏】LangGraph深度研究智能体实战:LangChain官方OpenDeepResearch完整源码解析与本地部署指南
  • 清华/人大/新国大联合发布:AI Agent记忆系统全面解析,解决灾难性遗忘与上下文溢出问题
  • Langchain-Chatchat如何评估知识库问答的准确性?
  • 大语言模型的 “思考” 秘密:一文读懂 prompt 工程核心逻辑
  • Langchain-Chatchat支持Excel表格内容作为知识源吗?
  • 多智能体系统在竞争优势分析中的应用:寻找护城河
  • AI生成的音乐,到底能商用吗
  • Linux GPIO-KEYS
  • OmniThoughtV:面向多模态深度思考的高质量数据蒸馏
  • 面试不是考试,而是“技术交流与信任构建”
  • 45、WPF 打印与 XPS 文档处理全解析
  • 46、WPF应用开发:从打印到过渡效果与世界浏览器应用构建
  • 【仿真测试】基于FPGA的完整64QAM通信链路实现,含频偏锁定,帧同步,定时点,Viterbi译码,信道,误码统计
  • Day35:DMA 原理与架构
  • Java如何通过组件优化WebUploader分片上传效率?
  • 阿里云客服支持与服务状态查询指南
  • 【毕业设计】SpringBoot+Vue+MySQL Spring Boot校园闲置物品交易系统平台源码+数据库+论文+部署文档
  • 11、Hyper-V与VMM 2008:服务器虚拟化的利器
  • 手把手教你用Dify接入本地大模型:AI知识库实战教程!
  • Scrapy框架实战教程:从入门到精通的专业爬虫开发指南(包含python环境配置)
  • 联想摩托罗拉与鸿日达设立3D打印联合实验室,开展通信设备轻量化及结构设计
  • 技术解读“创世纪计划”:架构、协作与开源挑战
  • ETSC:挖掘潜力,减少与工作相关的道路交通伤亡事故(英) 2025
  • Langchain-Chatchat问答系统灰度期间服务可用性保障
  • Activiti7工作流(八)流程变量
  • Langchain-Chatchat能否支持文档标签分类管理?
  • Langchain-Chatchat能否支持文档访问统计?
  • Langchain-Chatchat结合Traefik实现动态路由
  • 【程序源代码】成人用品商城系统源码微信小程序(含源码)