recherche
Maisondéveloppement back-endGolangComment créer des applications Go avec des modules GitLab privés dans Docker à l'aide de SSH ?

How to Build Go Apps with Private GitLab Modules in Docker using SSH?

Création d'applications Go avec des modules GitLab privés dans Docker

Ce guide vise à répondre aux défis spécifiques rencontrés lors de l'intégration de modules GitLab privés dans des applications Go au sein de Docker.

Comprendre le Problème

Le problème survient lorsqu'un Dockerfile tente d'extraire des packages privés de GitLab, mais que l'authentification échoue malgré le suivi de didacticiels similaires pour GitHub. Ce problème spécifique provient des différences entre les mécanismes d'authentification de GitHub et de GitLab.

Solution proposée

Pour résoudre ce problème, nous utiliserons l'authentification basée sur SSH et emploierons l'expérimentation de Docker. fonctionnalités.

Docker expérimental Fonctionnalités

Activez les fonctionnalités expérimentales de Docker en ajoutant le commentaire suivant au début de votre Dockerfile :

# syntax=docker/dockerfile:experimental

Configuration du fichier Docker

  1. Assurez-vous que votre environnement de construction a openssh-client :
RUN apk --no-cache add build-base git mercurial gcc curl openssh-client
  1. Établissez des hôtes_connus et configurez .gitconfig :
RUN mkdir -p -m 0700 ~/.ssh && \
    ssh-keyscan gitlab.com >> ~/.ssh/known_hosts && \
    echo -e "[url \"[email protected]:<company-name>\"]\n\tinsteadOf = https://gitlab.com/<company-name>\"" >> ~/.gitconfig</company-name></company-name>
  1. Créez votre application Go avec l'authentification basée sur SSH :
ENV GO111MODULE=on
ENV GOPRIVATE=gitlab.com/<company-name>
RUN --mount=type=ssh cd cmd/app/ && go build -o app</company-name>

Charger la clé ssh-agent

Avant de créer l'image Docker, la clé privée doit être chargée dans ssh-agent :

ssh-add id_rsa

Construire l'image Docker

Créez l'image Docker en utilisant ce qui suit command :

DOCKER_BUILDKIT=1 docker build --progress=plain .

Débogage de la connexion SSH

Si des problèmes de connexion SSH surviennent, ajoutez la commande de débogage suivante à votre Dockerfile :

RUN ssh -A -v -l git gitlab.com

Résoudre le problème d'AppArmor

Si Apparmor bloque Accédez à Docker au socket de clé SSH, modifiez le profil apparmor et ajoutez la ligne suivante avant le } de fermeture :

/run/user/1000/keyring/ssh rw,

Problème de nom de fichier clé

Assurez-vous que le le nom de fichier de clé est l'une des valeurs par défaut attendues par SSH (par exemple, id_rsa) ou utilisez le fichier .ssh/config pour mapper un nom de clé personnalisé à la valeur par défaut attendue.

Notes supplémentaires

Évitez d'utiliser chmod pour accorder des autorisations, car l'entrée de la clé SSH est suffisante pour partager la clé privée. Il est également recommandé d'éviter d'utiliser .netrc car il intègre les informations d'identification dans l'image Docker, compromettant potentiellement la sécurité.

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
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
Aller par rapport aux autres langues: une analyse comparativeAller par rapport aux autres langues: une analyse comparativeApr 28, 2025 am 12:17 AM

GOISASTRONGCHOICEFORPROSTRESSNEDINGSIMPLICITY, Performance et Concurrence, ButMaylackinAdvancedFeaturesAnSystemMaturity.1) Go'SyntaxisSIMPLEADEASYTOLEARN, LeadToFewerBugsandMoreMaintAwing

Comparaison des fonctions d'initié dans les initialiseurs statiques dans d'autres languesComparaison des fonctions d'initié dans les initialiseurs statiques dans d'autres languesApr 28, 2025 am 12:16 AM

Go'SinitFonctionnalandjava'sstaticitialisersbothservetOsEtunvironments peut-être la fonctionnalisation de la manière, mais ladifferinexecution et leControl.

Cas d'utilisation courants pour la fonction d'init en GoCas d'utilisation courants pour la fonction d'init en GoApr 28, 2025 am 12:13 AM

The CommermonusecasesFortFortFonctioningoAre: 1) ChargeingConfigurationFiles est en train de faire la diffusion de programmes, 2) d'initialiser les globalvariables, et3) RunningPre-Checkorvalidations est possible

Canaux dans Go: maîtriser la communication inter-goroutineCanaux dans Go: maîtriser la communication inter-goroutineApr 28, 2025 am 12:04 AM

Les canaux se sont émeurés de la création de personnes interrogées entre les degortines.

Erreurs d'emballage en Go: ajoutant du contexte aux chaînes d'erreurErreurs d'emballage en Go: ajoutant du contexte aux chaînes d'erreurApr 28, 2025 am 12:02 AM

Dans GO, les erreurs peuvent être enveloppées et le contexte peut être ajouté via des méthodes Errors.Wrap et Errors.unwrap. 1) En utilisant la nouvelle fonctionnalité du package Erreurs, vous pouvez ajouter des informations de contexte lors de la propagation des erreurs. 2) Aidez à localiser le problème en emballage les erreurs via fmt.errorf et% w. 3) Les types d'erreur personnalisés peuvent créer des erreurs plus sémantiques et améliorer la capacité expressive de la gestion des erreurs.

Considérations de sécurité lors du développement avec GoConsidérations de sécurité lors du développement avec GoApr 27, 2025 am 12:18 AM

Gooffersrobustfeaturesforsecucoding, ButdeveloversMustimplementSecurityBestPracticeseffectively.1) usego'scryptopackageforsecureatahandling.2) manageCurrencywithSynchronizationPrimiTeStOpreventraceConDITIONS.3)

Comprendre l'interface d'erreur de GoComprendre l'interface d'erreur de GoApr 27, 2025 am 12:16 AM

L'interface d'erreur de Go est définie comme TypeErrorInterface {error () String}, permettant à tout type qui implémente la méthode Error () d'être considérée comme une erreur. Les étapes à utiliser sont les suivantes: 1. Fondamentalement, vérifiez et journalisez les erreurs, telles que IFERR! = NIL {log.printf ("ANERROROCCURRED:% V", ERR) RETOUR}. 2. Créez un type d'erreur personnalisé pour fournir plus d'informations, telles que TypeMyErrorStruct {msgStringDetailString}. 3. Utilisez des emballages d'erreur (depuis Go1.13) pour ajouter du contexte sans perdre le message d'erreur d'origine,

Gestion des erreurs dans les programmes GO simultanésGestion des erreurs dans les programmes GO simultanésApr 27, 2025 am 12:13 AM

Toefficativement handleerrorsinconcurrentGOprograms, usEchannelStoCommunicateErrors, metterororwatchers, considérer les channeaux usuered, et les fournisseurs

See all articles

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

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit