Docker搭建部署Node項目

来源:https://www.cnblogs.com/edwardloveyou/archive/2020/07/13/13293377.html
-Advertisement-
Play Games

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


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

什麼是Docker

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

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

客戶端Docker

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

Docker基本操作

鏡像名稱

關於鏡像標簽,比如nginx:1.19.0-alpine,1.19.0是 nginx 的版本號,alpine是os的代號。

Jessie: debian 8

Stretch: debian 9

Buster: debian 10

Alpine: Alpine,推薦使用,因為體積非常小

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

拉取鏡像

docker pull nginx:1.19.0-alpine

啟動容器

--name web:指定容器名稱為web

-p 8080:80: 容器nginx監聽埠為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

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

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

Docker-compose

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

首先需要docker-compose.yml配置文件,比如下麵就是兩個容器的模板,image表示使用的鏡像,ports則表示埠映射,volumes則是需要映射的數據捲:

version: "3"

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

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

docker-compose build [options] [SERVICE...] #構建(重新構建)項目中的服務容器
docker-compose up -d # 運行 compose 項目,後臺執行

docker-compose up 是個非常強大的命令,它將嘗試自動完成包括構建鏡像,(重新)創建服務,啟動服務,並關聯服務相關容器的一系列操作。鏈接的服務都將會被自動啟動,除非已經處於運行狀態。可以說,大部分時候都可以直接通過該命令來啟動一個項目。

構建nginx-node-postgres項目

有了上面的基礎,接著就可以構建我們自己的項目了,首先是node服務的dockerfile,主要做瞭如下步驟

  1. 創建容器工作目錄
  2. 複製相關配置文件到容器
  3. 在容器安裝npm
  4. 運行pm2啟動容器
FROM node:14.5.0-alpine3.12
# 工作目錄
WORKDIR /usr/src/app
# 複製配置文件
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

  1. db配置的是資料庫postgres,其中數據捲 volumes 映射了資料庫目錄和初始化腳步
  2. app配置的是node服務,其中的build是映射上面dockerfile所在的目錄;depends_on表示依賴的容器、啟動先後,這裡先啟動db再啟動nodelinks表示將db的名稱映射到app容器
  3. nginx容器depend_on於app容器,同時配置轉發node的服務
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 #始終重啟,生產環境中推薦配置為 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的轉發
      - app
    expose:
      - 8080

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

docker-compose up

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

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在前面隨筆介紹了ABP+Vue前後端的整合處理,包括介紹了ABP的後端設計,以及前端對ABP介面API的ES6的封裝,通過JS的繼承類處理,極大減少了重覆臃腫的代碼,可以簡化對後端API介面的封裝,而且前端使用Element組件,很好展示API獲得的數據,通過在界面中展示樹狀列表,以及表格列表數據,... ...
  • 01 興趣 興趣是學習的第一老師。如果打算進入IT行業,找到自己興趣所在是最好的。 很多小伙伴對前後端分得不是很清楚,確認興趣方式如下: 通過網路視頻資源短期學習 線下培訓機構申請短期試學 一部分小伙伴試學後仍然感覺前後端差不多,很難判斷自己的興趣是前端還是後端。在這裡“興趣”的定義不是試學後滿心歡 ...
  • WEB學習路線2020完整版+附視頻教程,適合初學者的最新WEB前端學習路線彙總! ...
  • 以下純屬個人觀點和建議,肯定是有局限性的,但是也希望能給你帶來一些幫助。 我們儼然能感受到前端崗位現在已經發展成了最重要的研發崗位之一,所以多我們提出的要求也就越來越高了。所以我們需要的也就不僅僅只是掌握css、html、JavaScript了,但是這三大件一直都是前端的根本,這一點從未改變,而這三 ...
  • 1. 引言 1.1. 背景 隨著時代的進步,社會的發展,人們的生活形式與習慣也越來越多樣化,出行成為了人們生活中的一個重要組成部分,而客車成為許多人出行選擇的交通工具。面對巨大數量的乘客的購票需要,客車站就要選擇使用先進的管理方法來實現方便、快捷的售票、退票等方面的票務管理。隨著電腦的普及,信息處 ...
  • 動畫是將靜止的畫面變為動態的藝術.實現由靜止到動態,主要是靠人眼的視覺殘留效應。視覺殘留也叫視覺暫留現象,物體在快速運動時, 當人眼所看到的影像消失後,人眼仍能繼續保留其影像0.1~0.4秒左右的圖像,這種現象被稱為視覺暫留現象。利用人的這種視覺生理特性可製作出具有高度想象力和表現力的動畫影片。 電 ...
  • 一、 引言 對於一個多人團隊來說,制定一個統一的規範是必要的,因為個性化的東西無法產生良好的聚合效果,規範化可以提高編碼工作效率,使代碼保持統一的風格,以便於代碼整合和後期維護。 二、 HTML/CSS規範 2.1 瀏覽器相容 根據公司業務要求而定,一般:主流程測試:Chrome 30+、IE9+; ...
  • 結構型模式 適配器模式 類適配器和對象適配器 結構型模式 結構型模式的重點在於如何通過靈活的體系組織不同的對象,併在此基礎上完成更為複雜的類型(或者類型系統),而參與組合的各類型之間始終保持儘量鬆散的結構關係。 結構型模式包括以下幾種: 適配器模式 橋接模式 組合模式 裝飾模式 外觀模式 享元模式 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...