博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
docker安装mongodb
阅读量:6889 次
发布时间:2019-06-27

本文共 2563 字,大约阅读时间需要 8 分钟。



首先简单介绍一下docker:

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

好处就是可以移植,不需要重复安装,缺点需要消耗大量内存(可以忽略)。

其他不多说,马上开始今天的主题内容:

第一步:查找docker中的mongo

​docker search mongo

11452737-8c8cb7603cfe0f26.png

这个我们就拿官方的那个下载

第二步:拉取镜像

docker pull mongo:3.6

11452737-a7d99b5150ce74e0.png

这里安装的是3.6版本,我们查看一下是否已经下载下来

docker images

11452737-ecd801960c0f8589.png

第三步:运行mongo镜像

docker run -p 27917:27017 -v e://db:/data/db -d mongo:3.6

112a35f71e5ef07f4bc72d19f73ef90a7232e3ee
  • 说明
    -p 27917:27017 :将容器的 27017 端口映射到主机的 27917 端口(端口可以自己定义)
    -v e://db:/data/db :将主机中e盘目录下的 db 挂载到容器的/data/db,作为 mongo 数 据存储目录
  • 查看容器启动情况
docker ps

11452737-b80f51dfbb613dd4.png

表明我们的mongo镜像已经启动成功

第四步:重命名容器对象

由于上面我们启动时没有指定名字,系统就自动生成一个随机的名字reverent_mestorf,为了方便记录,我们需要重新命名成我们想要的名字

docker rename reverent_mestorf mongo3.6

11452737-de7e73b006508e8a.png

第五步:进入admin数据库

首先进入mongo容器,然后进入admin数据库

winpty docker exec -it mongo3.6 bash
mongo admin

11452737-e299e608b0ccf950.png

当然也可以简写成这样

winpty docker exec -it mongo3.6 mongo admin

11452737-2162ceb4a1267747.png

注:winpty 为window下的docker需要加的命令,linux是没有的

第六步:创建账户

  • 创建管理员账号(拥有所有权限)
db.createUser({   user: 'root',   pwd: 'admin',   roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]   });

11452737-718b0a2a8e8a0e71.png

表示创建成功

  • 开启验证
db.auth("root","admin");

11452737-74c5a3e096a7d47e.png

1 代表授权验证成功

  • 创建目标数据库(实际上切换即可)
use huafeng_db

  • 创建目标数据库管理用户
db.createUser({   user: 'huafeng',   pwd: 'huafeng123456',   roles: [ { role: "readWrite", db: "huafeng_db" } ]   });

  • 开启验证
db.auth("huafeng","huafeng123456");

11452737-311152e9f396f0fd.png

现在我们使用图形化界面工具连接一下我们刚创建的数据库,看看是否成功

本人使用 Robo 3T 工具

  • 打开软件 点击左上角 创建一个连接配置,如图 地址写刚才docker对应的ip地址 端口号填写刚才配置的,点击Test按钮 如图提示,表明可连接mongo成功11452737-8cf51ee1026a25d1.png

  • 如图 点击Authentication选项卡进行用户名与密码校验

    输入数据库名字,用户名,密码 以及验证方式为MONGODB-CR,点击Test按钮,提示验证失败

    11452737-09e67ea357219d1e.png

    当我们把验证方式改为SCRAM-SHA-1时,却可以如图验证成功

    11452737-7351a74257b9b427.png

说明:程序开发使用的都是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 = 3db.system.version.save(schema)

11452737-4b7a23e6267c48d1.png

如图返回结果则表明修改成功,否则失败

这里有个不好的操作就是,一定要先创建账号之后才能修改验证方式,然后删除原来的账号再重新创建一遍

  • 查看刚才创建的用户
use admin;db.system.users.find()

11452737-aec9b038cedbdc47.png

如图,你会发现,默认的登录校验方式都是SCRAM-SHA-1

  • 对刚才创建的huafeng这个账号进行删除,然后重新创建
db.system.users.remove({user:"huafeng"})

11452737-a8fb85f7ee797437.png
  • 再次查看用户信息
use admin;db.system.users.find()

11452737-bb821dfc0662dcfd.png

如上图所示,用户登录方式已经改变成MONGODB-CR,这时,我们使用Robo 3T重新连接一下

这时已经连接成功,整个安装过程就此结束

11452737-f7697fc240fad3a8.png

拓展

  • 本地连接远程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下导出的镜像文件不能导入成功(暂时没去研究是什么问题导致)



转载地址:http://wehbl.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
tcp_wrapper:tcp包装器
查看>>
Linux系统运行级别
查看>>
android TextView 垂直自动滚动字幕实现
查看>>
beetl插件内部测试版本1.0
查看>>
一个DEGREE引发的SESSION狂潮
查看>>
UML建模语言入门-视图,事物,关系,通用机制
查看>>
kvm安装和网桥配置
查看>>
Linux基础知识之文件的时间戳及touch的使用
查看>>
springboot(八):RabbitMQ详解
查看>>
使用kill -23 取消其他进程执行
查看>>
鲁棒性
查看>>
精品软件 推荐 微软官方出品的 杀毒软件 MSE Microsoft Security Essentials
查看>>
XenServer 用户管理 简介。
查看>>
[swift]-AFNetworking网络封装
查看>>
solr 简单的分布式布署
查看>>
如何建立多Master的SaltStack环境
查看>>
RHEL / CentOS Bash命令自动完成功能
查看>>
window 查询端口详细情况
查看>>
关于发送邮件日志显示450
查看>>