Docker部署Node.js的方法步驟

前言node

項目中會用到node作中間層,部署node則是用到了docker,在這裏總結、記錄下部署要點和步驟;關於docker的介紹和安裝這裏就不贅述了,網上也有不少相關的教程和文章了,須要可自行搜索查看。

項目結構docker

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

一、建立Node.js程序express

app.js

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

二、建立Dockerfilenpm

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.ymljson

apps:app

 - 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>

三、建立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>

四、啓動容器ui

上述幾個文件建立完畢,咱們執行下面的命令,則會建立咱們的鏡像而且啓動容器

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

五、測試

一、訪問本地的3008端口

image

二、測試當代碼變化,node自動重啓功能,咱們把"hello world!"改成"restart!!!!",再次刷新頁面

image

三、利用Portainer管理容器;可視化的界面相比命令行來講,咱們能夠很方便、快速查看容器日誌、容器配置、狀態、以及對進行重啓、刪除等操做;咱們訪問本地9000端口便可(docker-compese.yml中配置),結果以下。

image

以上就是本文的所有內容,但願對你們的學習有所幫助,

相關文章
相關標籤/搜索