


Wie erstelle ich Go-Apps mit privaten GitLab-Modulen in Docker mithilfe von SSH?
Go-Apps mit privaten GitLab-Modulen in Docker erstellen
Dieser Leitfaden zielt darauf ab, die spezifischen Herausforderungen anzugehen, die bei der Integration privater GitLab-Module in Go-Anwendungen auftreten innerhalb von Docker.
Verstehen der Problem
Das Problem tritt auf, wenn eine Docker-Datei versucht, private Pakete aus GitLab abzurufen, die Authentifizierung jedoch fehlschlägt, obwohl ähnliche Tutorials für GitHub befolgt wurden. Dieses spezifische Problem ergibt sich aus den Unterschieden zwischen den Authentifizierungsmechanismen von GitHub und GitLab.
Vorgeschlagene Lösung
Um dieses Problem zu lösen, werden wir die SSH-basierte Authentifizierung verwenden und Dockers experimentelle Methode einsetzen Funktionen.
Experimenteller Docker Funktionen
Aktivieren Sie experimentelle Docker-Funktionen, indem Sie den folgenden Kommentar am Anfang Ihrer Docker-Datei hinzufügen:
# syntax=docker/dockerfile:experimental
Dockerfile-Setup
- Stellen Sie sicher, dass Ihre Build-Umgebung dies hat openssh-client:
RUN apk --no-cache add build-base git mercurial gcc curl openssh-client
- Bekannte_Hosts einrichten und .gitconfig konfigurieren:
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
- Erstellen Sie Ihre Go-Anwendung mit SSH-basierter Authentifizierung :
ENV GO111MODULE=on ENV GOPRIVATE=gitlab.com/<company-name> RUN --mount=type=ssh cd cmd/app/ && go build -o app
Eingabetaste laden ssh-agent
Bevor das Docker-Image erstellt wird, muss der private Schlüssel in den ssh-agent geladen werden:
ssh-add id_rsa
Erstellen des Docker-Image
Erstellen Sie das Docker-Image wie folgt Befehl:
DOCKER_BUILDKIT=1 docker build --progress=plain .
Debuggen der SSH-Verbindung
Wenn SSH-Verbindungsprobleme auftreten, fügen Sie den folgenden Debug-Befehl zu Ihrer Docker-Datei hinzu:
RUN ssh -A -v -l git gitlab.com
Beheben des AppArmor-Problems
Wenn Apparmor Docker blockiert Zugriff auf den SSH-Schlüssel-Socket, bearbeiten Sie das Apparmor-Profil und fügen Sie die folgende Zeile vor dem schließenden } hinzu:
/run/user/1000/keyring/ssh rw,
Problem mit dem Schlüsseldateinamen
Stellen Sie sicher, dass der private Schlüssel vorhanden ist Dateiname ist einer der Standardwerte, die SSH erwartet (z. B. id_rsa) oder verwenden Sie die Datei .ssh/config, um dem erwarteten einen benutzerdefinierten Schlüsselnamen zuzuordnen Standard.
Zusätzliche Hinweise
Vermeiden Sie die Verwendung von chmod zum Erteilen von Berechtigungen, da der SSH-Schlüsseleintrag für die Freigabe des privaten Schlüssels ausreicht. Es wird außerdem empfohlen, die Verwendung von .netrc zu vermeiden, da es Anmeldeinformationen in das Docker-Image einbettet und möglicherweise die Sicherheit gefährdet.
Das obige ist der detaillierte Inhalt vonWie erstelle ich Go-Apps mit privaten GitLab-Modulen in Docker mithilfe von SSH?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

OpenSSL bietet als Open -Source -Bibliothek, die in der sicheren Kommunikation weit verbreitet sind, Verschlüsselungsalgorithmen, Tasten und Zertifikatverwaltungsfunktionen. In seiner historischen Version sind jedoch einige Sicherheitslücken bekannt, von denen einige äußerst schädlich sind. Dieser Artikel konzentriert sich auf gemeinsame Schwachstellen und Antwortmaßnahmen für OpenSSL in Debian -Systemen. DebianopensL Bekannte Schwachstellen: OpenSSL hat mehrere schwerwiegende Schwachstellen erlebt, wie z. Ein Angreifer kann diese Sicherheitsanfälligkeit für nicht autorisierte Lesen sensibler Informationen auf dem Server verwenden, einschließlich Verschlüsselungsschlüssel usw.

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...

Wie kann man im Beegoorm -Framework die mit dem Modell zugeordnete Datenbank angeben? In vielen BeEGO -Projekten müssen mehrere Datenbanken gleichzeitig betrieben werden. Bei Verwendung von BeEGO ...

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

In diesem Artikel werden eine Vielzahl von Methoden und Tools eingeführt, um PostgreSQL -Datenbanken im Debian -System zu überwachen, um die Datenbankleistung vollständig zu erfassen. 1. verwenden Sie PostgreSQL, um die Überwachungsansicht zu erstellen. PostgreSQL selbst bietet mehrere Ansichten für die Überwachung von Datenbankaktivitäten: PG_STAT_ACTIVITY: Zeigt Datenbankaktivitäten in Echtzeit an, einschließlich Verbindungen, Abfragen, Transaktionen und anderen Informationen. PG_STAT_REPLIKATION: Monitore Replikationsstatus, insbesondere für Stream -Replikationscluster. PG_STAT_DATABASE: Bietet Datenbankstatistiken wie Datenbankgröße, Transaktionsausschüsse/Rollback -Zeiten und andere Schlüsselindikatoren. 2. Verwenden Sie das Log -Analyse -Tool PGBADG
