中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用Docker Compose改善Node.js的開發

發布時間:2021-08-31 16:18:30 來源:億速云 閱讀:181 作者:chen 欄目:web開發

這篇文章主要介紹“如何使用Docker Compose改善Node.js的開發”,在日常操作中,相信很多人在如何使用Docker Compose改善Node.js的開發問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何使用Docker Compose改善Node.js的開發”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

在過去的幾年中,Docker和Node.js都變得非常流行。對于開發人員來說利用這些新技術來改善自己的開發體驗很有必要,而且在此過程中還

概述

本文中,我們以Express.js為一個示例展開,需要實現了解一丁點Node.js和npm的基礎知識。還要了解Express.js框架的基礎知識。

對Docker也要有一定的概念和要會基礎操作(不會也沒關系,很容易)。

如何使用Docker Compose改善Node.js的開發

最后本文全程使用Linux(Mac) shell終端命令行。

創建Express.js項目

為了要生成示范應用程序,需要使用Express應用程序生成器。需要運行以下npx命令行:

npx express-generator --view=pug --git <app-name>

Express生成器將生成Express應用。--view=pub選項表示使用pug視圖引擎。--git表示用來給項目添加一個git  .gitignore文件。

生成效果如下:

如何使用Docker Compose改善Node.js的開發

測試Express應用

要測試該應用程序,需要運行npm install安裝所有必需的npm模塊。然后,運行以下命令以啟動應用程序:

DEBUG=nodejs-docker-express:* npm start

如果沒有異常,應該會到一條類似的消息。

nodejs-docker-express:server Listening on port 3000

上面的命令非常簡單:它運行一個環境變量DEBUG=nodejs-docker-express,用來表示服務器進行詳細的調試。

對Windows系統,使用的參數要修改為:

set DEBUG=nodejs-docker-express:* & npm start

現在打開瀏覽器,在地址欄并輸入localhost:3000并訪問:

如何使用Docker Compose改善Node.js的開發

這樣示例的Express.js應用就已經在運行OK了。是不是非常簡單?有此基本的"Hello,World!"為基礎,我們進一步深入。

Docker多階段構建

容器化應用程序有很多好處:首先,無論運行平臺是什么,其行為都相同。借助Docker容器,應用程序可以輕松部署到各個公有容器云(比如AWS  Fargate,Google Cloud Run),自建的K8S集群中,甚至本地docker上。

容器化,基礎是Dockerfile。Dockerfile是構建Docker鏡像的基礎。用Dockerfile編譯生成的鏡像運行時,就稱之為容器。

如何使用Docker Compose改善Node.js的開發

如圖示,整個過程非常簡單:從Dockerfile構建Docker鏡像。運行鏡像,得到運行時容器。

Dockerfile

Dockerfile有一些類似命令行的語句:

FROM node:14-alpine as base WORKDIR /src COPY package*.json / EXPOSE 3000 FROM base as production ENV NODE_ENV=production RUN npm ci COPY . / CMD ["node", "bin/www"]  FROM base as dev ENV NODE_ENV=development RUN npm install -g nodemon && npm install COPY . / CMD ["nodemon", "bin/www"]

通過Docker鏡像的分層繼承,創建了一個精簡的production鏡像和一個功能更豐富,以開發為重點的dev鏡像。

在Dockerfile中,使用了多階段構建,整個過程分為三個階段:base,production和dev。production和dev依賴于base,base為node:14-alpine的基礎鏡像,該基礎鏡像需要從DockerHub獲取,這是一個官方Alpine基礎OS的Node.js官方鏡像,主鏡像為345MB,Node.js鏡像大概不到40M。

WORKDIR /src COPY package*.json / EXPOSE 3000

WORKDIR語句設置了Docker運行的工作目錄,其后的命令都在該工作目錄運行。COPY語句,復制package*.json(package.json和package-lock.json)容器中。

EXPOSE語句,設置Node.js Express Web服務器的監聽端口。上述步驟對于開發和生產階段都是通用的。

現在我們來看看生產目標階段是如何構建的。

production

在生產階段,繼續從基礎階段開始的工作,FROM語句指示Docker從base開始。ENV語句設置Docker將環境變量NODE_ENV為production。

FROM base as production ENV NODE_ENV=production RUN npm ci COPY . / CMD ["node", "bin/www"]

變量ENV設置為production可以使性能提高三倍,并且提供一些其他優化,比如緩存視圖。npm  install命令只會安裝主要依賴項,忽略開發依賴項。這些設置非常適合生產環境。

接著使用RUN語句運行npm ci而非npm install。npm ci適用于持續集成和部署。和npm  install相比,會繞過某些面向用戶的功能。當然,npm ci需要一個package-lock.json文件才能工作。

之后,還是使用COPY語句將代碼復制到工作目錄。

最后使用CMD語句,運行Node應用服務器和/srcbin/www

dev

我們利用了多階段構建,并在開發階段添加開發所需的組件:

FROM base as dev ENV NODE_ENV=development RUN npm install -g nodemon && npm install COPY . / CMD ["nodemon", "bin/www"]

大體上和生產極端類似,差異為NODE_ENV環境變量設置為development。

