前言
由于使用宝塔面板来配置MongoDB的BUG太多,实在受不了,今天心血来潮想要使用Docker容器来进行部署。本来以为也就二三十分钟的事情结果踩坑踩了将近两个小时,不过万幸还是成功部署上了
Docker & MongoDB
在开始讲之前,我们需要知道Docker和MongoDB是什么,虽然这两个工具已经非常流行,但可能还是有读者不知道其详细概念
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,也应该进行替换(坑点之一,对应上文)
在这之后就可以进行连接了
开放端口
我们需要开放端口并还需在服务器添加安全组策略,若两个中有一个没开都是访问不到的
暂无评论内容