91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

使用docker部署前端應用的案例

發布時間:2021-02-05 11:30:45 來源:億速云 閱讀:146 作者:小新 欄目:服務器

小編給大家分享一下使用docker部署前端應用的案例,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

docker 變得越來越流行,它可以輕便靈活地隔離環境,進行擴容,方便運維管理。對開發者也更方便開發,測試與部署。
最重要的是, 當你面對一個陌生的項目,你可以照著 Dockerfile,甚至不看文檔(文檔也不一定全,全也不一定對)就可以很快讓它在本地跑起來。

現在很強調 devops 的理念,我把 devops 五個大字放在電腦桌面上,格物致知了一天。豁然開朗,devops 的意思就是寫一個 Dockerfile 去跑應用(開玩笑。

這里介紹如何使用 Docker 部署前端應用。千里之行,始于足下,足下的意思就是,先讓它能夠跑起來。

先讓它跑起來

首先,簡單介紹一下一個典型的前端應用部署流程

  1. npm install, 安裝依賴

  2. npm run build,編譯,打包,生成靜態資源

  3. 服務化靜態資源

介紹完部署流程后,簡單寫一個 Dockerfile

FROM node:alpine

# 代表生產環境
ENV PROJECT_ENV production
WORKDIR /code
ADD . /code
RUN npm install && npm run build && npm install -g http-server
EXPOSE 80

CMD http-server ./public -p 80

現在這個前端服務已經跑起來了。接下來你可以完成部署的其它階段了。一般情況下,以下就成了運維的工作了,不過,拓展自己的知識邊界總是沒錯的。

  • 使用 nginx 或者 traefik 做反向代理

  • 使用 kubernetes 或者 compose 等做編排。

  • 使用 gitlab ci 或者 drone ci 等做 CI/CD

這時鏡像存在有兩個問題,導致每次部署時間過長,不利于產品的快速交付

  • 構建鏡像時間過長

  • 構建鏡像大小過大,1G+

從 dependencies 和 devDependencies 下手

陸小鳳說過,一個前端程序員若是每天工作八個小時,至少有兩個小時是白白浪費了的。一個小時用來 npm install,另一個小時用來 npm run build。

對于每次部署,如果能夠減少無用包的下載,便能夠節省很多鏡像構建時間。eslint,mocha,chai 等代碼風格測試模塊可以放到 devDependencies 中。在生產環境中使用 npm install --production 裝包。

關于兩者的區別可以參考文檔 https://docs.npmjs.com/files/package.json.html#dependencies

FROM node:alpine

ENV PROJECT_ENV production
WORKDIR /code
ADD . /code
RUN npm install --production && npm run build && npm install -g http-server
EXPOSE 80

CMD http-server ./public -p 80

好像是快了那么一點點。

我們注意到,相對于項目的源文件來講,package.json 是相對穩定的。如果沒有新的安裝包需要下載,則再次構建鏡像時,無需重新裝包。則可以在 npm install 上節省一半的時間。

利用鏡像緩存

對于 ADD 來講,如果需要添加的內容沒有發生變化,則可以利用緩存。把 package.json 與源文件分隔開寫入鏡像是一個很好的選擇。目前,如果沒有新的安裝包更新的話,可以節省一半時間

FROM node:alpine

ENV PROJECT_ENV production

# http-server 不變動也可以利用緩存
RUN npm install -g http-server

WORKDIR /code

ADD package.json /code
RUN npm install --production

ADD . /code
RUN npm run build
EXPOSE 80

CMD http-server ./public -p 80

關于利用緩存有更多細節,需要特別注意一下,如 RUN git clone <repo> 的緩存此類

參考官方文檔 https://docs.docker.com/develop/develop-images/dockerfile_best-practices/#leverage-build-cache

多階段構建

得益于緩存,現在鏡像構建時間已經快了不少。但是,鏡像的體積依舊過于龐大,也會增加每次的部署時間
考慮下每次 CI 部署的流程

  1. 在構建服務器構建鏡像

  2. 把鏡像推至鏡像倉庫服務器,

  3. 在生產服務器拉取鏡像,啟動容器

顯而易見,鏡像體積過大造成傳輸效率低下,增加每次部署的延時。

即使,構建服務器與生產服務器在同一節點下,沒有延時的問題。減少鏡像體積也能夠節省磁盤空間

關于鏡像體積的過大,很大一部分是因為node_modules 臭名昭著的體積

使用docker部署前端應用的案例

但最后我們只需要 public 文件夾下的內容,對于源文件以及node_modules下文件,占用體積過大且不必要,造成浪費。
此時可以利用 Docker 的多階段構建,僅來提取編譯后文件

參考官方文檔 https://docs.docker.com/develop/develop-images/multistage-build/

FROM node:alpine as builder

ENV PROJECT_ENV production

# http-server 不變動也可以利用緩存
WORKDIR /code

ADD package.json /code
RUN npm install --production

ADD . /code
RUN npm run build

# 選擇更小體積的基礎鏡像
FROM nginx:alpine
COPY --from=builder /code/public /usr/share/nginx/html

此時,鏡像體積從 1G+ 變成了 50M+

使用 CDN

分析一下 50M+ 的鏡像體積,nginx:alpine 的鏡像是16M,剩下的40M是靜態資源。

如果把靜態資源給上傳到 CDN,則沒有必要打入鏡像了,此時鏡像大小會控制在 20M 以下

關于靜態資源,可以分類成兩部分

  • /static,此類文件在項目中直接引用根路徑,打包時復制進 /public 下,需要被打入鏡像

  • /build,此類文件需要 require 使用,會被 webpack 打包并加 hash 值,并可以通過 publicPath 修改資源地址。可以把此類文件上傳至 cdn,并加上永久緩存,不需要打入鏡像

FROM node:alpine as builder

ENV PROJECT_ENV production

# http-server 不變動也可以利用緩存
WORKDIR /code

ADD package.json /code
RUN npm install --production

ADD . /code
# npm run uploadCdn 是把靜態資源上傳至 cdn 上的腳本文件
RUN npm run build && npm run uploadCdn


# 選擇更小體積的基礎鏡像
FROM nginx:alpine
COPY --from=builder code/public/index.html code/public/favicon.ico /usr/share/nginx/html/
COPY --from=builder code/public/static /usr/share/nginx/html/static

看完了這篇文章,相信你對“使用docker部署前端應用的案例”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

宁陵县| 陇西县| 奈曼旗| 安陆市| 泸州市| 澳门| 田东县| 东港市| 洛扎县| 金门县| 延安市| 广灵县| 通河县| 宁海县| 福安市| 惠东县| 澄迈县| 五家渠市| 佳木斯市| 大安市| 东乌珠穆沁旗| 项城市| 正阳县| 内江市| 巴南区| 保康县| 土默特右旗| 辰溪县| 林州市| 静海县| 陆川县| 浑源县| 沈丘县| 金昌市| 九江市| 申扎县| 抚顺市| 聊城市| 惠水县| 沙雅县| 锡林浩特市|