濮阳杆衣贸易有限公司

主頁 > 知識庫 > Docker搭建部署Node項目的方法步驟

Docker搭建部署Node項目的方法步驟

熱門標簽:撫順移動400電話申請 藍點外呼系統(tǒng) 威海人工外呼系統(tǒng)供應(yīng)商 在百度地圖標注車輛 做外呼系統(tǒng)的公司違法嗎 寧夏房產(chǎn)智能外呼系統(tǒng)要多少錢 烏海智能電話機器人 貴陽教育行業(yè)電話外呼系統(tǒng) 400電話申請方案

前段時間做了個node全棧項目,服務(wù)端技術(shù)棧是 nginx + koa + postgresql。其中在centos上搭建環(huán)境和部署都挺費周折,部署測試服務(wù)器,接著上線的時候又部署生產(chǎn)環(huán)境服務(wù)器。這中間就有很多既無聊又費精力,吃力不討好的"體力活"。所以就開始思考怎么自動化這部分搭建部署的工作,也就引出了Docker。

什么是Docker

Docker 是比虛擬機還要輕量級的虛擬化技術(shù),它虛擬化的實體就叫做容器。容器本身就是一個隔離了作用域的sandbox,同時它只包含了基礎(chǔ)庫和本身承載的服務(wù),非常精簡。容器運行起來后就只是宿主機中的一個進程而已,占用的資源是非常小的,這就為操作系統(tǒng)上運行容器集群創(chuàng)造了條件,可操作性和靈活性極佳。

鏡像和容器又是什么關(guān)系呢?可以把鏡像看成是類(class),容器看成對象(object),容器是由鏡像實例化產(chǎn)生出來的,當然一個鏡像可以生成多個容器。

客戶端Docker

如果不在服務(wù)器,我們在客戶端要怎么使用 Docker呢?在 Windows 和 OSX 上可以使用 Docker Desktop,再加上Kitematic,這兩個都是桌面管理工具,常規(guī)的操作方面非常便利。Docker Desktop 和 Kitematic 只是可視化了部分操作,命令行還是必備的,因為很多操作也只能命令行才行。

Docker基本操作

鏡像名稱

關(guān)于鏡像標簽,比如nginx:1.19.0-alpine,1.19.0是 nginx 的版本號,alpine是os的代號。

  • Jessie: debian 8
  • Stretch: debian 9
  • Buster: debian 10
  • Alpine: Alpine,推薦使用,因為體積非常小

Alpine 是體積最小的一個版本,有些甚至是其他版本的四分之一。這意味著構(gòu)建鏡像更快,運行效率更高,因為加載的組件更加少,無形中也意味著漏洞更少更安全。

拉取鏡像

docker pull nginx:1.19.0-alpine

啟動容器

  • --name web:指定容器名稱為web
  • -p 8080:80: 容器nginx監(jiān)聽端口為80,映射到本地端口8080
  • -v xxxx:xxxx:這里是用本地配置文件映射到容器nginx配置文件
  • -d:后臺運行
  • nginx:1.19.0-alpine:使用的鏡像
docker run --name web -p 8080:80 -v /usr/etc/nginx/nginx.conf:/etc/nginx/nginx.conf:ro -d nginx:1.19.0-alpine

其他操作

  • docker images #顯示鏡像
  • docker rmi xxx #刪除鏡像
  • docker ps #顯示運行的容器
  • docker rm xxx #刪除容器

Dockerfile

構(gòu)建鏡像比較方便的是使用Dockerfile,它就是鏡像的配置文件,只要有Dockerfile,隨時可以構(gòu)建鏡像。如下就是構(gòu)建一個非常簡單的nginx鏡像,from就是構(gòu)建時使用的基礎(chǔ)鏡像:

FROM nginx
COPY nginx.conf /etc/nginx/nginx.conf

Docker-compose

當我們的項目不僅只有單個容器,而是需要運行多個容器,而且容器之間還需要互相通信的時候,就需要更強大的管理工具了。比如k8s,但我們目前的小項目使用官方自帶的Docker-compose已經(jīng)足矣。

首先需要docker-compose.yml配置文件,比如下面就是兩個容器的模板,image表示使用的鏡像,ports則表示端口映射,volumes則是需要映射的數(shù)據(jù)卷:

version: "3"

services:
  webapp:
    image: web
    ports:
      - "8080:80"
    volumes:
      - "/data"
  redis:
    image: "redis:alpine"

接著可以使用以下命令行進行操作:

docker-compose build [options] [SERVICE...] #構(gòu)建(重新構(gòu)建)項目中的服務(wù)容器
docker-compose up -d # 運行 compose 項目,后臺執(zhí)行

