使用 Docker 容器部署 MongoDB 并支持远程访问(超多坑)

2,318 阅读3分钟

前言

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

Docker & MongoDB

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

Docker

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

MongoDB

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

MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 jsonbson 格式,因此可以存储比较复杂的数据类型。 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,也应该进行替换(坑点之一,对应上文)

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

开放端口

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

结语

如果有没弄清楚的地方欢迎大家向我提问,我都会尽力解答

这是我的 GitHub 主页 github.com/L2ncE

欢迎大家 Follow/Star/Fork 三连