docker安装mongodb
首先简单介绍一下docker:
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
好处就是可以移植,不需要重复安装,缺点需要消耗大量内存(可以忽略)。
其他不多说,马上开始今天的主题内容:
第一步:查找docker中的mongo
docker search mongo
这个我们就拿官方的那个下载
第二步:拉取镜像
docker pull mongo:3.6
这里安装的是3.6版本,我们查看一下是否已经下载下来
docker images
第三步:运行mongo镜像
docker run -p 27917:27017 -v e://db:/data/db -d mongo:3.6
- 说明
-p 27917:27017 :将容器的 27017 端口映射到主机的 27917 端口(端口可以自己定义)
-v e://db:/data/db :将主机中e盘目录下的 db 挂载到容器的/data/db,作为 mongo 数 据存储目录 - 查看容器启动情况
docker ps
表明我们的mongo镜像已经启动成功
第四步:重命名容器对象
由于上面我们启动时没有指定名字,系统就自动生成一个随机的名字reverent_mestorf,为了方便记录,我们需要重新命名成我们想要的名字
docker rename reverent_mestorf mongo3.6
第五步:进入admin数据库
首先进入mongo容器,然后进入admin数据库
winpty docker exec -it mongo3.6 bash
mongo admin
当然也可以简写成这样
winpty docker exec -it mongo3.6 mongo admin
注:winpty 为window下的docker需要加的命令,linux是没有的
第六步:创建账户
- 创建管理员账号(拥有所有权限)
db.createUser({ user: 'root', pwd: 'admin', roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] });
表示创建成功
- 开启验证
db.auth("root","admin");
1 代表授权验证成功
- 创建目标数据库(实际上切换即可)
use huafeng_db
- 创建目标数据库管理用户
db.createUser({ user: 'huafeng', pwd: 'huafeng123456', roles: [ { role: "readWrite", db: "huafeng_db" } ] });
- 开启验证
db.auth("huafeng","huafeng123456");
现在我们使用图形化界面工具连接一下我们刚创建的数据库,看看是否成功
本人使用 Robo 3T 工具
-
打开软件 点击左上角 创建一个连接配置,如图 地址写刚才docker对应的ip地址 端口号填写刚才配置的,点击Test按钮 如图提示,表明可连接mongo成功
-
如图 点击Authentication选项卡进行用户名与密码校验
输入数据库名字,用户名,密码 以及验证方式为MONGODB-CR,点击Test按钮,提示验证失败
当我们把验证方式改为SCRAM-SHA-1时,却可以如图验证成功
说明:程序开发使用的都是MONGODB-CR(直连)方式验证
- 通过查看mongo官方文档发现,原来新版的mongodb(3.0以后)加入了SCRAM-SHA-1校验方式,需要第三方工具配合进行验证,默认的currentVersion 值为5,若需要MONGODB-CR 验证则需要做以下操作
use admin; var schema = db.system.version.findOne({"_id" : "authSchema"}) schema.currentVersion = 3 db.system.version.save(schema)
如图返回结果则表明修改成功,否则失败
这里有个不好的操作就是,一定要先创建账号之后才能修改验证方式,然后删除原来的账号再重新创建一遍
- 查看刚才创建的用户
use admin; db.system.users.find()
如图,你会发现,默认的登录校验方式都是SCRAM-SHA-1
- 对刚才创建的huafeng这个账号进行删除,然后重新创建
db.system.users.remove({user:"huafeng"})
- 再次查看用户信息
use admin; db.system.users.find()
如上图所示,用户登录方式已经改变成MONGODB-CR,这时,我们使用Robo 3T重新连接一下
这时已经连接成功,整个安装过程就此结束
拓展
- 本地连接远程mongo数据库
winpty docker exec -it mongo3.6 mongo -u 用户名 -p 密码 host:port/数据库名称
- 备份远程mongo数据库到本地docker中
mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径
如:
winpty docker exec -it mongo3.6 mongodump -h 192.168.3.185 --port 27917 -u huafeng -p huafeng123456 -d huafneg_db -o /data/db
注: 上面是一行代码,文章排版问题。本地备份IP可以不填,如果是默认端口也可以不填(安全问题,端口一般是要改变的)
- docker把容器中的mongo导出成镜像文件
docker export [CONTAINER ID] > 文件名.tar
- docker导入镜像
docker load < 文件名.tar
注: 测试发现,window下导出的镜像文件不能导入成功(暂时没去研究是什么问题导致)

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Hulu大规模容器调度系统Capos
Hulu是美国领先的互联网专业视频服务平台,目前在美国拥有超过2000万付费用户。Hulu总部位于美国洛杉矶,北京办公室是仅次于总部的第二大研发中心,也是从Hulu成立伊始就具有重要战略地位的分支办公室,独立负责播放器开发,搜索和推荐,广告精准投放,大规模用户数据处理,视频内容基因分析,人脸识别,视频编解码等核心项目。 在视频领域我们有大量的视频转码任务;在广告领域当我们需要验证一个投放算法的效果时,我们需要为每种新的算法运行一个模拟的广告系统来产出投放效果对比验证;在AI领域我们需要对视频提取帧,利用一些训练框架产出模型用于线上服务。这一切都需要运行在一个计算平台上,Capos是Hulu内部的一个大规模分布式任务调度和运行平台。 Capos是一个容器运行平台,包含镜像构建,任务提交管理,任务调度运行,日志收集查看,Metrics收集
- 下一篇
ECS运维:操作系统有异常?诊断日志来帮忙!
云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。阿里云使用严格的IDC标准、服务器准入标准以及运维标准,保证云计算整个基础框架的高可用性、数据的可靠性以及云服务器ECS的高可用性。但在使用ECS实例的过程中,仍然有可能会出现由于操作系统配置不当或程序过载等原因导致系统内核崩溃的情况,这将导致系统夯机、异常重启或无法正常启动等问题。为了分析根本原因而避免问题反复发生,运维人员通常依靠查看系统日志来做分析诊断,然而此时也许实例已经无法正常SSH远程连接,让定位故障原因的过程变得非常困难。现在阿里云提供了一键查看系统日志和屏幕截屏的功能,为运维人员提供了一个方便的工具,给系统异常故障的分析诊断提供更多的支持。 为什么需要系统串口日志
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 设置Eclipse缩进为4个空格,增强代码规范
- CentOS关闭SELinux安全模块
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Windows10,CentOS7,CentOS8安装Nodejs环境
- CentOS7设置SWAP分区,小内存服务器的救世主
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程