記錄一次被docker多容器通訊虐的死去活來的部署之路(node + mongoDB + nginx)

緣由是這樣的

  • 想要部署一個mocker平臺,就在朋友的推薦下選擇了api-mocker這個現成的項目
  • 該項目分爲服務端node、客戶端vue、以及數據庫mongoDB
  • 在嘗試直接部署的時候發現須要裝一大堆的環境,node、mongo、nginx啊,特別的麻煩,以前簡單的使用過docker,就在想能不能用docker免環境直接部署呢?因而就有了此次的嘗試

多容器通訊

  • 該項目分爲3個部分,因而就要創建3個容器(node、mongo、nginx)
  • 那容器之間怎麼實現通訊呢?javascript

    # 經過link指令創建鏈接
     $ docker run --name <Name> -d -p <path1>:<path2> --link <containerName>:<alias> <containerName:tag/imageID>
    • --link 容器鏈接指令
    • < containerName > : < alias >
    • < 被鏈接容器名稱 > : < 容器訪問別名 >
    • 注:別名在主動創建鏈接的容器中訪問被鏈接容器使用
    • 如下指令在容器檢測鏈接狀態前端

      $ curl <alias>

接下來咱們開始嘗試部署

實現過程

一、構建mongo容器
二、構建node容器並與mongo容器創建鏈接
三、構建nginx容器並與node容器創建鏈接vue

構建mongo容器

  • 咱們先拉取mongo鏡像java

    $ docker pull mongo:latest
    $ docker images
     REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
     mongo               latest              05b3651ee24e        2 weeks ago         382MB
  • 下面咱們讓這個鏡像跑起來node

    $ docker run --name mock-mongo -d -p 27017:27017 mongo:latest --auth
     # 須要與本地創建文件共享,則使用一下-v指令
     # -v /data/db:/data/db
    --auth 指令開啓了mongo的鏈接身份校驗
    開啓校驗 是因爲 node 跨容器鏈接時 不設置身份校驗 開啓服務端沒法鏈接上mongo數據庫
    nodejs.MongoError: [egg-mongoose]Authentication failed.
  • 查看容器nginx

    $ docker ps -a
     CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                      PORTS                      NAMES
     0d440be90935        mongo               "docker-entrypoint.s…"   14 hours ago        Up 14 hours                 0.0.0.0:27017->27017/tcp   mock-mongo
  • 因爲咱們mongo開啓了身份驗證,因此咱們要進入mongo容器配置一下node鏈接時使用的帳號git

    $ docker exec -it mock-mongo /bin/bash
     $ mongo admin
     # 建立manager user
     $ db.createUser({user:"admin", pwd:"admin",roles:[{role:"admin",db:"admin"}]})
     # 帳號受權
     $ db.auth('admin','admin')
如今咱們的mongo數據庫已經跑起來了,接下來咱們就要創建node容器了

構建node容器並與mongo容器創建鏈接

  • 在開始構建node容器前咱們要先約定好mongo容器別名,端口號以及登陸帳號密碼github

    • mongo容器別名:db
    • mongo端口號:27017
    • 帳號密碼:admin:admin
  • 咱們先修改node服務端的配置mongodb

    文件配置 dockerfile/api-mocker/server/config/config.default.js
    修改mongo鏈接配置,db爲預先設定的mock-mongo容器的別名
    mongoose: {
        url: 'mongodb://admin:admin@db:27017/api-mock?authSource=admin'
      },
  • 如今咱們編寫一個Dockerfile文件來構建鏡像docker

    # 指定基礎鏡像
      FROM node:latest
        
      # 維護者
      MAINTAINER qiushiyuan1994@qq.com
        
      # 工做目錄
      WORKDIR /www
        
      # 將本地文件添拷貝到容器中,不會解壓
      COPY api-mocker node-server/api-mocker
        
      EXPOSE 7001
        
      WORKDIR /www/node-server/api-mocker/server
        
      RUN npm install
        
      WORKDIR /www/node-server/api-mocker
        
      # 構建容器後調用,在容器啓動時才進行調用
      CMD ["make", "prod_server"]
  • 咱們使用編寫好的dockerfile文件構建鏡像

    $ docker build -t="mock-server:1.0.0" .
  • 讓咱們查看一下鏡像

    $ docker images
     REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
     mock-server         1.0.0               957ad2aa1f97        8 minutes ago       674MB
     mongo               latest              05b3651ee24e        2 weeks ago         382MB
  • 如今就到了關鍵的一步,咱們將mocker-server鏡像運行起來,並創建服務器與數據庫的鏈接

    $ docker run -d -i -t -p 7001:7001 --name mock-server1 --link mock-mongo:db mock-server:1.0.0 /bin/bash
  • 讓咱們再看看如今正在運行的容器

    $ docker ps
     CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS                      NAMES
     ee780b903c64        mock-server:1.0.0   "/bin/bash"              About a minute ago   Up 11 seconds       0.0.0.0:7001->7001/tcp     mock-server
     0d440be90935        mongo               "docker-entrypoint.s…"   16 hours ago         Up 16 hours         0.0.0.0:27017->27017/tcp   mock-mongo
  • 檢測node容器和mongo容器的鏈接狀態

    $ docker exec -it mock-server /bin/bash
     $ curl db