docker-compose up 是個非常強大的命令,它將嘗試自動完成包括構(gòu)建鏡像,(重新)創(chuàng)建服務(wù),啟動服務(wù),并關(guān)聯(lián)服務(wù)相關(guān)容器的一系列操作。鏈接的服務(wù)都將會被自動啟動,除非已經(jīng)處于運行狀態(tài)??梢哉f,大部分時候都可以直接通過該命令來啟動一個項目。

構(gòu)建nginx-node-postgres項目

有了上面的基礎(chǔ),接著就可以構(gòu)建我們自己的項目了,首先是node服務(wù)的dockerfile,主要做了如下步驟

  • 創(chuàng)建容器工作目錄
  • 復(fù)制相關(guān)配置文件到容器
  • 在容器安裝npm包
  • 運行pm2啟動容器
FROM node:14.5.0-alpine3.12
# 工作目錄
WORKDIR /usr/src/app
# 復(fù)制配置文件
COPY package*.json ./
COPY process.yml ./
RUN npm set registry https://registry.npm.taobao.org/ \

  && npm install pm2 -g \

  && npm install
# 使用pm2管理
CMD ["pm2-runtime", "process.yml", "--only", "app", "--env", "production"]
EXPOSE 3010

接著配置 docker-compose.yml

  • db配置的是數(shù)據(jù)庫postgres,其中數(shù)據(jù)卷 volumes 映射了數(shù)據(jù)庫目錄和初始化腳步
  • app配置的是node服務(wù),其中的build是映射上面dockerfile所在的目錄;depends_on表示依賴的容器、啟動先后,這里先啟動db再啟動node;links表示將db的名稱映射到app容器
  • nginx容器depend_on于app容器,同時配置轉(zhuǎn)發(fā)node的服務(wù)
version: '3'

services:
  db:
    image: postgres:12.3-alpine
    container_name: postgres
    environment:
      - TZ=Asia/Shanghai
      - POSTGRES_PASSWORD=xxxx
    volumes:
      - ./postgres/data:/var/lib/postgresql/data
      - ./postgres/init:/docker-entrypoint-initdb.d
    ports:
      - 5432:5432
    restart: always #始終重啟,生產(chǎn)環(huán)境中推薦配置為 always
    expose:
      - 5432
      
  app: 
    image: koa-pg
    container_name: koa
    volumes:
      - ./dist:/usr/src/app/dist
      - ./logs:/usr/src/app/logs
    build: ./
    environment:
      - TZ=Asia/Shanghai
    restart: always
    depends_on:
      - db
    links:
      - db
    expose:
      - 3010
      
  nginx:
    image: nginx:1.19.0-alpine
    container_name: nginx
    volumes:
      - ./nginx.conf:/etc/nginx/nginx.conf
    ports:
      - 8080:80
    environment:
      - TZ=Asia/Shanghai
    restart: always
    depends_on:
      - app
    links: # host名代替ip配置nginx的轉(zhuǎn)發(fā)
      - app
    expose:
      - 8080

配置完我們的項目之后,接著就是運行起來

docker-compose up

在我們的本地開發(fā)機是如此,部署到服務(wù)器也是如此,你想要部署幾臺服務(wù)器就部署幾臺,只要裝了docker,都是一句命令行就能解決的事情。

要啟動幾個容器,修改下docker-compose.yml的配置,再次docker-compose up,so easy !

到此這篇關(guān)于Docker搭建部署Node項目的方法步驟的文章就介紹到這了,更多相關(guān)Docker搭建部署Node 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標簽:泰州 蕪湖 周口 松原 銅川 那曲 慶陽 朝陽

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Docker搭建部署Node項目的方法步驟》,本文關(guān)鍵詞  Docker,搭建,部署,Node,項,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Docker搭建部署Node項目的方法步驟》相關(guān)的同類信息!
  • 本頁收集關(guān)于Docker搭建部署Node項目的方法步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    环江| 三穗县| 卓尼县| 浦江县| 喜德县| 普格县| 东莞市| 宁德市| 成安县| 广水市| 板桥市| 永兴县| 华亭县| 汝阳县| 南涧| 遵义县| 孙吴县| 潮州市| 师宗县| 依安县| 灌南县| 应城市| 宁陵县| 横峰县| 岑溪市| 蕉岭县| 汉川市| 保靖县| 遂昌县| 霍邱县| 西丰县| 昌宁县| 汉寿县| 富裕县| 宁乡县| 本溪| 兰溪市| 马龙县| 清水县| 三江| 高阳县|