Maison interface Web js tutoriel Synchronisation d'un package NPM entre plusieurs registres

Synchronisation d'un package NPM entre plusieurs registres

Nov 25, 2024 am 07:53 AM

Syncing an NPM Package Between Multiple Registries

Photo de Nicolas Radzimski sur Unsplash

Le problème

Notre équipe s'appuie sur un registre interne GitLab NPM pour la gestion des packages. Cela fonctionne parfaitement pour la distribution interne, mais il existe des cas où un package doit être partagé avec des collaborateurs externes. Synchroniser le package du registre interne vers un registre externe est devenu un nouveau défi.

J'ai cherché une solution et, comme d'habitude, j'ai rencontré une série d'obstacles qui en ont fait un autre chapitre de mes difficultés de développeur.

Tentative 1 : Utilisation de requêtes HTTP pour imiter la CLI NPM

Au départ, je pensais pouvoir gérer cela avec des requêtes HTTP brutes, imitant essentiellement ce que fait la CLI NPM sous le capot. L'idée était simple : interrogez le registre source pour les métadonnées du package, récupérez l'archive tar et téléchargez-la dans le registre cible.

Pourquoi cela a échoué :

• Le processus était trop complexe et fragile.
• Cela nécessitait de construire manuellement l'intégralité du manifeste package.json pour chaque version.
• Chaque petit faux pas entraînait des colis cassés.

Tentative 2 : tirer parti de npm-registry-sync

Ensuite, j'ai découvert npm-registry-sync, une bibliothèque conçue pour synchroniser les registres NPM. Cet outil a presque résolu le problème ; il pourrait surveiller les changements et les reproduire dans les registres.

Pourquoi ça n'a pas fonctionné pour moi :

• Il fonctionne en « mode démon », interrogeant continuellement les mises à jour.
• Dans un pipeline GitLab CI, j'avais besoin d'une exécution unique, entièrement contrôlée par le pipeline — aucun processus en arrière-plan n'est autorisé.

La solution gagnante : la CLI NPM

Finalement, j'ai réalisé que je pouvais m'en tenir à la CLI NPM éprouvée. Les étapes étaient simples :

  1. Installez le package localement à partir du registre A.
    1. Reconfigurez NPM pour pointer vers le registre B.
    2. Publiez le package dans le registre B.

Bien que cela ait fonctionné à merveille, quelques étapes supplémentaires ont été nécessaires pour le rendre compatible avec CI.


Configuration de NPM pour plusieurs registres

La gestion dynamique des configurations de registre dans un pipeline CI était un peu délicate.

Voici comment je l'ai résolu :

Configuration générale

À l'aide de la CLI npm, vous pouvez définir des paramètres pour chaque registre :

npm config set "//my.awesome.registry.com:<parameter name>=<parameter value>"
Copier après la connexion
Copier après la connexion

Je vous ai trouvé important :
L'URL dans la configuration doit exclure le protocole (https:).

Association package-registre

Pour associer un espace de noms ou un package spécifique à un registre :

npm config set "<your namespace>:registry" "<your registry url with https:>"
Copier après la connexion
Copier après la connexion

Gestion de l'authentification dans les pipelines CI

Certains registres nécessitaient une combinaison nom d'utilisateur/mot de passe, tandis que d'autres utilisaient des jetons. Voici ce que j'ai appris :

Jetons

Les jetons sont simples, mais assurez-vous de supprimer le protocole lors de la configuration de l'URL d'authentification :

npm config set "//my.awesome.registry.com:<parameter name>=<parameter value>"
Copier après la connexion
Copier après la connexion

Authentification de base

