99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Nodejs應(yīng)用編譯構(gòu)建提速建議

OSC開源社區(qū) ? 來源:OSCHINA 社區(qū) ? 2023-06-01 09:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

為什么在本地構(gòu)建就快,但編譯機上很慢

在編輯機上每次的構(gòu)建環(huán)境都是全新的,完成一次構(gòu)建比本地需要多一些步驟:

現(xiàn)成的全局包緩存 VS 重新構(gòu)建緩存: 咱可以先簡單理解為咱使用 npm 的時候那個全局的緩存目錄,編輯機需要準(zhǔn)備持久化的緩存的環(huán)境,包括下載、掛載以重建緩存,如果緩存內(nèi)容過大,時間也會相對更長,本地構(gòu)建直接使用了穩(wěn)定的本地文件系統(tǒng);

增量安裝依賴 VS 全量安裝依賴: 本地不太經(jīng)常需要執(zhí)行 install 的過程,即使需要,也因為有持久的 node_modules 目錄存在,不需要全量安裝,但編輯機環(huán)境每次需要重新安裝這個項目需要的所有依賴;

增量構(gòu)建 VS 全量構(gòu)建: 本地構(gòu)建默認(rèn)會將構(gòu)建緩存放到 node_modules 目錄下,第二次構(gòu)建的時候這些構(gòu)建就能被用起來,使得后面的構(gòu)建更快,但這個構(gòu)建的默認(rèn)緩存位置在編輯機上不會被持久化,也就是每次需要全量構(gòu)建.

網(wǎng)絡(luò)環(huán)境: 有些依賴包安裝依賴外部網(wǎng)絡(luò)甚至海外網(wǎng)絡(luò),本地的網(wǎng)絡(luò)環(huán)境比較順暢,但編輯機的網(wǎng)絡(luò)對與海外網(wǎng)的訪問沒有保證.

難以利用的優(yōu)勢: 多核大內(nèi)存,nodejs 項目的構(gòu)建,大部分工作都在一個線程上執(zhí)行了,不好直接利用編譯機的多核優(yōu)勢

額外的步驟: 編譯機需要下載鏡像、制作并上傳運行鏡像、緩存內(nèi)容持久化,而本地一般只是產(chǎn)出包.

所以從以上角度入手,我們可以基于這樣的一些思路進(jìn)行構(gòu)建速度的優(yōu)化:

優(yōu)化鏡像大??;

善用持久化緩存實現(xiàn)增量構(gòu)建 (編輯機會對 /cache/ 目錄下的內(nèi)容進(jìn)行持久緩存)

充分利用多核優(yōu)勢:

比如 ts-loader 的類型校驗就可以通過其它插件在單獨的線程執(zhí)行,eslint-loader 也支持多線程 (但目前有 bug, 不建議使用).

再比如我們可以對項目的各功能模塊解耦,拆成多個構(gòu)建同時進(jìn)行。

減少不必要的構(gòu)建:

比如合理配置 exclude 以精簡構(gòu)建文件范圍;

對于不常變動的文件,拆出來一次構(gòu)建,下次復(fù)用.

判斷是否可能有其它方式去掉對外網(wǎng)依賴的包

如何分析構(gòu)建速度

檢查 /cache/ 目錄大小:

在編譯命令中加入:du -sh /cache, 通過構(gòu)建日志查看目錄大小

在整體編譯命令前后都加上date, 可以看自己項目的構(gòu)建過程耗時,即編譯命令執(zhí)行時間

在主要的編譯命令的每一行前面加上time, eg:time npm install可以看 install 過程的實際耗時,build 過程同理.

對比整體構(gòu)建時間 (網(wǎng)頁上直接顯示的任務(wù)時間) 與編譯命令執(zhí)行時間 (末尾的 date 時間 - 開頭的 date 時間), 如果整體時間超過編譯命令執(zhí)行時間很多 (> 1min30s), 可能是 /cache/ 目錄或鏡像過大導(dǎo)致的。

以下為詳情介紹:

使用更小的運行鏡像

如果有較大的鏡像,建議聯(lián)系運維進(jìn)行優(yōu)化.

善用持久緩存

緩存可以對應(yīng)用構(gòu)建帶來提速的效果,但如果緩存目錄持續(xù)增長,大到一定程度反倒可能讓速度變慢.

了解緩存機制:

1. 緩存目錄: /cache/

