Docker部署MongoDB
1、查看可用的 MongoDB 版本
docker search mongo
2、拉取最新版的 MongoDB 镜像
docker pull mongo:latest
3、查看本地镜像
docker images
4、运行容器
安装完成后,我们可以使用以下命令来运行 mongo 容器:
(1)数据未持久化
docker run -itd --name mongo -p 27017:27017 mongo --auth
(2)数据持久化
docker run --name my_mongo -v /mongo_local_data:/data/db --rm -d -p 27017:27017 mongo
参数说明:
- -itd 交互后台运行容器
- --name 自定义容器名称
- -p 27017:27017 容器服务的 27017 端口映射到宿主机的 端口 27017,那么外部可以通过 宿主机 IP:27017 访问容器内 mongo。
- 镜像名
- --auth 需要密码才能访问容器服务。
5、创建mongoDB账号
最后我们可以通过 docker ps 命令查看容器的运行信息:
(1)进入容器创建数据库访问用户账号密码,并且尝试连接。
docker exec -it mongo mongo admin
docker exec -it 容器ID mongo admin
linux
mac
(2)执行mongoDB语句, 创建mongoDB账号
db.createUser({ user:'admin',pwd:'123456',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
(3)使用创建账号进行连接
db.auth('admin', '123456')
二、访问容器数据库
三、容器数据持久化
没做数据持久化的话,容器内的数据随着容器关闭而消失,解决方法是把容器内的目录映射到本地,这样容器即使容器停止、不小心删除了数据也仍然在。
1.在宿主机本地创建目录:/mongo_local_data,执行命令
# 创建卷
docker volume create mongo_local_data
# 运行景相融弄个器
docker run --name my_mongo -v /mongo_local_data:/data/db --rm -d -p 27018:27017 mongo
/data/db是镜像mongo容器内的存储数据的目录
/mongo_local_data是物理机生成的数据持久化目录
运行容器命令后,自动生成物理机数据持久化目录
cd /
ls -l
【window 、mac】
如果遇到问题“docker: Error response from daemon: Mounts denied:
The path /mongo_local_data is not shared from the host and is not known to Docker.
You can configure shared paths from Docker -> Preferences... -> Resources -> File Sharing.
See https://docs.docker.com/docker-for-mac for more info.”
按照报错提示,需要将容器内指定目录,挂载到主机上!
解决办法:
(1)客户端界面化挂载方式
(2)命令行方式
①创建卷
docker volume create 卷名docker volume lsdocker volume inspect 卷名
②用该卷创建一个容器
docker run -d --name=容器名称 -v 卷名:容器路径 镜像名
docker run -itd --name my_mongo -v mongo_local_data:/data/db --restart=always -p 27018:27017 mongo
③进入容器内持久化的目录
docker exec -it 11b4e9c8b3bc bash -c "cd /data/db&& ls"
可视化界面查看卷目录
下图为mongodb容器内的数据存放目录:
注意:启动时,参数如果加--auth参数,恢复导入数据时,会有验证问题。
2.其他数据持久化挂载方式:
docker run -d --name=容器名称 --mounts src=卷名,dst=容器路径 镜像名docker run -d --name=mongo --mounts src=mongo_local_data,dst=/data/db mongo
Docker部署MongoDB相关推荐
- mysql主从配置duxi_手把手超详细Docker部署MongoDB集群
Mongodb集群搭建 mongodb 集群搭建的方式有三种:主从备份(Master - Slave)模式,或者叫主从复制模式. 副本集(Replica Set)模式. 分片(Sharding)模式. ...
- Docker部署MongoDB副本集
docker拉取mongo docker pull mongo 安装mongo单机版 docker run -itd --name mongo -p 27017:27017 mongo --authd ...
- Docker应用五:使用Dockerfile部署MongoDB
在Docker容器中部署MongoDB 不做铺垫,直接开撸: 一.软件准备: docker(已安装) MongoDB-3.2.0.tgz 二.准备配置文件mongo.conf port=27017 d ...
- 在Docker中安装和部署MongoDB集群
在Docker中安装和部署MongoDB集群 - tianshidan1998 - 博客园
- Docker构建YApi镜像, Docker安装YApi, Docker部署YApi
目录 概述 基本环境 docker网络 安装MongoDb 构建YAPI镜像 运行YAPI Nginx反向代理 挂域名 概述 YApi 是高效.易用.功能强大的 api 管理平台,旨在为开发.产品.测 ...
- docker部署webapp的例子
2019独角兽企业重金招聘Python工程师标准>>> 本文以 [tcl-tennis](https://github.com/limijiaoyin/tcl-tennis) 为例, ...
- 使用Docker部署Spring-Boot-项目,带劲!
Docker 一次构建.处处运行及快速启停的特性,在微服务架构中有着举足轻重的地位,具体的概念性的东西就不介绍了,不懂的点击这里阅读 Docker 基础教程. 本篇栈长主要介绍下如何通过 Intell ...
- docker部署项目通过127.0.0.1访问数据库:Connection refused
背景说明 同一台机子(以linux为例)部署以下项目.数据库 docker部署mysql.mongo.postgresql.clickhouse数据库 docker部署spring-boot项目.py ...
- 【进阶】34、docker部署mall商城
文章目录 一.学习网址 二.mall的docker部署 1)docker环境安装 2)部署harbor 3)Mysql安装 4)部署redis 5)nginx安装 6)RabbitMQ安装 7)Ela ...
最新文章
- IQKeyboardManager使用方法
- 【Vegas原创】exp时,ORA-00932: 数据类型不一致解决方法
- iOS 进阶之底层原理一OC对象原理alloc做了什么
- 对geobeansEvent事件回调函数的改进
- TLD(Tracking-Learning-Detection)学习与源码理解之(五)
- qvector 结构体排序_C++结构体的应用_YCOJ
- 使用第三方《UITableView+FDTemplateLayoutCell》自动计算UITableViewCell高度(Masonry约束)...
- modf函数C语言,C / C ++中的modf()
- 历史回顾——NLP问题解决方案的演变史
- 个人经验分享 | 在面试官眼中:PDF版简历和个人主页的区别
- 列举一台微型计算机的常用硬件,电脑基础知识问答卷
- [唐胡璐]VBS技巧 - Find a File Recursively(递归查找文件)
- 千万级测试String、StringBuffer和StringBuilder的速度
- mysql 部署在私有云_教你在 RHEL 7 中部署私有云网盘
- 《抓住“三伏天”习武健身的黄金季节》--胡俭雷
- C++中acculumate函数使用
- 抖音支付唤起支付失败,报错10003
- linux lib.a反编译,android反编译-smali文件语法
- Real user ID, effective user ID, set user ID
- 记一次绕过火绒安全提权实战案例