La génération d'un hachage d'authentification de base (nom d'utilisateur : mot de passe) nécessitait une attention particulière aux détails. Dans certaines distributions, la commande base64 présente des bizarreries qui diffèrent des autres.

Sur macOS :

npm config set "<your namespace>:registry" "<your registry url with https:>"
Copier après la connexion
Copier après la connexion

Vous donnera (comme prévu) :

npm config set "//my.registry.com:_authToken=<token>"
Copier après la connexion

Avec docker Linuxkit :

echo -n "<my username & password hash>" | base64
Copier après la connexion

Que se passe-t-il ici ? Il y a un saut de ligne !

Sur certaines distributions, le paramètre wrap a une valeur par défaut de 76 caractères pour le formatage des clés privées, etc.

Ça fonctionne comme ceci :

d2hhdCBhcmUgeW91IGRvaW5nIGhlcmU/IGdvdCB5YSEgc29tZSBtb3JlIHRleHQgdG8gbWFrZSB0aGlzIHJlYWxseSByZWFsbHkgbG9uZw==
Copier après la connexion

Le echo -n est très important. En cas d'omission, echo ajoutera un saut de ligne à la fin de la chaîne et cela manipulera votre hachage.

Le scénario terminé

En mettant tout cela ensemble, le script pourrait ressembler à ceci :

d2hhdCBhcmUgeW91IGRvaW5nIGhlcmU/IGdvdCB5YSEgc29tZSBtb3JlIHRleHQgdG8gbWFrZSB0
aGlzIHJlYWxseSByZWFsbHkgbG9uZw==
Copier après la connexion

Vous pouvez donc l'utiliser comme ceci :

echo -n "<my username & password hash>" | base64 --wrap 0
Copier après la connexion

Principales leçons apprises

  1. S'en tenir à des outils simples :
    La CLI npm n'est peut-être pas sophistiquée pour cette tâche, mais elle est fiable et fait le travail.

  2. Attention aux détails :
    La configuration de l'authentification, en particulier avec base64, peut présenter de subtiles bizarreries spécifiques à la plate-forme.

  3. Gardez-le compatible avec CI :
    Évitez les solutions telles que les démons ou les tâches en arrière-plan lorsque vous travaillez dans des pipelines CI/CD. Gardez le processus sous contrôle du pipeline.

La synchronisation des packages npm entre les registres a été une expérience d'apprentissage frustrante mais enrichissante. Si vous êtes confronté à un défi similaire, j’espère que ces leçons vous aideront à naviguer dans la lutte avec un peu plus de facilité !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment créer et publier mes propres bibliothèques JavaScript? Comment créer et publier mes propres bibliothèques JavaScript? Mar 18, 2025 pm 03:12 PM

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

Comment optimiser le code JavaScript pour les performances dans le navigateur? Comment optimiser le code JavaScript pour les performances dans le navigateur? Mar 18, 2025 pm 03:14 PM

L'article traite des stratégies pour optimiser les performances JavaScript dans les navigateurs, en nous concentrant sur la réduction du temps d'exécution et la minimisation de l'impact sur la vitesse de chargement de la page.

Que dois-je faire si je rencontre l'impression de code brouillé pour les reçus en papier thermique frontal? Que dois-je faire si je rencontre l'impression de code brouillé pour les reçus en papier thermique frontal? Apr 04, 2025 pm 02:42 PM

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

Comment déboguer efficacement le code JavaScript à l'aide d'outils de développeur de navigateur? Comment déboguer efficacement le code JavaScript à l'aide d'outils de développeur de navigateur? Mar 18, 2025 pm 03:16 PM

L'article traite du débogage efficace de JavaScript à l'aide d'outils de développeur de navigateur, de se concentrer sur la définition des points d'arrêt, de l'utilisation de la console et d'analyser les performances.

Qui est payé plus de python ou de javascript? Qui est payé plus de python ou de javascript? Apr 04, 2025 am 12:09 AM

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

Comment utiliser les cartes source pour déboguer le code JavaScript minifié? Comment utiliser les cartes source pour déboguer le code JavaScript minifié? Mar 18, 2025 pm 03:17 PM

L'article explique comment utiliser les cartes source pour déboguer JavaScript minifiée en le mappant au code d'origine. Il discute de l'activation des cartes source, de la définition de points d'arrêt et de l'utilisation d'outils comme Chrome Devtools et WebPack.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en utilisant JavaScript? Comment fusionner les éléments du tableau avec le même ID dans un seul objet en utilisant JavaScript? Apr 04, 2025 pm 05:09 PM

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

La différence dans Console.Log de sortie Résultat: Pourquoi les deux appels sont-ils différents? La différence dans Console.Log de sortie Résultat: Pourquoi les deux appels sont-ils différents? Apr 04, 2025 pm 05:12 PM

Discussion approfondie des causes profondes de la différence de sortie Console.log. Cet article analysera les différences dans les résultats de sortie de la fonction Console.log dans un morceau de code et expliquera les raisons derrière. � ...

See all articles