Docker部署Node.js的方法步驟
阿新 • • 發佈:2018-11-27
前言
專案中會用到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
2、測試當代碼變化,node自動重啟功能,我們把"hello world!"改為"restart!!!!",再次重新整理頁面
image
3、利用Portainer管理容器;視覺化的介面相比命令列來說,我們可以很方便、快速檢視容器日誌、容器配置、狀態、以及對進行重啟、刪除等操作;我們訪問本地9000埠即可(docker-compese.yml中配置),結果如下。
image
以上就是本文的全部內容,希望對大家的學習有所幫助,