如今咱們的服務端和數據庫已經創建起了鏈接,接下來咱們要開始部署咱們的客戶端

構建nginx容器並與node容器創建鏈接

  • 在創建nginx前,咱們要先約定好,node容器別名,nginx轉發的端口號以及客戶端訪問nginx域名及端口號

    • node服務器別名:node
    • node容器映射的端口號:7001
    • nginx域名:127.0.0.1
    • nginx端口號:90
  • 咱們先拉取nginx鏡像並創建容器

    $ docker pull nginx:latest
    $ docker run -p 90:80 --link mock-node:node nginx:latest --name mock-nginx
    # 查看容器鏈接狀態
    $ docker exec -it mock-nginx /bin/bash
    $ env
    # 看到如下數據則表示鏈接成功了
    NODE_PORT_7001_TCP=tcp://172.17.0.3:7001
    NODE_PORT_7001_TCP_PORT=7001
    NODE_ENV_YARN_VERSION=1.9.4
  • 如今咱們在看看已經運行中的容器

    $ docker ps
       CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                      NAMES
       09644025d148        nginx               "nginx -g 'daemon of…"   5 hours ago         Up 5 hours          0.0.0.0:90->80/tcp         mock-nginx
       ee780b903c64        mock-server:1.0.0   "/bin/bash"              About a minute ago   Up 11 seconds      0.0.0.0:7001->7001/tcp     mock-server
       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
    • ...

      咱們當前操做環境是17版 15寸macbook pro,掛載須要特殊配置,所以我才用了第二種方式
  • 配置文件修改

    • 容器內配置文件路徑 /etc/nginx/conf.d/default.conf
    • 拷貝配置文件至本地

      $ docker cp mock-nginx:/etc/nginx/conf.d/default.conf ~/nginx/default.conf
    • 在nginx配置文件增長如下配置

      server {
         location /mock-api/ {
             # node 爲指令服務端容器別名
             proxy_pass http://node:7001/;
         }
      
         location /mock {
           autoindex on;
           alias /root/dist;
         }
      }
    • 覆蓋容器內配置並重啓nginx

      $ docker cp ~/nginx/default.conf mock-nginx:/etc/nginx/conf.d/default.conf
      # 進入容器
      $ docker exec -it mock-nginx /bin/bash
      # 重啓nginx,看到如下提示則表示重啓成功
      $ nginx -s reload
      2018/11/03 17:23:14 [notice] 68#68: signal process started
    • 接下來就到了咱們的最後激動人心的最後一步
    • 修改咱們前端項目請求的網絡域名並打包上傳

      // api-mocker/client/config 
      // module.exports > build > serverRoot
      
      module.exports = {
          build: {
              serverRoot: '127.0.0.1:90/mock-api'
          }
      }
    • 將打包後的dist文件上傳至nginx配置的/root/dist目錄下

      $ docker cp ~/Sites/api-mocker/client/dist mock-nginx:/root
      固然nginx的容器構建也能夠編寫一個dockfile文件來實現,這裏咱們就不詳細說明了,掛載配置文件和日誌至本地主機有興趣的能夠本身嘗試一下

測試

  • 全部驚心動魄的配置咱們都已經完成,如今咱們來測試一下
  • 訪問前端項目: http://127.0.0.1:90/mock
    咱們會看到,如下界面說明咱們前端項目部署成功

    clipboard.png

  • 咱們嘗試註冊一個帳號,看到成功提示,那就說明咱們整個項目部署成功了

    clipboard.png
    clipboard.png

至此咱們的部署就已經大功告成了,能夠開心的mock接口寫項目了,撒花~~~

總結

第一次寫文章、第一次這樣部署都是艱難的,本身整理了一下思路,也但願能給你們帶來一些幫助
最後附上本身整理的docker經常使用命令以及該項目使用配置文件以爲有用的能夠star下咯不早了 晚安~

相關文章
相關標籤/搜索