首頁 web前端 js教程 在多個登錄機碼之間同步 NPM 包

在多個登錄機碼之間同步 NPM 包

Nov 25, 2024 am 07:53 AM

Syncing an NPM Package Between Multiple Registries

照片由 Nicolas Radzimski 在 Unsplash 拍攝

問題

我們的團隊依賴內部 GitLab NPM 註冊表來管理套件。這非常適合內部分發,但在某些情況下需要與外部協作者共用套件。將套件從內部註冊表同步到外部註冊表成為一項新的挑戰。

我開始尋找解決方案,但像往常一樣,遇到了一系列障礙,這使我的開發者鬥爭變成了又一章。

試試 1:使用 HTTP 請求模仿 NPM CLI

最初,我認為我可以使用原始 HTTP 請求來處理這個問題,本質上是模仿 NPM CLI 在幕後所做的事情。這個想法很簡單:查詢來源註冊表中的包元數據,獲取 tarball,並將其上傳到目標註冊表。

為什麼失敗:

• 過程過於複雜且脆弱。
• 它需要為每個版本手動建立整個package.json 清單。
• 每一個小失誤都會造成包裹破損。

試試 2:利用 npm-registry-sync

接下來,我發現了 npm-registry-sync,一個專為同步 NPM 註冊表而設計的函式庫。這個工具幾乎解決了這個問題;它可以監控更改並跨註冊表複製它們。

為什麼它對我不起作用:

• 它以「守護程式模式」運行,並不斷輪詢更新。
• 在 GitLab CI 管道中,我需要一次執行,完全由管道控制 — 不允許後台程序。

獲勝解決方案:NPM CLI

最終,我意識到我可以堅持使用久經考驗的 NPM CLI。步驟很簡單:

  1. 從註冊表 A 本地安裝軟體包。
    1. 重新配置 NPM 以指向註冊表 B。
    2. 將套件發佈到Registry B。

雖然這很神奇,但需要一些額外的步驟才能使其對 CI 友好。


為多個登錄配置 NPM

在 CI 管道中動態管理登錄機碼配置有點棘手。

這是我解決的方法:

整體配置

使用 npm CLI,您可以為每個登錄機碼設定參數:

npm config set "//my.awesome.registry.com:<parameter name>=<parameter value>"
登入後複製
登入後複製

重要問題:
配置中的 URL 必須排除協定 (https:)。

包到註冊表關聯

將特定命名空間或套件與登錄機碼關聯:

npm config set "<your namespace>:registry" "<your registry url with https:>"
登入後複製
登入後複製

處理 CI 管道中的身份驗證

有些註冊表需要使用者名稱/密碼組合,而其他註冊表則使用令牌。這是我學到的:

代幣

令牌很簡單,但請確保在設定驗證 URL 時剝離協定:

npm config set "//my.awesome.registry.com:<parameter name>=<parameter value>"
登入後複製
登入後複製

基本認證

產生基本的身份驗證雜湊(使用者名稱:密碼)需要注意細節。在某些發行版中,base64 指令具有與其他發行版不同的怪癖。

在 macOS 上:

npm config set "<your namespace>:registry" "<your registry url with https:>"
登入後複製
登入後複製

會給你(如預期):

npm config set "//my.registry.com:_authToken=<token>"
登入後複製

使用 docker linuxkit:

echo -n "<my username & password hash>" | base64
登入後複製

這是怎麼回事?換行了!

在某些發行版上,wrap 參數預設為 76 個字符,用於格式化私鑰等。

它的運作方式如下:

d2hhdCBhcmUgeW91IGRvaW5nIGhlcmU/IGdvdCB5YSEgc29tZSBtb3JlIHRleHQgdG8gbWFrZSB0aGlzIHJlYWxseSByZWFsbHkgbG9uZw==
登入後複製

echo -n 非常重要。如果省略,echo 會在字串末尾添加換行符,這將操縱您的雜湊值。

完成的腳本

將它們放在一起,腳本可能如下所示:

d2hhdCBhcmUgeW91IGRvaW5nIGhlcmU/IGdvdCB5YSEgc29tZSBtb3JlIHRleHQgdG8gbWFrZSB0
aGlzIHJlYWxseSByZWFsbHkgbG9uZw==
登入後複製

所以你可以像這樣使用它:

echo -n "<my username & password hash>" | base64 --wrap 0
登入後複製

主要經驗教訓

  1. 堅持使用簡單的工具:
    npm CLI 可能不太適合這項任務,但它很可靠並且可以完成工作。

  2. 注意細節:
    配置身份驗證,尤其是使用 Base64,可能會出現微妙的特定於平台的怪癖。

  3. 保持 CI 友善:
    在 CI/CD 管道中工作時,避免使用守護程序或後台任務等解決方案。讓流程處於管道控制之下。

在登錄機碼之間同步 npm 套件是令人沮喪但有益的學習經驗。如果您面臨類似的挑戰,我希望這些課程可以幫助您更輕鬆地度過難關!

以上是在多個登錄機碼之間同步 NPM 包的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1655
14
CakePHP 教程
1414
52
Laravel 教程
1307
25
PHP教程
1253
29
C# 教程
1228
24
神秘的JavaScript:它的作用以及為什麼重要 神秘的JavaScript:它的作用以及為什麼重要 Apr 09, 2025 am 12:07 AM

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

JavaScript的演變:當前的趨勢和未來前景 JavaScript的演變:當前的趨勢和未來前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript引擎:比較實施 JavaScript引擎:比較實施 Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript:探索網絡語言的多功能性 JavaScript:探索網絡語言的多功能性 Apr 11, 2025 am 12:01 AM

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

Python vs. JavaScript:學習曲線和易用性 Python vs. JavaScript:學習曲線和易用性 Apr 16, 2025 am 12:12 AM

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

如何使用Next.js(前端集成)構建多租戶SaaS應用程序 如何使用Next.js(前端集成)構建多租戶SaaS應用程序 Apr 11, 2025 am 08:22 AM

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

從C/C到JavaScript:所有工作方式 從C/C到JavaScript:所有工作方式 Apr 14, 2025 am 12:05 AM

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

如何安裝JavaScript? 如何安裝JavaScript? Apr 05, 2025 am 12:16 AM

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

See all articles