1. 程式人生 > >Docker部署Node.js的方法步驟

Docker部署Node.js的方法步驟

前言

專案中會用到node做中間層,部署node則是用到了docker,在這裡總結、記錄下部署要點和步驟;關於docker的介紹和安裝這裡就不贅述了,網上也有很多相關的教程和文章了,需要可自行搜尋檢視。

專案結構

-- docker-node
  |-- data
  |-- server
    |-- app.js
    |-- Dockerfile
    |-- process.yml
    |-- package.json
  |-- docker-compose.yml
</pre>

1、建立Node.js程式

app.js

const express = require('express');
const app = express();
app.get('/', (req, res) => res.send('hello world!'));
</pre>
app.listen(3008);

2、建立Dockerfile

FROM node:8.9-alpine
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app
RUN npm set registry https://registry.npm.taobao.org/
RUN npm install
CMD ["./node_modules/pm2/bin/pm2-docker", "process.yml"]
</pre>

從Dockerfile中可以看到我們是通過pm2-docker執行node應用的,利用PM2我們可以監聽檔案變化,達到應用重啟、日誌分存等效果;這裡我們需要一個process.yml的配置檔案,相關用法可以檢視PM2文件。

process.yml

apps:

 - script : 'app.js'
  name  : 'dokcer-node'
  exec_mode: 'fork'
  watch : true
  instances: 1
  log_date_format : 'YYYY-MM-DD HH:mm Z'
  ignore_watch: ['node_modules']
</pre>

3、建立docker-compose.yml

生產環境上我們用到往往不只一個容器,我們可以通過一個配置檔案來管理多個Docker容器,然後使用docker-compose來啟動,停止、重啟應用。

docker-compose.yml

version: "3.0"
services:
 server_node:
  container_name: server-node
  build: 
   context: ./server
  volumes:
   - ./server:/usr/src/app
  ports:
   - "3008:3008"
  environment:
   - TZ=Asia/Shanghai

 portainer:
  image: portainer/portainer:1.11.4
  container_name: portainer
  expose:
   - "9000"
  ports:
   - "9000:9000"
  volumes:
   - /var/run/docker.sock:/var/run/docker.sock
   - ./data/portainer:/data
  environment:
   - TZ=Asia/Shanghai
</pre>

4、啟動容器

上述幾個檔案建立完畢,我們執行下面的命令,則會建立我們的映象並且啟動容器

$ docker-compose -f docker-compose.yml up -d

5、測試

1、訪問本地的3008埠

image

image

2、測試當代碼變化,node自動重啟功能,我們把"hello world!"改為"restart!!!!",再次重新整理頁面

image

image

3、利用Portainer管理容器;視覺化的介面相比命令列來說,我們可以很方便、快速檢視容器日誌、容器配置、狀態、以及對進行重啟、刪除等操作;我們訪問本地9000埠即可(docker-compese.yml中配置),結果如下。

image

image

以上就是本文的全部內容,希望對大家的學習有所幫助,

 

QQ圖片20181026133527.jpg