资讯专栏INFORMATION COLUMN

记录一次被docker多容器通信虐的死去活来的部署之路(node + mongoDB + nginx

TNFE / 1203人阅读

摘要:原因是这样的想要部署一个平台,就在朋友的推荐下选择了这个现成的项目该项目分为服务端客户端以及数据库在尝试直接部署的时候发现需要装一大堆的环境,啊,特别的麻烦,之前简单的使用过,就在想能不能用免环境直接部署呢于是就有了这次的尝试多容器通信该

原因是这样的

想要部署一个mocker平台,就在朋友的推荐下选择了api-mocker这个现成的项目

该项目分为服务端node、客户端vue、以及数据库mongoDB

在尝试直接部署的时候发现需要装一大堆的环境,node、mongo、nginx啊,特别的麻烦,之前简单的使用过docker,就在想能不能用docker免环境直接部署呢?于是就有了这次的尝试

多容器通信

该项目分为3个部分,于是就要建立3个容器(node、mongo、nginx)

那容器之间怎么实现通信呢?

</>复制代码

  1. # 通过link指令建立连接
  2. $ docker run --name -d -p : --link :

--link 容器连接指令

< containerName > : < alias >

< 被连接容器名称 > : < 容器访问别名 >

注:别名在主动建立连接的容器中访问被连接容器使用

以下指令在容器检测连接状态

</>复制代码

  1. $ curl

接下来我们开始尝试部署 实现过程

1、构建mongo容器
2、构建node容器并与mongo容器建立连接
3、构建nginx容器并与node容器建立连接

构建mongo容器

我们先拉取mongo镜像

</>复制代码

  1. $ docker pull mongo:latest

</>复制代码

  1. $ docker images
  2. REPOSITORY TAG IMAGE ID CREATED SIZE
  3. mongo latest 05b3651ee24e 2 weeks ago 382MB

下面我们让这个镜像跑起来

</>复制代码

  1. $ docker run --name mock-mongo -d -p 27017:27017 mongo:latest --auth
  2. # 需要与本地建立文件共享,则使用一下-v指令
  3. # -v /data/db:/data/db

</>复制代码

  1. --auth 指令开启了mongo的连接身份校验
    开启校验 是由于 node 跨容器连接时 不设置身份校验 开启服务端无法连接上mongo数据库

</>复制代码

  1. nodejs.MongoError: [egg-mongoose]Authentication failed.

查看容器

</>复制代码

  1. $ docker ps -a
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 0d440be90935 mongo "docker-entrypoint.s…" 14 hours ago Up 14 hours 0.0.0.0:27017->27017/tcp mock-mongo

由于我们mongo开启了身份验证,所以我们要进入mongo容器配置一下node连接时使用的账号

</>复制代码

  1. $ docker exec -it mock-mongo /bin/bash
  2. $ mongo admin
  3. # 创建manager user
  4. $ db.createUser({user:"admin", pwd:"admin",roles:[{role:"admin",db:"admin"}]})
  5. # 账号授权
  6. $ db.auth("admin","admin")

</>复制代码

  1. 现在我们的mongo数据库已经跑起来了,接下来我们就要建立node容器了
构建node容器并与mongo容器建立连接

在开始构建node容器前我们要先约定好mongo容器别名,端口号以及登录账号密码

mongo容器别名:db

mongo端口号:27017

账号密码:admin:admin

我们先修改node服务端的配置

</>复制代码

  1. 文件配置 dockerfile/api-mocker/server/config/config.default.js
    修改mongo连接配置,db为预先设定的mock-mongo容器的别名

</>复制代码

  1. mongoose: {
  2. url: "mongodb://admin:admin@db:27017/api-mock?authSource=admin"
  3. },

现在我们编写一个Dockerfile文件来构建镜像

</>复制代码

  1. # 指定基础镜像
  2. FROM node:latest
  3. # 维护者
  4. MAINTAINER qiushiyuan1994@qq.com
  5. # 工作目录
  6. WORKDIR /www
  7. # 将本地文件添拷贝到容器中,不会解压
  8. COPY api-mocker node-server/api-mocker
  9. EXPOSE 7001
  10. WORKDIR /www/node-server/api-mocker/server
  11. RUN npm install
  12. WORKDIR /www/node-server/api-mocker
  13. # 构建容器后调用,在容器启动时才进行调用
  14. CMD ["make", "prod_server"]

我们使用编写好的dockerfile文件构建镜像

</>复制代码

  1. $ docker build -t="mock-server:1.0.0" .

让我们查看一下镜像

</>复制代码

  1. $ docker images
  2. REPOSITORY TAG IMAGE ID CREATED SIZE
  3. mock-server 1.0.0 957ad2aa1f97 8 minutes ago 674MB
  4. mongo latest 05b3651ee24e 2 weeks ago 382MB

现在就到了关键的一步,我们将mocker-server镜像运行起来,并建立服务器与数据库的连接

</>复制代码

  1. $ docker run -d -i -t -p 7001:7001 --name mock-server1 --link mock-mongo:db mock-server:1.0.0 /bin/bash

让我们再看看现在正在运行的容器

</>复制代码

  1. $ docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. ee780b903c64 mock-server:1.0.0 "/bin/bash" About a minute ago Up 11 seconds 0.0.0.0:7001->7001/tcp mock-server
  4. 0d440be90935 mongo "docker-entrypoint.s…" 16 hours ago Up 16 hours 0.0.0.0:27017->27017/tcp mock-mongo

检测node容器和mongo容器的连接状态

</>复制代码

  1. $ docker exec -it mock-server /bin/bash
  2. $ curl db

</>复制代码

  1. 现在我们的服务端和数据库已经建立起了连接,接下来我们要开始部署我们的客户端
构建nginx容器并与node容器建立连接

在建立nginx前,我们要先约定好,node容器别名,nginx转发的端口号以及客户端访问nginx域名及端口号

node服务器别名:node

node容器映射的端口号:7001

nginx域名:127.0.0.1

nginx端口号:90

我们先拉取nginx镜像并建立容器

</>复制代码

  1. $ docker pull nginx:latest
  2. $ docker run -p 90:80 --link mock-node:node nginx:latest --name mock-nginx
  3. # 查看容器连接状态
  4. $ docker exec -it mock-nginx /bin/bash
  5. $ env
  6. # 看到以下数据则表示连接成功了
  7. NODE_PORT_7001_TCP=tcp://172.17.0.3:7001
  8. NODE_PORT_7001_TCP_PORT=7001
  9. NODE_ENV_YARN_VERSION=1.9.4

现在我们在看看已经运行中的容器

</>复制代码

  1. $ docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 09644025d148 nginx "nginx -g "daemon of" 5 hours ago Up 5 hours 0.0.0.0:90->80/tcp mock-nginx
  4. ee780b903c64 mock-server:1.0.0 "/bin/bash" About a minute ago Up 11 seconds 0.0.0.0:7001->7001/tcp mock-server
  5. 0d440be90935 mongo "docker-entrypoint.s…" 24 hours ago Up 24 hours 0.0.0.0:27017->27017/tcp mock-mongo

由于前端独立部署的原因,我们需要修改nginx的配置,修改nginx的配置的方式有以下几种

在建立容器是使用-v指令将配置文件挂载到本地主机,在本地修改后在容器重启nginx

将配置文件复制到本地主机,修改后替换容器的对应文件,然后再容器内重启nginx

...

</>复制代码

  1. 我们当前操作环境是17版 15寸macbook pro,挂载需要特殊配置,因此我才用了第二种方式

配置文件修改

容器内配置文件路径 /etc/nginx/conf.d/default.conf

拷贝配置文件至本地

</>复制代码

  1. $ docker cp mock-nginx:/etc/nginx/conf.d/default.conf ~/nginx/default.conf

在nginx配置文件增加以下配置

</>复制代码

  1. server {
  2. location /mock-api/ {
  3. # node 为指令服务端容器别名
  4. proxy_pass http://node:7001/;
  5. }
  6. location /mock {
  7. autoindex on;
  8. alias /root/dist;
  9. }
  10. }

覆盖容器内配置并重启nginx

</>复制代码

  1. $ docker cp ~/nginx/default.conf mock-nginx:/etc/nginx/conf.d/default.conf
  2. # 进入容器
  3. $ docker exec -it mock-nginx /bin/bash
  4. # 重启nginx,看到以下提示则表示重启成功
  5. $ nginx -s reload
  6. 2018/11/03 17:23:14 [notice] 68#68: signal process started

接下来就到了我们的最后激动人心的最后一步

修改我们前端项目请求的网络域名并打包上传

</>复制代码

  1. // api-mocker/client/config
  2. // module.exports > build > serverRoot
  3. module.exports = {
  4. build: {
  5. serverRoot: "127.0.0.1:90/mock-api"
  6. }
  7. }

将打包后的dist文件上传至nginx配置的/root/dist目录下

</>复制代码

  1. $ docker cp ~/Sites/api-mocker/client/dist mock-nginx:/root

</>复制代码

  1. 当然nginx的容器构建也可以编写一个dockfile文件来实现,这里我们就不详细说明了,挂载配置文件和日志至本地主机有兴趣的可以自己尝试一下

测试

所有惊心动魄的配置我们都已经完成,现在我们来测试一下

访问前端项目: http://127.0.0.1:90/mock
我们会看到,以下界面说明我们前端项目部署成功

我们尝试注册一个账号,看到成功提示,那就说明我们整个项目部署成功了


</>复制代码

  1. 至此我们的部署就已经大功告成了,可以开心的mock接口写项目了,撒花~~~
总结

第一次写文章、第一次这样部署都是艰难的,自己整理了一下思路,也希望能给大家带来一些帮助
最后附上自己整理的docker常用命令以及该项目使用配置文件
觉得有用的可以star下咯
不早了 晚安~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/27515.html

相关文章

  • 记录次被docker容器通信死去活来部署之路node + mongoDB + nginx

    摘要:原因是这样的想要部署一个平台,就在朋友的推荐下选择了这个现成的项目该项目分为服务端客户端以及数据库在尝试直接部署的时候发现需要装一大堆的环境,啊,特别的麻烦,之前简单的使用过,就在想能不能用免环境直接部署呢于是就有了这次的尝试多容器通信该 原因是这样的 想要部署一个mocker平台,就在朋友的推荐下选择了api-mocker这个现成的项目 该项目分为服务端node、客户端vue、以及...

    amc 评论0 收藏0
  • 记录次被docker容器通信死去活来部署之路node + mongoDB + nginx

    摘要:原因是这样的想要部署一个平台,就在朋友的推荐下选择了这个现成的项目该项目分为服务端客户端以及数据库在尝试直接部署的时候发现需要装一大堆的环境,啊,特别的麻烦,之前简单的使用过,就在想能不能用免环境直接部署呢于是就有了这次的尝试多容器通信该 原因是这样的 想要部署一个mocker平台,就在朋友的推荐下选择了api-mocker这个现成的项目 该项目分为服务端node、客户端vue、以及...

    Rango 评论0 收藏0
  • 进军Docker 1.12,将代理与Swarm完美整合

    摘要:其一将用于代理与面向公开的服务之间的通信。数据库上线并开始运行后,我们接下来部署后端。现在,会帮助我们完成全部负载均衡工作。这样所有来自代理的请求都将指向网络,并由后者跨越全部实例执行负载均衡。 七夕大家过得怎么样?今天数人云带大家回归技术和干货。虽然我们能够在Swarm集群当中部署任意数量的服务,但这并不代表各项服务全部可为用户所访问。而新的Swarm网络使得各项服务之间能够更为轻松...

    cartoon 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<