2. 默認(rèn)行為: 對于 nodejs 的應(yīng)用, 目前持久緩存會為 npm, pnpm 提供安裝包的緩存, 以加快 npm install / pnpm install 的過程

3. 工作原理: 

    3.1 /cache/ 目錄下的內(nèi)容會構(gòu)建成功后自動上傳到服務(wù)器進(jìn)行存儲, 并在下次構(gòu)建任務(wù)執(zhí)行前進(jìn)行掛載

    3.2 /cache/ 與 當(dāng)前工作目錄(即 './', 拉取的源碼存放位置) 不在同一個文件系統(tǒng)(相當(dāng)于是緩存在C盤而源碼在D盤), pnpm install的行為將從 hark link回退為文件復(fù)制(硬鏈接的方式相對于大量小文件的拷貝, 速度要快很多)

    3.3 /cache/ 的工作涉及上傳、下載過程, 如果過大也將會影響整個構(gòu)建過程的速度

排除全局緩存對構(gòu)建速度的影響

檢查 /cache/ 的大小,可以在編譯命令中加入:du -sh /cache, 查看日志,如果文件夾超過 1G (僅供參考), 建議咚咚聯(lián)系行云部署 (j-one) 對應(yīng)用緩存進(jìn)行清理

解決緩存跨盤造成的性能損失

