前言
由于使用宝塔面板来配置 MongoDB
的 BUG 太多,实在受不了,今天心血来潮想要使用 Docker 容器来进行部署。本来以为也就二三十分钟的事情结果踩坑踩了将近两个小时,不过万幸还是成功部署上了。
Docker & MongoDB
在开始讲之前,我们需要知道 Docker
和 MongoDB
是什么,虽然这两个工具已经非常流行,但可能还是有读者不知道其详细概念
Docker
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux 或 Windows 操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
MongoDB
MongoDB 是一个基于分布式文件存储的数据库。由 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,也应该进行替换(坑点之一,对应上文)
在这之后就可以进行连接了。
开放端口
我们需要开放端口并还需在服务器添加安全组策略,若两个中有一个没开都是访问不到的。