Synchronisation d'un package NPM entre plusieurs registres
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 :
- Installez le package localement à partir du registre A.
- Reconfigurez NPM pour pointer vers le registre B.
- 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>"
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:>"
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>"
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:>"
Vous donnera (comme prévu) :
npm config set "//my.registry.com:_authToken=<token>"
Avec docker Linuxkit :
echo -n "<my username & password hash>" | base64
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==
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==
Vous pouvez donc l'utiliser comme ceci :
echo -n "<my username & password hash>" | base64 --wrap 0
Principales leçons apprises
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.Attention aux détails :
La configuration de l'authentification, en particulier avec base64, peut présenter de subtiles bizarreries spécifiques à la plate-forme.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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

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.

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.

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 ...

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.

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.

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 JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

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. � ...
