docker安装mongodb

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: 学习更多编程技术,请关注 “吾要编程” 微信公众号 首先简单介绍一下docker: Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。



首先简单介绍一下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下导出的镜像文件不能导入成功(暂时没去研究是什么问题导致)




相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
2月前
|
存储 安全 C++
Odoo 安装方式选择:源码安装 vs Docker
Odoo部署常采用源码编译或Docker容器化,但分别面临依赖复杂、版本风险和服务化难题,以及镜像臃肿和扩展受限的问题。Websoft9提出混合方案,融合两者优势:通过智能环境适配、三阶段部署流程(环境预检、混合模式选择、持久化配置)及声明式YAML配置,实现高效、灵活的双模运行时。此方案显著降低依赖冲突解决时间(从83分钟至0),生产环境构建耗时缩短至8分钟,并达100% CVE漏洞修复率,适合ERP定制开发与规模化部署的企业需求。
|
14天前
|
Linux iOS开发 Docker
MyEMS开源系统安装之Linux/macOS上的DOcker
本指南详细介绍了如何在Linux/macOS上使用Docker部署MyEMS系统。主要内容包括:前置条件(如安装Docker、npm和MySQL),以及分步骤部署各个组件(如myems-api、myems-admin、myems-modbus-tcp等)。每个步骤涵盖源代码复制、环境配置、镜像构建、容器运行及日志管理等操作,并提供了多平台构建的支持。最后,指南还说明了默认端口和登录凭据,帮助用户快速启动并访问MyEMS的管理界面和Web界面。
40 1
|
1月前
|
关系型数据库 MySQL 数据库
Docker 安装常用软件相关命令
本文介绍了在CentOS 7.9系统上安装Docker的详细步骤,包括添加阿里云镜像源、安装Docker及相关组件、启动服务以及配置镜像加速。同时,还展示了如何通过Docker安装MySQL 5.7版本数据库,涵盖拉取镜像、创建数据目录、运行容器及配置挂载点等操作,并提供验证安装成功的命令和截图。适合需要部署Docker与MySQL环境的用户参考。
141 4
|
1月前
|
存储 弹性计算 Linux
安装Docker
常见操作系统安装docker步骤
124 15
|
1月前
|
Docker 容器
在openEuler 22.03 LTS上安装Docker CE和Docker Compose
以上就是在openEuler 22.03 LTS上安装Docker CE和Docker Compose的过程。希望这个指南能帮助你顺利完成安装。
315 12
|
2月前
|
Linux 虚拟化 Docker
win11怎么安装docker的必要设置自学软硬件工程师778天
win11怎么安装docker的必要设置自学软硬件工程师778天
win11怎么安装docker的必要设置自学软硬件工程师778天
|
2月前
|
Prometheus 监控 Cloud Native
Prometheus+Grafana(docker安装)
本文档详细介绍了如何使用Docker容器快速部署Prometheus监控系统和Grafana数据可视化平台。该方案适用于需要快速搭建监控环境的开发测试场景,具备部署简单、资源占用低、易于维护等特点。
|
2月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu系统的Docker上安装MySQL的方法
以上的步骤就是在Ubuntu系统的Docker上安装MySQL的详细方法,希望对你有所帮助!
286 12
|
3月前
|
监控 关系型数据库 MySQL
zabbix7.0.9安装-以宝塔安装形式-非docker容器安装方法-系统采用AlmaLinux9系统-最佳匹配操作系统提供稳定运行环境-安装教程完整版本-优雅草卓伊凡
zabbix7.0.9安装-以宝塔安装形式-非docker容器安装方法-系统采用AlmaLinux9系统-最佳匹配操作系统提供稳定运行环境-安装教程完整版本-优雅草卓伊凡
200 30
|
3月前
|
Ubuntu 关系型数据库 MySQL
容器技术实践:在Ubuntu上使用Docker安装MySQL的步骤。
通过以上的操作,你已经步入了Docker和MySQL的世界,享受了容器技术给你带来的便利。这个旅程中你可能会遇到各种挑战,但是只要你沿着我们划定的路线行进,你就一定可以达到目的地。这就是Ubuntu、Docker和MySQL的灵魂所在,它们为你开辟了一条通往新探索的道路,带你亲身感受到了技术的力量。欢迎在Ubuntu的广阔大海中探索,用Docker技术引领你的航行,随时准备感受新技术带来的震撼和乐趣。
181 16