接著,用RUN語句安裝nodemon。每當文件更改時,nodemon都會重新啟動服務器,從而開發體驗更加流暢。同時執行npm  install,該命令會遞歸安裝dev依賴項。例如,如果要使用Jest測試應用程序,那將是開發依賴項之一。

請注意,這兩個命令通過&&放在一起,創建更少的Docker層,于構建緩存非常有用。這是撰寫Dockerfile時候常用的一個技巧。

和生產階段相同,將代碼復制到容器。但是,用nodemon取代了Node服務器,這樣在每次文件/src更改時會重新啟動它。

.dockerignore

和git的.gitignore一樣,docker也使用.dockerignore來忽略不想放入Docker鏡像的文件。通過忽略無關的文件更改,它有助于使Docker鏡像保持身材,而且能使構建緩存更高效。本示例中.dockerignore

.git node_modules

非常簡單,告訴Docker不COPY.git文件夾和node_modules從主機復制到Docker容器。

使用Docker Compose

到目前為止,我們創建一個使用運行Node.js Express應用程序Docker所需的大部分功能。為了更便捷,我們還建議用Docker  Compose,這樣可以更輕松地使用單個或多個容器運行應用程序。這樣也無需要記住很長的命令來構建或運行容器。只需通過:

docker-compose build docker-compose up

但是docker-compose使用yml的配置文件和dockerfile略有不同:

如何使用Docker Compose改善Node.js的開發

上述,我們指定Docker  Compose的版本,在本例中為3.8,對應Docker引擎19.0.3支持的最新版本。這樣可以支持多階段Docker構建。

接著,指定正在使用的服務。在本教程中,只有一個名為web的服務,具有context為當前目錄的構建以及一個重要的構建參數target設置為dev。這告訴Docker在dev階段構建Docker映像。

之后,通過volumes制定  Docker卷。它指示Docker從Docker容器上的./和主機本地/src目錄復制和同步更改。當我們在主機中更改文件時,這將很有用,并且文件也將立即反映到容器中。

command語句運行npm run start:dev,start:dev執行內容定義在package.json,內容為:

"start:dev": "nodemon ./bin/www"

表示使用nodemon啟動Web服務器。在開發環境中,可以在每次保存文件時重新啟動服務器。

接下來,用ports語句設置docker端口映射主機的3000端口與容器3000端口。在構建容器時,公開了端口3000,  Web服務器就會在3000上運行。

最后,設置了兩個環境變量。首先,將其NODE_ENV設置為development,因為這樣可以看到詳細的Debug信息,也沒有任何視圖緩存。然后,將debug設置為*,讓Web服務器打印出所有內容的詳細調試消息。

測試應用程序

前面,設置了弄好了基礎構建配置文件,接著構建Docker鏡像。使用BuildKit優化Docker構建。啟用BuildKit可以更快地構建Docker鏡像,運行以下命令:

COMPOSE_DOCKER_CLI_BUILD=1 DOCKER_BUILDKIT=1 docker-compose build

該命令告訴Compose在BuildKit上構建Docker鏡像。它應該在一段時間內運行并構建Docker鏡像,如下所示:

如何使用Docker Compose改善Node.js的開發

Docker鏡像大約在14秒內構建完成,使用BuildKit可以更快。運行該鏡像:

docker-compose up

如何使用Docker Compose改善Node.js的開發

然后瀏覽器訪問localhost:3000:

如何使用Docker Compose改善Node.js的開發

這樣我們,自配置的應用程序在Docker上已經完美運行。我們來改改源文件,看看效果。

我們修改下源碼將" Welcome to Express"更改為" Welcome to Express with  Docker"來測試。在源文件目錄/src下,找到routes/index.jsline文件,修改語句為:

res.render('index', { title: 'Express with Docker' });

保存文件,然后可以看到Web服務器已經重新啟動,表示Docker卷和nodemon可以都可以正常工作。

如何使用Docker Compose改善Node.js的開發

F5刷新瀏覽器,內容已經修改:

如何使用Docker Compose改善Node.js的開發

總結

本文中我們利用Docker和Docker  Compose構建了一個簡單的Nodejs的開發和運行環境。Node.js和docker的配合很好。通過使用docker-compose,開發體驗更加流暢。當然這這是一個很簡單的開始,對于更復雜的應用(比如需要訪問數據庫)才是Docker  Compose的用武之地,他可以同時啟動和管理多個容器,比如給開發環境增加Mongo或MySQL添加為應用程序的數據源,只需很輕松地增加一個docker-compose配置的服務語句就可以搞定整個環境。

到此,關于“如何使用Docker Compose改善Node.js的開發”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

秭归县| 贵溪市| 海兴县| 多伦县| 长葛市| 甘德县| 子洲县| 资中县| 龙里县| 苍溪县| 蒲城县| 巴东县| 客服| 临高县| 威信县| 洛宁县| 塘沽区| 扶沟县| 和硕县| 绥滨县| 正阳县| 祁阳县| 岐山县| 绍兴县| 雷山县| 赤水市| 黔西县| 丰原市| 博乐市| 淮南市| 牡丹江市| 霞浦县| 唐河县| 茌平县| 遂昌县| 庄河市| 林甸县| 台南县| 郴州市| 高阳县| 九龙县|