首頁  >  文章  >  web前端  >  Docker部署Node.js的詳細流程

Docker部署Node.js的詳細流程

不言
不言轉載
2018-11-26 14:24:092434瀏覽

這篇文章帶給大家的內容是關於php佇列的實作程式碼介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

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

專案結構

-- docker-node
  |-- data
  |-- server
    |-- app.js
    |-- Dockerfile
    |-- process.yml
    |-- package.json
  |-- docker-compose.yml

1、建立Node.js程式

app.js

const express = require('express');
const app = express();
app.get('/', (req, res) => res.send('hello world!'));
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"]
從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']

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

4、啟動容器

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

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

5、測試

1、存取本機的3008埠

Docker部署Node.js的詳細流程

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

Docker部署Node.js的詳細流程

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

Docker部署Node.js的詳細流程

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

#

以上是Docker部署Node.js的詳細流程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除