欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker搭建部署Node項(xiàng)目的方法步驟

 更新時(shí)間:2021年07月27日 11:29:28   作者:Jeff.Zhong  
本文主要介紹了Docker搭建部署Node項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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

什么是Docker

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

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

客戶端Docker

如果不在服務(wù)器,我們?cè)诳蛻舳艘趺词褂?Docker呢?在 Windows 和 OSX 上可以使用 Docker Desktop,再加上Kitematic,這兩個(gè)都是桌面管理工具,常規(guī)的操作方面非常便利。Docker Desktop 和 Kitematic 只是可視化了部分操作,命令行還是必備的,因?yàn)楹芏嗖僮饕仓荒苊钚胁判小?/p>

Docker基本操作

鏡像名稱

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

  • Jessie: debian 8
  • Stretch: debian 9
  • Buster: debian 10
  • Alpine: Alpine,推薦使用,因?yàn)轶w積非常小

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

拉取鏡像

docker pull nginx:1.19.0-alpine

啟動(dòng)容器

  • --name web:指定容器名稱為web
  • -p 8080:80: 容器nginx監(jiān)聽(tīng)端口為80,映射到本地端口8080
  • -v xxxx:xxxx:這里是用本地配置文件映射到容器nginx配置文件
  • -d:后臺(tái)運(yùn)行
  • 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 #顯示運(yùn)行的容器
  • docker rm xxx #刪除容器

Dockerfile

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

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

Docker-compose

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

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

version: "3"

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

接著可以使用以下命令行進(jìn)行操作:

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

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

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

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

  • 創(chuàng)建容器工作目錄
  • 復(fù)制相關(guān)配置文件到容器
  • 在容器安裝npm包
  • 運(yùn)行pm2啟動(dòng)容器
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ù)庫(kù)postgres,其中數(shù)據(jù)卷 volumes 映射了數(shù)據(jù)庫(kù)目錄和初始化腳步
  • app配置的是node服務(wù),其中的build是映射上面dockerfile所在的目錄;depends_on表示依賴的容器、啟動(dòng)先后,這里先啟動(dòng)db再啟動(dòng)node;links表示將db的名稱映射到app容器
  • nginx容器depend_on于app容器,同時(shí)配置轉(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

配置完我們的項(xiàng)目之后,接著就是運(yùn)行起來(lái)

docker-compose up

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

要啟動(dòng)幾個(gè)容器,修改下docker-compose.yml的配置,再次docker-compose up,so easy !

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

相關(guān)文章

  • 詳細(xì)講解Docker-Compose部署Kafka?KRaft集群環(huán)境

    詳細(xì)講解Docker-Compose部署Kafka?KRaft集群環(huán)境

    這篇文章主要為大家介紹了Docker-Compose部署Kafka?KRaft集群環(huán)境的全面詳細(xì)講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 一臺(tái)虛擬機(jī)基于docker搭建大數(shù)據(jù)HDP集群的思路詳解

    一臺(tái)虛擬機(jī)基于docker搭建大數(shù)據(jù)HDP集群的思路詳解

    這篇文章主要介紹了一臺(tái)虛擬機(jī)基于docker搭建大數(shù)據(jù)HDP集群?,本篇文章主要講了大數(shù)據(jù)集群搭建的架構(gòu)設(shè)計(jì)和實(shí)現(xiàn)思路部分,后面文章會(huì)探討上層應(yīng)用的構(gòu)建,需要的朋友可以參考下
    2022-11-11
  • docker保存鏡像到本地并加載本地鏡像文件詳解

    docker保存鏡像到本地并加載本地鏡像文件詳解

    平常我們下載docker鏡像會(huì)通過(guò)配置國(guó)內(nèi)源來(lái)加速下載,但是有時(shí)候會(huì)有另外的需求,比如某個(gè)機(jī)器不能聯(lián)網(wǎng),我們就需要從其他機(jī)器下載,打包后,拷貝到這個(gè)機(jī)器,下面這篇文章主要給大家介紹了關(guān)于docker保存鏡像到本地并加載本地鏡像文件的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • 詳解docker部署SpringBoot及替換jar包的方法

    詳解docker部署SpringBoot及替換jar包的方法

    這篇文章主要介紹了詳解docker部署SpringBoot及替換jar包的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Docker搭建青龍面板教程(圖文)

    Docker搭建青龍面板教程(圖文)

    青龍面板是一款用于管理和運(yùn)行腳本的Web界面,廣泛應(yīng)用于各類自動(dòng)化腳本的管理,本文主要介紹了Docker搭建青龍面板教程,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • Docker如何搭建私有鏡像倉(cāng)庫(kù)

    Docker如何搭建私有鏡像倉(cāng)庫(kù)

    這篇文章主要介紹了Docker如何搭建私有鏡像倉(cāng)庫(kù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 從docker鏡像里提取dockerfile的兩種方法

    從docker鏡像里提取dockerfile的兩種方法

    Dockerfile是用來(lái)構(gòu)建Docker鏡像的構(gòu)建文件,是由一系列命令和參數(shù)構(gòu)成的腳本,下面這篇文章主要給大家介紹了關(guān)于如何從docker鏡像里提取dockerfile的兩種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • Docker鏡像瘦身大小從1.43 GB減少到22.4MB

    Docker鏡像瘦身大小從1.43 GB減少到22.4MB

    本文主要介紹了 Docker鏡像瘦身大小從1.43 GB減少到22.4MB,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • docker compose自定義網(wǎng)絡(luò)實(shí)現(xiàn)固定容器ip地址

    docker compose自定義網(wǎng)絡(luò)實(shí)現(xiàn)固定容器ip地址

    這篇文章主要介紹了docker compose自定義網(wǎng)絡(luò)實(shí)現(xiàn)固定容器ip地址,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • k3d入門(mén)指南之在Docker中運(yùn)行K3s的詳細(xì)教程

    k3d入門(mén)指南之在Docker中運(yùn)行K3s的詳細(xì)教程

    在本文中,我們將簡(jiǎn)單了解k3d,這是一款可讓您在安裝了Docker的任何地方運(yùn)行一次性Kubernetes集群的工具,此外在本文中我們還將探討在使用k3d中可能會(huì)出現(xiàn)的一切問(wèn)題,感興趣的朋友跟隨小編一起看看吧
    2021-05-05

最新評(píng)論