主要思路: 使源碼與 /cache/ 處于同一個文件系統(tǒng)。目前對于 pnpm 的應(yīng)用推薦該方式. 原理: 使源碼與 /cache/ 處于同一個文件系統(tǒng),這可以讓 pnpm 的 hard link 方式生效,相對于 node_modules 那些數(shù)以萬計的小文件復(fù)制,執(zhí)行效率會得到可觀的提升。參考:Pnpm 是否可以跨多個驅(qū)動器或文件系統(tǒng)工作? 方式: 將當(dāng)前工作目錄的代碼復(fù)制到 /cache/ 下再執(zhí)行 install、build 命令. 參考命令:

    # 記下當(dāng)前工作目錄
    CUR_WORKSPACE=`pwd`
    # 存放源碼
    # 咱統(tǒng)一用 /cache/source 放源碼就好, 雖然也可以改成其它目錄的名字
    mkdir -p /cache/source
    # 拷貝當(dāng)前目錄的代碼, 到 /cache/source 下
    rsync -r ./ /cache/source --exclude=node_modules --exclude=.git
    # 切換 workspace
    cd  /cache/source
    ########## 這里替換成自己需要的內(nèi)容  ###########
    # 執(zhí)行 install
    pnpm i
    # 執(zhí)行 build
    pnpm run build
    ########## 這里替換成自己需要的內(nèi)容  ###########

    # 將構(gòu)建結(jié)果拷貝到抽包地址
    ########## 如果不是 dist, 請根據(jù)需要換成其它目錄, 就是你項目構(gòu)建完生成的目標(biāo)代碼目錄
    cp -r ./dist/* ${CUR_WORKSPACE}/.build
    # 刪除不需要被緩存的文件
    cd ../ && rm -rf /cache/source

以上編譯命令基于行云部署前端項目本身精簡

請大家在理解原理、思路的基礎(chǔ)上根據(jù)自身需要修改.

緩存構(gòu)建結(jié)果

webpack 及其插件,會對構(gòu)建結(jié)果進(jìn)行緩存。我們可以利用 /cache/ 的持久化緩存來實現(xiàn)代碼構(gòu)建緩存。其它構(gòu)建工具也可以參考相關(guān)文檔進(jìn)行配置. 如果使用 webpack4 或依賴 webpack4 的構(gòu)建工具,比如 @vue/cli-service 等,通常會使用 cache-loader 對構(gòu)建結(jié)果進(jìn)行緩存,babel-loader 也會有自己的構(gòu)建緩存,但默認(rèn)都放在 node_modules/.cache 目錄下,建議參考相關(guān)文檔將 cache 目錄設(shè)置為 /cache/build (或者其它 /cache/ 的子目錄) 對于 webpack5, 自己就已經(jīng)集成了 cache 功能,可以刪掉 cache-loader 等插件,減少不必要的工作。參考:webpack cache 如果是 monorepo 的應(yīng)用,還可以實現(xiàn)子項目級別的緩存,比如使用nx進(jìn)行 monorepo 的管理,則可以配置 NX_CACHE_DIRECTORY 來設(shè)置緩存地址,eg:

export NX_CACHE_DIRECTORY=/cache/jdos3-console-ui/.nx

eslint 也是一個很費時的操作,它也支持緩存,但默認(rèn)不開啟,如果有需要也可以開啟緩存,但緩存策略需要使用 'content', 因為每次構(gòu)建文件的 createTime 都會改變,metadata 的策略會失靈。參考:eslint cache 通常我們需要同時兼容本地開發(fā)和行云部署的構(gòu)建,可以通過環(huán)境變量的方式實現(xiàn),以 webpack5 為例: webpack5 的緩存配置:
{
    cache: {
        type: 'filesystem',
        profile: true,
        cacheDirectory: process.env.BUILD_CACHE_DIRECTORY,
        compression: 'gzip',
    },
}

同時在行云部署的編譯命令中增加:
export BUILD_CACHE_DIRECTORY=/cache/.webpack

另一種利用緩存的思路:緩存 node_modules

(編譯團(tuán)隊提出了這種思路,我目前沒有進(jìn)行相關(guān)嘗試,產(chǎn)品上針對該思路的通用解決方案在探索中)

主要思路: 模擬本地構(gòu)建 (本地構(gòu)建會持久保留 node_modules 目錄)

收益:

1. 加速 install 的過程,減少包的安裝.

2. 利用代碼構(gòu)建緩存: webpack5 或 babel-loader 等一般會在 node_modules/.cache 目錄下存放構(gòu)建緩存,這也是很多應(yīng)用本地構(gòu)建較快的原因。當(dāng)然 .cache 目錄會持續(xù)增長,需要定時清理,有興趣大家可以看看本地的代碼里是否有這個目錄,占多大空間. 參考命令:

大體上與上面 ' 解決緩存跨盤造成的性能損失 ' 過程相同,只是最后 rm 的過程保留 node_modules 目錄,以供下次使用

    ####### 與上面 解決緩存跨盤造成的性能損失 一致 #########
    # 記下當(dāng)前工作目錄
    CUR_WORKSPACE=`pwd`
    # 存放源碼
    mkdir -p /cache/source
    # 拷貝當(dāng)前目錄代碼到 /cache/ 下
    rsync -r ./ /cache/source --exclude=node_modules --exclude=.git
    # 切換 workspace
    cd  /cache/source
    # 執(zhí)行 install
    npm i
    # 執(zhí)行 build
    npm run build
    # 將構(gòu)建結(jié)果拷貝到抽包地址
    cp -r ./dist/* ${CUR_WORKSPACE}/.build
    
    ####### 差異: 刪除時排除 node_modules 目錄 #########
    # 刪除不需要被緩存的文件
    ls -A | grep -vE "^.$|^..$|^node_modules"|xargs rm -rf

減少源碼

避免在 coding 中提交 node_modules 以及各種大的二進(jìn)制文件

優(yōu)化編譯過程

優(yōu)化依賴包安裝的過程

有些項目依賴了 image-minimizer-webpack-plugin, 這是一個用于壓縮圖片的工具,該資源依賴的 cwebp-bin 等資源需要從海外的網(wǎng)站下載,這個過程可能會很慢甚至失敗。如果可能,建議直接提交壓縮后的圖片到代碼庫,同時去掉對這個插件的引用.

可以在編譯命令前加上 time, 比如time pnpm install來觀察這一步驟的耗時,如果這一步驟很長,可以看是否有可以去掉的依賴包,或者禁用對可選依賴包的安裝,有時候升級構(gòu)建工具也能使包依賴得到優(yōu)化.

優(yōu)化構(gòu)建過程

對于 webpack 構(gòu)建的應(yīng)用,對 rules、plugin (如果支持) 檢查是否正確設(shè)置了 exclude, 用以減少不必要的文件構(gòu)建

啟用構(gòu)建緩存 (但緩存的持續(xù)增長還是需要關(guān)注,緩存過大的問題后續(xù)可能從產(chǎn)品層面得以優(yōu)化)

ts-loader 通??梢蚤_啟 transpileOnly: true, 并通過fork-ts-checker-webpack-plugin進(jìn)行類型檢查

eslint 的優(yōu)化,可以對規(guī)則進(jìn)行優(yōu)化,有些校驗規(guī)則是非常耗時的,但同時受益并不是很大,可以考慮關(guān)閉。具體可以這么做:

4.1 設(shè)置 __TIMING__環(huán)境變量,可以啟用對每個 eslint rule 的性能分析,export TIMING = 1;

4.2 在本地正常執(zhí)行構(gòu)建,檢測 eslint rule performance 的輸出,分析耗時較長的規(guī)則,確認(rèn)是否必要

補充:

關(guān)于 eslint 的多線程問題:對 eslint 開啟多線程之后會導(dǎo)致 build 過程發(fā)現(xiàn)的規(guī)則異常不能拋出,導(dǎo)致規(guī)則實際會失效。該問題參考 Issue, 這個問題挺久了,一直沒有得到有效解決.

同時也可以考慮將 eslint 的校驗作為 git hook 執(zhí)行,避免提交不規(guī)范的代碼,此時在 build 過程可以省略這一步驟.

5. 代碼 minify 的過程,推薦使用 esbuild, 在 webpack 里面就可以配置.

{
   optimization: {
       minimize: true,
       minimizer: [
           new TerserPlugin({
               minify: TerserPlugin.esbuildMinify,
           }),
       ],
   }
}

6. 對于不經(jīng)常變動的部分,建議提前編譯,或通過 DllPlugin 進(jìn)行優(yōu)化。比如行云部署項目本身依賴 monaco editor, 但每次對它的源碼進(jìn)行構(gòu)建很耗時,所以直接將提前編譯好的代碼提交了,后續(xù)直接用.

7. 注意避免一個項目被 build 多次,比如:

7.1 對于使用 vue-cli-service 的應(yīng)用,v5.0.0-beta.0 開始,可能會根據(jù)瀏覽器列表配置生成不同的包,會導(dǎo)致多次構(gòu)建

7.2 有一些項目需要微前端接入,可能會為獨立運行時、子應(yīng)用模式采用不同的入口,從而構(gòu)建兩次。比如 JModule 的用戶,由于極早期 webpack-jmodule-plugin 的版本不能自定義入口文件,通常會構(gòu)建兩次,建議升級為最新的 @jmodule/plugin-webpack, 并且采用同一個入口文件構(gòu)建一次.

8. 如果是一個相對簡單的應(yīng)用,可以考慮換其它構(gòu)建工具,比如 esbuild、swc, 編程語言帶來的性能差異,確實能形成降維打擊.

9. 如果可能,分析項目代碼間的依賴,拆分為多個構(gòu)建并行執(zhí)行,編譯機的最大優(yōu)勢就是多核,咱可以充分利用.

10. 升級 webpack 以及其它構(gòu)建插件,通常也能帶來一定程度的速度提升,我們 jci 項目的編譯就從升級中獲得了一些受益.

前端構(gòu)建的提速是一項比較復(fù)雜且細(xì)節(jié)的工程,目前產(chǎn)品上在持續(xù)跟蹤構(gòu)建慢的應(yīng)用,努力優(yōu)化編譯速度,但前端本身擁有一個比較自由的技術(shù)環(huán)境,沒有統(tǒng)一的構(gòu)建工具與流程,另外語言本身的執(zhí)行效率、單線程的構(gòu)建也不好讓編譯機發(fā)揮其最大能力,所以目前全局的通用優(yōu)化手段還是會比較局限,還是依賴項目自身的優(yōu)化。希望大家一起努力共建美好的明天.





審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 驅(qū)動器
    +關(guān)注

    關(guān)注

    54

    文章

    8697

    瀏覽量

    149967
  • cache技術(shù)
    +關(guān)注

    關(guān)注

    0

    文章

    41

    瀏覽量

    1236

原文標(biāo)題:Nodejs應(yīng)用編譯構(gòu)建提速建議

文章出處:【微信號:OSC開源社區(qū),微信公眾號:OSC開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    OpenHarmony 移植:build lite 編譯構(gòu)建過程

    這些疑惑,會對 build lite 編譯構(gòu)建過程有個更深入的理解。 1、產(chǎn)品解決方案代碼是如何被調(diào)用編譯的 在文件 buildliteBUILD.gn 配置文件中的構(gòu)建目標(biāo) //bu
    的頭像 發(fā)表于 02-19 16:19 ?1269次閱讀

    鴻蒙開發(fā)【編譯構(gòu)建】講解

    編譯構(gòu)建是將應(yīng)用/服務(wù)的源代碼、資源、第三方庫等,通過編譯工具轉(zhuǎn)換為可直接在硬件設(shè)備上運行的二進(jìn)制機器碼,然后再將二進(jìn)制機器碼封裝為HAP/APP軟件包,并為HAP/APP包進(jìn)行簽名的過程。其中
    發(fā)表于 02-27 17:41

    buildroot中添加nodejs后推薦加哪些包?

    現(xiàn)有一IoT中運行的nodejs 16項目,計劃用buildroot部署在設(shè)備上。我將開發(fā)板中的buildroot升級后,成功編譯運行了nodejs16本體。但在啟動項目、依賴等時遇到各種“依賴
    發(fā)表于 11-01 12:57

    02.002 NodeJS入門 為什么要學(xué)習(xí)NodeJS

    nodejs
    充八萬
    發(fā)布于 :2023年07月19日 14:27:44

    07.007 NodeJS入門 命令的結(jié)構(gòu)

    nodejs
    充八萬
    發(fā)布于 :2023年07月19日 14:30:13

    04.004 NodeJS入門 NodeJS的作用 #硬聲創(chuàng)作季

    nodejs
    充八萬
    發(fā)布于 :2023年07月19日 14:33:58

    05.005 NodeJS入門 NodeJS的安裝

    nodejs
    充八萬
    發(fā)布于 :2023年07月19日 14:35:12

    01.001 NodeJS視頻簡介

    nodejs
    充八萬
    發(fā)布于 :2023年07月19日 19:05:48

    【W(wǎng)RTnode2R試用體驗】測試nodejs

    正好,WRTnode官方已經(jīng)編譯好了0.10版本的nodejs,現(xiàn)在我們看看怎么安裝下載下面的文件,我是下載到樹莓派中,然后通過SSH登錄WRTnode使用SCP命令從樹莓派獲取二進(jìn)制安裝包opkg
    發(fā)表于 12-05 21:58

    nodejs與java的互調(diào)用方法

    nodejs 與java的互調(diào)用方法很多,我們可選的是使用oracle 新的vm 引擎(graalvm很不錯) 還有就是基于browserify進(jìn)行包裝,同時給java 提供一套require
    發(fā)表于 11-04 07:31

    如何使用buildroot編譯構(gòu)建系統(tǒng)?

    如何使用buildroot編譯構(gòu)建系統(tǒng)?
    發(fā)表于 12-28 07:14

    OpenHarmony應(yīng)用的編譯構(gòu)建過程

    2022 年 3 月 31 日發(fā)布了最新的 IDE 工具 DevEco Studio 3.0 Beta3,仔細(xì)閱讀文檔后發(fā)現(xiàn)最新 OpenHarmony 應(yīng)用的編譯構(gòu)建過程已經(jīng)公開。
    的頭像 發(fā)表于 04-21 08:13 ?4352次閱讀

    使用Homebridge和HAP NodeJS來模擬HomeKit API

    電子發(fā)燒友網(wǎng)站提供《使用Homebridge和HAP NodeJS來模擬HomeKit API.zip》資料免費下載
    發(fā)表于 07-10 10:42 ?0次下載
    使用Homebridge和HAP <b class='flag-5'>NodeJS</b>來模擬HomeKit API

    【技術(shù)視界】DevEco Hvigor高效編譯,構(gòu)建過程新秘籍

    的是華為終端BG編譯構(gòu)建技術(shù)專家的分享,希望能為您的開發(fā)之路帶來啟發(fā)~ 作者:Lewei,華為終端BG編譯構(gòu)建技術(shù)專家 DevEcoHvigor是使用TypeScript語言開發(fā)的全新
    的頭像 發(fā)表于 09-26 12:10 ?1539次閱讀
    【技術(shù)視界】DevEco Hvigor高效<b class='flag-5'>編譯</b>,<b class='flag-5'>構(gòu)建</b>過程新秘籍

    鴻蒙OpenHarmony開發(fā):【編譯構(gòu)建指導(dǎo)】

    OpenHarmony編譯子系統(tǒng)是以GN和Ninja構(gòu)建為基座,對構(gòu)建和配置粒度進(jìn)行部件化抽象、對內(nèi)建模塊進(jìn)行功能增強、對業(yè)務(wù)模塊進(jìn)行功能擴展的系統(tǒng),該系統(tǒng)提供以下基本功能
    的頭像 發(fā)表于 05-13 09:31 ?2684次閱讀
    鴻蒙OpenHarmony開發(fā):【<b class='flag-5'>編譯</b><b class='flag-5'>構(gòu)建</b>指導(dǎo)】