使用Docker容器部署MongoDB并支持远程访问及遇到的坑

前言

由于使用宝塔面板来配置MongoDB的BUG太多,实在受不了,今天心血来潮想要使用Docker容器来进行部署。本来以为也就二三十分钟的事情结果踩坑踩了将近两个小时,不过万幸还是成功部署上了

Docker & MongoDB

在开始讲之前,我们需要知道DockerMongoDB是什么,虽然这两个工具已经非常流行,但可能还是有读者不知道其详细概念

Docker

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

MongoDB

MongoDB是一个基于分布式文件存储 [1]  的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

使用Docker部署MongoDB

Docker的安装请参照其他文章

在进入我们服务器的终端后就可以开始操作了,首先我们要拉取最新的mongo镜像

$ docker pull mongo:latest

使用docker images来检查是否成功拉取镜像

$ docker images

接下来我们就可以让镜像跑起来并跑在27017端口

若跑在其他端口会有坑,后面讲

$ docker run -itd --name mongo -p 27017:27017 mongo

我们可以使用docker ps来验证是否已经跑起来了,下一步我们直接进入容器中

$ docker exec -it mongo /bin/bash

接下来我们不慌着直接使用mongo命令,因为直接使用的话就会踩坑。我们的目的是部署了MongoDB并能让其支持远程访问,所以我们需要先去更改它的配置文件,更改配置文件需要使用到vim,所以我们还需要下载vim,但我们知道,直接下载的话非常缓慢,所以我们还得给容器换一个源

容器中换源

正则替换成阿里的镜像可以快速update

$ sed -i s@/archive.ubuntu.com/@/mirrors.aliyun.com/@g /etc/apt/sources.list
$ sed -i s@/security.ubuntu.com/@/mirrors.aliyun.com/@g /etc/apt/sources.list
$ apt clean
$ apt-get update -y

更改配置

接下来就可以下载vim并更改配置了

$ apt-get install vim
$ vim /etc/mongod.conf.orig

进入到配置我们中将其中的bindIp: 127.0.0.1注释掉# bindIp: 127.0.0.1,或改成0.0.0.0即可。除此之外,若你MongoDB部署的端口不是27017,也应该进行替换(坑点之一,对应上文)

在这之后就可以进行连接了

开放端口

我们需要开放端口并还需在服务器添加安全组策略,若两个中有一个没开都是访问不到的

到此这篇关于使用Docker容器部署MongoDB并支持远程访问及遇到的坑的文章就介绍到这了,更多相关Docker部署MongoDB内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(使用Docker容器部署MongoDB并支持远程访问及遇到的坑)