Doceker部署Node.js

前言

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

項目結構
`-- docker-node
    |-- data
    |-- server
        |-- app.js
        |-- Dockerfile
        |-- process.yml
        |-- package.json
    |-- docker-compose.yml

一、建立Node.js程序

app.jsdocker

const express = require('express');
const app = express();

app.get('/', (req, res) => res.send('hello world!'));

app.listen(3008);

二、建立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文檔express

process.ymlnpm

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

三、建立docker-compose.yml

生產環境上咱們用到每每不僅一個容器,咱們能夠經過一個配置文件來管理多個Docker容器,而後使用docker-compose來啓動,中止、重啓應用。json

docker-compose.ymlapp

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

四、啓動容器

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

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

五、測試

一、訪問本地的3008端口
圖片描述ui

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

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

相關文章
相關標籤/搜索