您好,登錄后才能下訂單哦!
本篇內容介紹了“怎么使用Docker高效部署Node應用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
一個簡單的 Node 應用
「index.js」
一個 hello, world 版的 Node Web App
const http = require('http') const app = async (req, res) => { res.end('hello, world') } http.createServer(app).listen(3000, () => console.log(3000))
「package.json」
配置 npm start 來啟動應用
"scripts": { "start": "node index.js" },
但這僅僅是最簡單的 Node 應用,真實環境中還有各種數據存儲及定時任務調度等,暫撇開不談,這已經足夠了。
再稍微復雜一點點的 Node 應用可以查看山月的項目 whoami[5]: 一個最簡化的 serverless 與 dockerize 示例。
NODE_ENV=production
在生產環境中,無需安裝 devDependecies 中依賴,NODE_ENV 環境變量設置為 production 時將會跳過 devDep。
# 通過設置環境變量,只安裝生產環境依賴 $ NODE_ENV=production npm ci # 通過顯式指定 flag,只安裝生產環境依賴 $ npm ci --production
另一方面,某些第三方模塊會根據 NODE_ENV 環境變量做出一些意料不到的配置。因此在生產環境注意該環境變量的配置。
一個 Node 應用的簡單部署
一個典型的、面向服務端的 Node 應用是這么跑起來的:
npm install
npm run config,從配置服務(consul/vault)拉取配置 ,如數據庫與緩存的賬號密碼,此時構建服務器需要配置服務權限
npm run migrate,數據庫遷移腳本,執行數據庫表列行更改操作,此時構建服務器需要數據庫訪問權限
npm start,啟動一個 Node 服務
把運行步驟翻譯為 Dockerfile:
# 選擇一個體積小的鏡像 (~5MB) FROM node:12-alpine # 環境變量設置為生產環境 ENV NODE_ENV production WORKDIR /code # 更好的根據 Image Layer 利用緩存 ADD package.json package-lock.json /code RUN npm ci ADD . /code # 配置服務及數據庫遷移 RUN npm run config --if-present && npm run migrate --if-present EXPOSE 3000 CMD npm start
這對于大部分 Node 應用已經是足夠了,如果精益求精,可以再走接下來的多階段構建
node-gyp 與 Native Addon
在 Node 中有可能存在著一些 Native Addon,它們通過 node-gyp 進行編譯,而它依賴于 python,make 與 g++。
$ apk --no-cache add python make g++
在帶有編譯過程的鏡像構建中,源文件與構建工具都會造成空間的浪費。借助鏡像的「多階段構建」可以高效利用空間。Go App 與 FE App 的構建也遵循此規則。
多階段構建 Go 應用[6]
多階段構建前端應用[7]
在構建 Node 應用鏡像時,第一層鏡像用以構造 node_modules。
# 選擇一個體積小的鏡像 (~5MB) FROM node:12-alpine as builder # 環境變量設置為生產環境 ENV NODE_ENV production # 更好的根據 Image Layer 利用緩存 ADD package.json package-lock.json ./ RUN npm ci # 多階段構建之第二階段 # 多階段構建之第二階段 # 多階段構建之第二階段 FROM node:12-alpine WORKDIR /code ENV NODE_ENV production ADD . . COPY --from=builder node_modules node_modules # 配置服務及數據庫遷移 RUN npm run config --if-present && npm run migrate --if-present EXPOSE 3000 CMD npm start
“怎么使用Docker高效部署Node應用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。